- 浏览: 7986891 次
- 性别:
- 来自: 广州
-
文章分类
- 全部博客 (2425)
- 软件工程 (75)
- JAVA相关 (662)
- ajax/web相关 (351)
- 数据库相关/oracle (218)
- PHP (147)
- UNIX/LINUX/FREEBSD/solaris (118)
- 音乐探讨 (1)
- 闲话 (11)
- 网络安全等 (21)
- .NET (153)
- ROR和GOG (10)
- [网站分类]4.其他技术区 (181)
- 算法等 (7)
- [随笔分类]SOA (8)
- 收藏区 (71)
- 金融证券 (4)
- [网站分类]5.企业信息化 (3)
- c&c++学习 (1)
- 读书区 (11)
- 其它 (10)
- 收藏夹 (1)
- 设计模式 (1)
- FLEX (14)
- Android (98)
- 软件工程心理学系列 (4)
- HTML5 (6)
- C/C++ (0)
- 数据结构 (0)
- 书评 (3)
- python (17)
- NOSQL (10)
- MYSQL (85)
- java之各类测试 (18)
- nodejs (1)
- JAVA (1)
- neo4j (3)
- VUE (4)
- docker相关 (1)
最新评论
-
xiaobadi:
jacky~~~~~~~~~
推荐两个不错的mybatis GUI生成工具 -
masuweng:
(转)JAVA获得机器码的实现 -
albert0707:
有些扩展名为null
java 7中可以判断文件的contenttype了 -
albert0707:
非常感谢!!!!!!!!!
java 7中可以判断文件的contenttype了 -
zhangle:
https://zhuban.me竹板共享 - 高效便捷的文档 ...
一个不错的网络白板工具
1 数据字典存放数据库的元数据,包括 内部rdbms(x$)表,数据字典表,
动态性能视图和数据字典视图
2 内部RDBMS(X$)表
为加密的表,跟踪内部数据库信息,
可以select kvittag,kvitval,kvitdsc from x$kvit
看一些内部参数
3 数据字典表
保存表,索引,约束等数据库结构的信息,以 $结尾,sql.bsq文件来创建;
其中dba_objects中的object_id和data_object_id中,object_id为逻辑号,一旦分配
就不会改变,data_object_i为物理号,有可能发生改变。
4 静态数据字典视图,不能直接被修改,分三类
USER_类:包含了用户所有的相关信息,ALL_类,DBA_类(需要select any table
权限)
5 常见视图
1)DICT
返回当前用户可以访问的所有数据字典视图
select table_name from dict where table_name like '%TABLES$%';
返回和TABLES相关的视图
2)DICT_COLUMNS
记录了字典视图列及相关说明
3)obj 为user_objects建立的同义词,获得用户所拥有的对象信息
select object_name,object_type from obj;
6 动态视图
oracle创建GV$和v$视图,GV$ 满足RAC需要。通过访问v$对象,并不是访问视图,而是指向v_$视图的同义词;oracle访问时,先
访问view优先,再访问同义词
7 访问v$parameter时,访问的是同义词
8 PGA:不需要LATCH保护,非共享内存。PGA分为固定PGA和可变PGA(其空间分配与使用
时可以变化)
可变PGA分为会话内存(存放会话的登陆信息),私有的SQL区包含绑定变量信息(对于
专用服务器模式,部分内存在PGA中分配,对于共享服务器模式,内存在SGA分配)
一个私有SQL区在cursor打开分配,当执行结束时游标关闭释放。
私有SQL区域分为永久区域(包含变量绑定信息),运行时区域(存放SQL语句运行时
所需要的信息,在执行请求时首先创建)
UGA(User Global Area,用户全局区,由用户会话数据,游标状态和索引区组成),
UGA是基于会话的。
通过V$PGASTAT视图,可以查询PGA累计释放回OS的内存空间
select name,value from v$pgastat where name like '%OS';
9 自动化PGA管理有如下几个参数
PGA_AGGREGATE_TARGET:该参数指定所有session能用的PGA的最大内存
workarea_size_policy:用于指定开关PGA内存自动管理功能,AUTO时,表示
自动PGA管理功能。mannul为手工。
10
PGA_AGGREGATE_TARGET参数的设置,oracle提供的方案
对于 OLTP系统,需要保留20%物理内存给操作系统,剩余80%给oracle,而ORACLE使用的内存中,建议PGA占20%。
11 根据某个oracle进程,看其oracle 进程PGA使用内存情况
select * from v$process where spid=xxxxx;
查看PGA内存消耗在什么地方:
select p.PROGRAM,p.pid,pm.category,pm.allocated,pm.used,pm.max_allocated
from v$process p,v$process_memory pm
where p.PID=pm.pid and p.SPID=xxxx;
想要分析当前 PGA 时可以通过以下 SQL 产生一个当前系统的 PGA 指标:
select name,
value,
100 *
(value / decode((select sum(value)
from v$sysstat
where name like 'workarea executions%'),
0,
NULL,
(select sum(value)
from v$sysstat
where name like 'workarea executions%'))) pct
from v$sysstat
where name like 'workarea executions%';
12 PGA自动管理原理
Oracle 中对自动 PGA 管理采用反馈环( FeedBack Loop )算法来实现。当进程开始 SQL 执行时,首先通过 Local Memory
Manager 注册一个 ActiveWorkArea Profile ,工作区 Profile 是进城与内存管理器之间通信的唯一接口,活动 Profile 通过
Local Memory Manager 来维护,存储在 SGA 中,有了这些 Profile ,后台的 Global Memory Manager 就可以计算出一个在一定上
限内并能提供较好性能的 Global Memory Bound ,这个值用于限制单个进程使用的 PGA 内存上限, Global Memory Manager 每个 3
秒钟更新一次 Global Memory Bound , Local Memory Manager 得到 Global Memory Bound 后会计算出每个 Active Statement 所
要分配的 PGA 内存,称为 Expect Size ,然后每个 Active Statement 将会得到子所分得的 Expect Size ,并在该内存中进行运算
。
13 PGA的调整
伴随自动PGA调整功能的引入,oracle同时引入相应的动态性能视图用于优化建议,PGA的优化建议通过v$pga_target_advice 和
v$pga_target_advice_histogram提供
SQL>
select pga_target_for_estimate/1024/1024 PGAMB,pga_target_factor,estd_pga_cache_hit_percentage,estd_overalloc_count
from v$pga_target_advice;
第一列表示不同的PGA的具体值
第二列PGA_TARGET_FACTOR为“1”表示当前的pga_aggregate_target设置大小
第三列表示PGA的估算得到的Cache命中率的百分比
第四列如果为“0”表示可以消除PGA的过载
当可消除PGA过载,也就是ESTD_OVERALLOC_COUNT为“0”,
命中率最高,也就是 ESTD_PGA_CACHE_HIT_PERCENTAGE为最高值
当这两者全具体时,这时的PGA大小就是优化
14 SGA:
分为固定区域(FIXED AREA),buffer cache,shared pool,redo log buffer,large pool.
1) buffer cache:
9i中有新参数db_cache_size最小值得为一个粒度(granule),粒度为9i引入的新的概念,是连续虚拟内存分配的单位,
10G中,如果SGA<1GB,粒度为4mb,否则为16MB(32位WINDOWS 为8MB)
show parameter cache_size;
select * from v$sga;
select * from v$sgainfo;
15 SGA与共享内存
shmmax是系统允许的单个共享内存段的最大值,
cat /proc/sys/kernel/shmmax
查看oracle 分配了多少共享内存满足要求
ipcs -sa
推荐是将SGA限制在一个共享内存中。通过修改/proc/sys/kernel/shmmax达到目的,修改/etc/sysctl.conf使文件持久化
kernel.shmmax=xxxxxxx
show parameter sga_max_size
alter system set db_cache_size=100m;
缓冲区建议
show parameter db_cache_ad
select * from v$db_cache_advice;
sharedpool建议
select * from v$shared_pool_advice;
在10g中,使用自动管理sga_target设置即可,可以自动分配的内存包括buffer cache,shared pool,java pool和large pool.
将sga_target设置为非0值即可。
而在11G中,SGA和PGA都可以自动设置,新的参数为memory_target,只需要设置这个即可。
16 捕捉存在问题的SQL语句
SELECT /*+ ORDERED */
sql_text
FROM v$sqltext a
WHERE (a.hash_value, a.address) IN (
SELECT DECODE (sql_hash_value,
0, prev_hash_value,
sql_hash_value
),
DECODE (sql_hash_value, 0, prev_sql_addr, sql_address)
FROM v$session b
WHERE b.paddr = (SELECT addr
FROM v$process c
WHERE c.spid = '&pid'))
ORDER BY piece ASC
/
其中输入的pid为通过ps -ef看到的id
动态性能视图和数据字典视图
2 内部RDBMS(X$)表
为加密的表,跟踪内部数据库信息,
可以select kvittag,kvitval,kvitdsc from x$kvit
看一些内部参数
3 数据字典表
保存表,索引,约束等数据库结构的信息,以 $结尾,sql.bsq文件来创建;
其中dba_objects中的object_id和data_object_id中,object_id为逻辑号,一旦分配
就不会改变,data_object_i为物理号,有可能发生改变。
4 静态数据字典视图,不能直接被修改,分三类
USER_类:包含了用户所有的相关信息,ALL_类,DBA_类(需要select any table
权限)
5 常见视图
1)DICT
返回当前用户可以访问的所有数据字典视图
select table_name from dict where table_name like '%TABLES$%';
返回和TABLES相关的视图
2)DICT_COLUMNS
记录了字典视图列及相关说明
3)obj 为user_objects建立的同义词,获得用户所拥有的对象信息
select object_name,object_type from obj;
6 动态视图
oracle创建GV$和v$视图,GV$ 满足RAC需要。通过访问v$对象,并不是访问视图,而是指向v_$视图的同义词;oracle访问时,先
访问view优先,再访问同义词
7 访问v$parameter时,访问的是同义词
8 PGA:不需要LATCH保护,非共享内存。PGA分为固定PGA和可变PGA(其空间分配与使用
时可以变化)
可变PGA分为会话内存(存放会话的登陆信息),私有的SQL区包含绑定变量信息(对于
专用服务器模式,部分内存在PGA中分配,对于共享服务器模式,内存在SGA分配)
一个私有SQL区在cursor打开分配,当执行结束时游标关闭释放。
私有SQL区域分为永久区域(包含变量绑定信息),运行时区域(存放SQL语句运行时
所需要的信息,在执行请求时首先创建)
UGA(User Global Area,用户全局区,由用户会话数据,游标状态和索引区组成),
UGA是基于会话的。
通过V$PGASTAT视图,可以查询PGA累计释放回OS的内存空间
select name,value from v$pgastat where name like '%OS';
9 自动化PGA管理有如下几个参数
PGA_AGGREGATE_TARGET:该参数指定所有session能用的PGA的最大内存
workarea_size_policy:用于指定开关PGA内存自动管理功能,AUTO时,表示
自动PGA管理功能。mannul为手工。
10
PGA_AGGREGATE_TARGET参数的设置,oracle提供的方案
对于 OLTP系统,需要保留20%物理内存给操作系统,剩余80%给oracle,而ORACLE使用的内存中,建议PGA占20%。
11 根据某个oracle进程,看其oracle 进程PGA使用内存情况
select * from v$process where spid=xxxxx;
查看PGA内存消耗在什么地方:
select p.PROGRAM,p.pid,pm.category,pm.allocated,pm.used,pm.max_allocated
from v$process p,v$process_memory pm
where p.PID=pm.pid and p.SPID=xxxx;
想要分析当前 PGA 时可以通过以下 SQL 产生一个当前系统的 PGA 指标:
select name,
value,
100 *
(value / decode((select sum(value)
from v$sysstat
where name like 'workarea executions%'),
0,
NULL,
(select sum(value)
from v$sysstat
where name like 'workarea executions%'))) pct
from v$sysstat
where name like 'workarea executions%';
12 PGA自动管理原理
Oracle 中对自动 PGA 管理采用反馈环( FeedBack Loop )算法来实现。当进程开始 SQL 执行时,首先通过 Local Memory
Manager 注册一个 ActiveWorkArea Profile ,工作区 Profile 是进城与内存管理器之间通信的唯一接口,活动 Profile 通过
Local Memory Manager 来维护,存储在 SGA 中,有了这些 Profile ,后台的 Global Memory Manager 就可以计算出一个在一定上
限内并能提供较好性能的 Global Memory Bound ,这个值用于限制单个进程使用的 PGA 内存上限, Global Memory Manager 每个 3
秒钟更新一次 Global Memory Bound , Local Memory Manager 得到 Global Memory Bound 后会计算出每个 Active Statement 所
要分配的 PGA 内存,称为 Expect Size ,然后每个 Active Statement 将会得到子所分得的 Expect Size ,并在该内存中进行运算
。
13 PGA的调整
伴随自动PGA调整功能的引入,oracle同时引入相应的动态性能视图用于优化建议,PGA的优化建议通过v$pga_target_advice 和
v$pga_target_advice_histogram提供
SQL>
select pga_target_for_estimate/1024/1024 PGAMB,pga_target_factor,estd_pga_cache_hit_percentage,estd_overalloc_count
from v$pga_target_advice;
第一列表示不同的PGA的具体值
第二列PGA_TARGET_FACTOR为“1”表示当前的pga_aggregate_target设置大小
第三列表示PGA的估算得到的Cache命中率的百分比
第四列如果为“0”表示可以消除PGA的过载
当可消除PGA过载,也就是ESTD_OVERALLOC_COUNT为“0”,
命中率最高,也就是 ESTD_PGA_CACHE_HIT_PERCENTAGE为最高值
当这两者全具体时,这时的PGA大小就是优化
14 SGA:
分为固定区域(FIXED AREA),buffer cache,shared pool,redo log buffer,large pool.
1) buffer cache:
9i中有新参数db_cache_size最小值得为一个粒度(granule),粒度为9i引入的新的概念,是连续虚拟内存分配的单位,
10G中,如果SGA<1GB,粒度为4mb,否则为16MB(32位WINDOWS 为8MB)
show parameter cache_size;
select * from v$sga;
select * from v$sgainfo;
15 SGA与共享内存
shmmax是系统允许的单个共享内存段的最大值,
cat /proc/sys/kernel/shmmax
查看oracle 分配了多少共享内存满足要求
ipcs -sa
推荐是将SGA限制在一个共享内存中。通过修改/proc/sys/kernel/shmmax达到目的,修改/etc/sysctl.conf使文件持久化
kernel.shmmax=xxxxxxx
show parameter sga_max_size
alter system set db_cache_size=100m;
缓冲区建议
show parameter db_cache_ad
select * from v$db_cache_advice;
sharedpool建议
select * from v$shared_pool_advice;
在10g中,使用自动管理sga_target设置即可,可以自动分配的内存包括buffer cache,shared pool,java pool和large pool.
将sga_target设置为非0值即可。
而在11G中,SGA和PGA都可以自动设置,新的参数为memory_target,只需要设置这个即可。
16 捕捉存在问题的SQL语句
SELECT /*+ ORDERED */
sql_text
FROM v$sqltext a
WHERE (a.hash_value, a.address) IN (
SELECT DECODE (sql_hash_value,
0, prev_hash_value,
sql_hash_value
),
DECODE (sql_hash_value, 0, prev_sql_addr, sql_address)
FROM v$session b
WHERE b.paddr = (SELECT addr
FROM v$process c
WHERE c.spid = '&pid'))
ORDER BY piece ASC
/
其中输入的pid为通过ps -ef看到的id
发表评论
-
mybatis generator中的字段大小写生成问题
2017-10-22 19:35 11459mybatis generator插件中,如果 mysql数据 ... -
MySQL统计一个列中不同值的数量
2017-07-11 14:04 16324https://yiqiwuliao.com/post/mys ... -
mysql 1449 : The user specified as a definer ('root'@'%') does not exist 解决方法
2017-03-02 09:44 1841权限问题,授权 给 root 所有sql 权限 mysql ... -
几个不错的MYSQL 优化TIPS
2016-11-19 12:30 846图片来自http://imysql.com/的PDF分享 [ ... -
powerdesign 逆向ORACLE的坑
2016-09-27 17:08 594要注意的是,在WIN 64中,如果要用powerdesin 来 ... -
( 转)mysql中删除两条重复记录中的一条
2015-10-19 20:19 1355| id | createTime | labId | pub ... -
mysql中sql语句=,>的时候的索引设置
2015-05-02 12:27 1333在 https://www.percona.com/blog/ ... -
mysql中profile的使用
2015-04-30 11:11 2262mysql 的 sql 性能分析器主要用途是显示 sql 执行 ... -
mysql中的sql mode
2015-04-13 11:29 1185mysql sql mode小结 1 sql mode可以 ... -
PROCEDURE ANALYSE()为mysql提高性能提供建议
2015-04-02 16:37 1510procedure analyse();语法如下 select ... -
mongodb中意外退出的问题
2015-02-11 14:32 1366mongodb启动的时候,意外退出: Unclean shut ... -
mysql 5.5中保留字查询
2014-06-05 23:16 1514mysql 5.5中保留字查询 http://www.5is ... -
(转)oracle 临时表空间的增删改查
2014-03-18 12:44 1174oracle 临时表空间的增删改查 1、查看临时表空间 (d ... -
pl-sql developer安装
2014-02-07 09:16 1159一直都是机器本机上有oracle,所以装pl sql deve ... -
oracle中的nvl,nvl2等参数
2013-12-26 11:18 23161.nul函数将一个null值转换为一个实际的值。 数据类型可 ... -
Oracle中的ROWNUM rowid 以及MySQL中实现rownum功能类似的语句
2013-12-26 11:08 2384http://gong-10140.iteye.com/blo ... -
ORACLE XE版本的限制
2013-12-07 08:11 371210g中用户数据最大为4G, 11G中最大为11G,如果超出大 ... -
oracle中监控索引是否可用
2013-11-04 07:22 1114在oracle中,可以使用如下的方法监控索引是否可用: a ... -
mysql 5.6中的时间类型的新精度介绍
2013-10-28 09:33 8441留意到mysql 5.6中,可以使用select now(6) ... -
<<oracle索引技术》读书笔记1
2013-08-25 16:23 1355expert indexing in oracle datab ...
相关推荐
内容概要:本文详细介绍了基于MATLAB GUI界面和卷积神经网络(CNN)的模糊车牌识别系统。该系统旨在解决现实中车牌因模糊不清导致识别困难的问题。文中阐述了整个流程的关键步骤,包括图像的模糊还原、灰度化、阈值化、边缘检测、孔洞填充、形态学操作、滤波操作、车牌定位、字符分割以及最终的字符识别。通过使用维纳滤波或最小二乘法约束滤波进行模糊还原,再利用CNN的强大特征提取能力完成字符分类。此外,还特别强调了MATLAB GUI界面的设计,使得用户能直观便捷地操作整个系统。 适合人群:对图像处理和深度学习感兴趣的科研人员、高校学生及从事相关领域的工程师。 使用场景及目标:适用于交通管理、智能停车场等领域,用于提升车牌识别的准确性和效率,特别是在面对模糊车牌时的表现。 其他说明:文中提供了部分关键代码片段作为参考,并对实验结果进行了详细的分析,展示了系统在不同环境下的表现情况及其潜在的应用前景。
嵌入式八股文面试题库资料知识宝典-计算机专业试题.zip
嵌入式八股文面试题库资料知识宝典-C and C++ normal interview_3.zip
内容概要:本文深入探讨了一款额定功率为4kW的开关磁阻电机,详细介绍了其性能参数如额定功率、转速、效率、输出转矩和脉动率等。同时,文章还展示了利用RMxprt、Maxwell 2D和3D模型对该电机进行仿真的方法和技术,通过外电路分析进一步研究其电气性能和动态响应特性。最后,文章提供了基于RMxprt模型的MATLAB仿真代码示例,帮助读者理解电机的工作原理及其性能特点。 适合人群:从事电机设计、工业自动化领域的工程师和技术人员,尤其是对开关磁阻电机感兴趣的科研工作者。 使用场景及目标:适用于希望深入了解开关磁阻电机特性和建模技术的研究人员,在新产品开发或现有产品改进时作为参考资料。 其他说明:文中提供的代码示例仅用于演示目的,实际操作时需根据所用软件的具体情况进行适当修改。
少儿编程scratch项目源代码文件案例素材-剑客冲刺.zip
少儿编程scratch项目源代码文件案例素材-几何冲刺 转瞬即逝.zip
内容概要:本文详细介绍了基于PID控制器的四象限直流电机速度驱动控制系统仿真模型及其永磁直流电机(PMDC)转速控制模型。首先阐述了PID控制器的工作原理,即通过对系统误差的比例、积分和微分运算来调整电机的驱动信号,从而实现转速的精确控制。接着讨论了如何利用PID控制器使有刷PMDC电机在四个象限中精确跟踪参考速度,并展示了仿真模型在应对快速负载扰动时的有效性和稳定性。最后,提供了Simulink仿真模型和详细的Word模型说明文档,帮助读者理解和调整PID控制器参数,以达到最佳控制效果。 适合人群:从事电力电子与电机控制领域的研究人员和技术人员,尤其是对四象限直流电机速度驱动控制系统感兴趣的读者。 使用场景及目标:适用于需要深入了解和掌握四象限直流电机速度驱动控制系统设计与实现的研究人员和技术人员。目标是在实际项目中能够运用PID控制器实现电机转速的精确控制,并提高系统的稳定性和抗干扰能力。 其他说明:文中引用了多篇相关领域的权威文献,确保了理论依据的可靠性和实用性。此外,提供的Simulink模型和Word文档有助于读者更好地理解和实践所介绍的内容。
嵌入式八股文面试题库资料知识宝典-2013年海康威视校园招聘嵌入式开发笔试题.zip
少儿编程scratch项目源代码文件案例素材-驾驶通关.zip
小区开放对周边道路通行能力影响的研究.pdf
内容概要:本文探讨了冷链物流车辆路径优化问题,特别是如何通过NSGA-2遗传算法和软硬时间窗策略来实现高效、环保和高客户满意度的路径规划。文中介绍了冷链物流的特点及其重要性,提出了软时间窗概念,允许一定的配送时间弹性,同时考虑碳排放成本,以达到绿色物流的目的。此外,还讨论了如何将客户满意度作为路径优化的重要评价标准之一。最后,通过一段简化的Python代码展示了遗传算法的应用。 适合人群:从事物流管理、冷链物流运营的专业人士,以及对遗传算法和路径优化感兴趣的科研人员和技术开发者。 使用场景及目标:适用于冷链物流企业,旨在优化配送路线,降低运营成本,减少碳排放,提升客户满意度。目标是帮助企业实现绿色、高效的物流配送系统。 其他说明:文中提供的代码仅为示意,实际应用需根据具体情况调整参数设置和模型构建。
少儿编程scratch项目源代码文件案例素材-恐怖矿井.zip
内容概要:本文详细介绍了基于STM32F030的无刷电机控制方案,重点在于高压FOC(磁场定向控制)技术和滑膜无感FOC的应用。该方案实现了过载、过欠压、堵转等多种保护机制,并提供了完整的源码、原理图和PCB设计。文中展示了关键代码片段,如滑膜观测器和电流环处理,以及保护机制的具体实现方法。此外,还提到了方案的移植要点和实际测试效果,确保系统的稳定性和高效性。 适合人群:嵌入式系统开发者、电机控制系统工程师、硬件工程师。 使用场景及目标:适用于需要高性能无刷电机控制的应用场景,如工业自动化设备、无人机、电动工具等。目标是提供一种成熟的、经过验证的无刷电机控制方案,帮助开发者快速实现并优化电机控制性能。 其他说明:提供的资料包括详细的原理图、PCB设计文件、源码及测试视频,方便开发者进行学习和应用。
基于有限体积法Godunov格式的管道泄漏检测模型研究.pdf
嵌入式八股文面试题库资料知识宝典-CC++笔试题-深圳有为(2019.2.28)1.zip
少儿编程scratch项目源代码文件案例素材-几何冲刺 V1.5.zip
Android系统开发_Linux内核配置_USB-HID设备模拟_通过root权限将Android设备转换为全功能USB键盘的项目实现_该项目需要内核支持configFS文件系统
C# WPF - LiveCharts Project
少儿编程scratch项目源代码文件案例素材-恐怖叉子 动画.zip
嵌入式八股文面试题库资料知识宝典-嵌⼊式⼯程师⾯试⾼频问题.zip