Oracle优化工具介绍

ChinaITOldMan 2019-08-06 11:37:12
在网上看到Oracle中有 awr、statspack、sqlprofile、sqltrace与OWI等调优工具,请问哪些比较常用?或有更好的调优方法?及能否介绍下他们怎样用或有推荐下关于这些工具的帖子?

我知道通过set autotrace在Sql plus或 toad中可通过执行计划等进行简单的查看,能有更好的方法吗?


谢谢大家的指点!
...全文
1482 10 打赏 收藏 转发到动态 举报
写回复
用AI写文章
10 条回复
切换为时间正序
请发表友善的回复…
发表回复
ChinaITOldMan 2019-08-19
  • 打赏
  • 举报
回复
thanks everyone, close this subject!
minsic78 2019-08-07
  • 打赏
  • 举报
回复
引用 7 楼 ChinaITOldMan 的回复:
[quote=引用 6 楼 minsic78 的回复:] [quote=引用 5 楼 minsic78 的回复:] 是的,正式点的生产交易库一般是用rman来热备的,但如果是生产环境的OLAP系统,个人认为开归档来rman备份,太拉低,应该向其他办法去实现其高可用,毛估估的话,数据库大概有一半的IO来自于redo,开了归档的话,redo的读,归档的写又会加重IO的负担。
太容易拉低数据库的性能,应该想其他办法去实现OLAP数据库的高可用。[/quote] 哦,谢谢您,按你的意思OLTP的production database 系统还是可以用RMAN做备份的吧?[/quote] 是的~
ChinaITOldMan 2019-08-07
  • 打赏
  • 举报
回复
引用 6 楼 minsic78 的回复:
[quote=引用 5 楼 minsic78 的回复:] 是的,正式点的生产交易库一般是用rman来热备的,但如果是生产环境的OLAP系统,个人认为开归档来rman备份,太拉低,应该向其他办法去实现其高可用,毛估估的话,数据库大概有一半的IO来自于redo,开了归档的话,redo的读,归档的写又会加重IO的负担。
太容易拉低数据库的性能,应该想其他办法去实现OLAP数据库的高可用。[/quote] 哦,谢谢您,按你的意思OLTP的production database 系统还是可以用RMAN做备份的吧?
ChinaITOldMan 2019-08-07
  • 打赏
  • 举报
回复
谢谢楼上的老兄!
minsic78 2019-08-06
  • 打赏
  • 举报
回复
结合不同情况都有用。 SQL一级的优化,一般就是autotrace、dbms_xplan包(主要是display、display_cursor、display_awr等几个函数),或者10046 event(可以说是sqltrace的加强版),sqlprofile更多是用来固定执行计划的,也就是说,用来最终优化方案实施阶段。 AWR你可以把它当作statspack的升级版,10g以后AWR基本替代了statspack,而且不需要额外安装。这两者都是用来分析实例一级性能的工具。 OWI,其实就是等待事件,这个无论是会话一级还是实例一级都有用到。
minsic78 2019-08-06
  • 打赏
  • 举报
回复
引用 5 楼 minsic78 的回复:
是的,正式点的生产交易库一般是用rman来热备的,但如果是生产环境的OLAP系统,个人认为开归档来rman备份,太拉低,应该向其他办法去实现其高可用,毛估估的话,数据库大概有一半的IO来自于redo,开了归档的话,redo的读,归档的写又会加重IO的负担。
太容易拉低数据库的性能,应该想其他办法去实现OLAP数据库的高可用。
minsic78 2019-08-06
  • 打赏
  • 举报
回复
是的,正式点的生产交易库一般是用rman来热备的,但如果是生产环境的OLAP系统,个人认为开归档来rman备份,太拉低,应该向其他办法去实现其高可用,毛估估的话,数据库大概有一半的IO来自于redo,开了归档的话,redo的读,归档的写又会加重IO的负担。
ChinaITOldMan 2019-08-06
  • 打赏
  • 举报
回复
引用 3 楼 minsic78 的回复:
DBA等级认定各个公司都不一样,不好说,而且DBA也只是称谓而已 要使用哪种备份工具和策略,和数据库的定位、能承受什么样的数据丢失有关系,通常严格意义上重要点的数据库应该使用rman备份,但是如果oracle作为数据仓库,你可能都接受不了它打开归档,所以要想其他方案来实现高可用。 exp/imp与10g以后引入的expdp/impdp用来一般用来迁移数据,备份的话,只要你能接受一定程度上的数据丢失那也没问题。他们用来迁移少量数据,甚至是上几十T的数据,也不是不可以,但有要求有一定的停应用时间来保证数据一致性,有可能以天计。 前两种是热备,当然exp/imp与expdp/impdp其实是个不完全的逻辑备份,冷备的话,首先就要停库,或者停掉一部分业务,全库冷备严格意义上只需要拷贝三大核心文件(数据文件、控制文件与在线日志文件)就可以,备份一部分表空间也可以,oracle支持满足一定条件的表空间进行表空间传输:使用前面提到的exp/imp或者expdp/impdp来迁移表空间元数据,并拷贝表空间的数据文件实现表空间的传输。
谢谢您一直以来的耐心指教!多谢您! 也就是说正式的生产数据库一般是用RMAN进行备份与恢复吧 ?
minsic78 2019-08-06
  • 打赏
  • 举报
回复
DBA等级认定各个公司都不一样,不好说,而且DBA也只是称谓而已 要使用哪种备份工具和策略,和数据库的定位、能承受什么样的数据丢失有关系,通常严格意义上重要点的数据库应该使用rman备份,但是如果oracle作为数据仓库,你可能都接受不了它打开归档,所以要想其他方案来实现高可用。 exp/imp与10g以后引入的expdp/impdp用来一般用来迁移数据,备份的话,只要你能接受一定程度上的数据丢失那也没问题。他们用来迁移少量数据,甚至是上几十T的数据,也不是不可以,但有要求有一定的停应用时间来保证数据一致性,有可能以天计。 前两种是热备,当然exp/imp与expdp/impdp其实是个不完全的逻辑备份,冷备的话,首先就要停库,或者停掉一部分业务,全库冷备严格意义上只需要拷贝三大核心文件(数据文件、控制文件与在线日志文件)就可以,备份一部分表空间也可以,oracle支持满足一定条件的表空间进行表空间传输:使用前面提到的exp/imp或者expdp/impdp来迁移表空间元数据,并拷贝表空间的数据文件实现表空间的传输。
ChinaITOldMan 2019-08-06
  • 打赏
  • 举报
回复
好的,谢谢您! 还有几个问题麻烦下您!多谢! 若学习了Oracle的体系结构、PL/SQL基本编程、数据库的备份与恢复、用户管理与权限、事务与锁机、性能的基本优化与问题捕获、RAC与OGG等 基本是不是达到初中级DBA的水平? a.另外有没有关于Oracle数据库数据库的备份与恢复的详细例子? b.一般是不是用RMAN进行数据库的日常备份与恢复 ? c. 利用Oracle 的EXP/IMP是不是只能做一些小级别数据库的备份?Exp/IMP是不是很少使用? d. 冷备份是不是很少使用?若冷备份出自己的表空间文件,是否可再通过恢复表空间把自己建立的所有数据库对象恢复到一个Oracle数据库中?若可以怎样处理?谢谢
第一篇 Oracle管理配置 第1章 Oracle安装配置(教学视频:10分钟) 23 1.1 Oracle简介 23 1.1.1 数据库术语 23 1.1.2 主流数据库简介 24 1.1.3 Oracle数据库的特点 24 1.2 安装Oracle数据库 25 1.2.1 Oracle数据库的版本变迁及安装环境 25 1.2.2 安装过程 26 1.2.3 安装中需要注意的问题 27 1.3 本章小结 28 1.4 习题 28 第2章 Oracle常用工具(教学视频:7分钟) 29 2.1 Net Configuration Assistant(网络配置助手) 29 2.1.1 监听程序配置 29 2.1.2 命名方法配置 31 2.1.3 本地Net服务名配置 32 2.2 Net Manager(网络管理员) 34 2.3 本章实例 36 2.4 本章小结 38 2.5 习题 38 第3章 SQL Plus和PL/SQL(教学视频:11分钟) 39 3.1 SQL Plus与PL/SQL简介 39 3.2 使用SQL Plus 40 3.2.1 登录SQL Plus 40 3.2.2 SQL Plus输出结果的格式化 41 3.2.3 SQL Plus小结 46 3.3 PL/SQL 46 3.3.1 PL/SQL常用开发工具 46 3.3.2 开发一个简单的PL/SQL程序 48 3.4 本章实例 49 3.5 本章小结 50 3.6 习题 50 第二篇 Oracle数据库对象 第4章 Oralce数据库(教学视频:15分钟) 51 4.1 创建Oracle数据库 51 4.2 Oracle数据库的相关术语 52 4.2.1 数据库 53 4.2.2 数据库实例和SID 53 4.2.3 ORACLE_SID 54 4.3 Oracle数据库的备份与恢复 55 4.3.1 逻辑备份/恢复(导出/导入) 55 4.3.2 物理备份/恢复 56 4.3.3 利用PL/SQL Developer备份数据库 60 4.4 本章实例 61 4.5 本章小结 61 4.6 习题 62 第5章 Oracle数据表对象(教学视频:42分钟) 63 5.1 Oracle表空间 63 5.1.1 Oracle表空间简介 63 5.1.2 创建Oracle表空间 64 5.1.3 查看表空间 66 5.1.4 修改数据库默认表空间 67 5.1.5 修改表空间名称 68 5.1.6 删除表空间 69 5.2 创建Oracle数据表 70 5.2.1 利用工具创建数据表 70 5.2.2 利用工具查看数据表 71 5.2.3 利用命令创建数据表 72 5.2.4 利用命令查看表结构 72 5.3 修改Oracle数据表结构 73 5.3.1 利用工具修改数据表结构 73 5.3.2 利用命令修改数据表结构 74 5.4 删除数据表 75 5.4.1 利用工具删除数据表 76 5.4.2 利用SQL语句删除数据表 76 5.5 备份/恢复数据表 76 5.5.1 利用工具备份/恢复数据表 77 5.5.2 利用命令备份/恢复数据表 82 5.6 临时表 83 5.6.1 临时表简介 83 5.6.2 会话级临时表 84 5.6.3 事务级临时表 85 5.6.4 查看临时表在数据库中的信息 86 5.6.5 临时表的应用场景 86 5.7 特殊的表dual 87 5.7.1 分析dual表 87 5.7.2 dual表的应用场景 87 5.7.3 修改dual表对查询结果的影响 88 5.8 本章实例 89 5.9 本章小结 90 5.10 习题 90 第6章 约束(教学视频:43分钟) 91 6.1 主键约束 91 6.1.1 主键简介 91 6.1.2 创建主键约束 92 6.1.3 修改表的主键约束 94 6.1.4 主键应用场景 96 6.2 外键约束 97 6.2.1 外键简介 97 6.2.2 创建外键约束 97 6.2.3 级联更新与级联删除 100 6.2.4 修改外键属性 102 6.2.5 外键使用 104 6.3 唯一性约束 105 6.3.1 唯一性约束简介 105 6.3.2 创建唯一性约束 105 6.3.3 修改唯一性约束 107 6.3.4 唯一性约束的使用 108 6.4 检查约束 108 6.4.1 检查约束简介 108 6.4.2 创建检查约束 108 6.4.3 修改检查约束 110 6.4.4 检查约束的使用 111 6.5 默认值约束 111 6.5.1 默认值约束简介 112 6.5.2 创建默认值约束 112 6.5.3 修改默认值约束 113 6.6 本章实例 115 6.7 本章小结 116 6.8 习题 116 第7章 视图(教学视频:50分钟) 117 7.1 关系视图 117 7.1.1 建立关系视图 117 7.1.2 修改/删除视图 118 7.1.3 联接视图 120 7.1.4 编译视图 122 7.1.5 使用force选项强制创建视图 124 7.1.6 利用视图更新数据表 125 7.1.7 with check option选项 126 7.1.8 关系视图小结 128 7.2 内嵌视图 128 7.2.1 内嵌视图简介 128 7.2.2 内嵌视图的使用 128 7.2.3 内嵌视图小结 130 7.3 对象视图 131 7.3.1 对象视图简介 131 7.3.2 对象视图简介 131 7.4 物化视图 133 7.4.1 物化视图简介 133 7.4.2 物化视图的使用 133 7.4.3 物化视图的数据加载 135 7.4.4 物化视图的数据更新 135 7.4.5 查询重写 136 7.5 本章小结 136 7.6 本章实例 137 7.7 习题 137 第8章 函数与存储过程(教学视频:48分钟) 138 8.1 函数 138 8.1.1 函数简介 138 8.1.2 创建函数 139 8.1.3 函数中的括号 140 8.1.4 函数的参数 141 8.1.5 函数的确定性 142 8.1.6 典型函数举例 143 8.2 存储过程 144 8.2.1 存储过程简介 144 8.2.2 创建存储过程 144 8.2.3 存储过程的参数——IN参数 146 8.2.4 存储过程的参数——OUT参数 147 8.2.5 存储过程的参数——IN OUT参数 149 8.2.6 存储过程的参数——参数顺序 149 8.2.7 存储过程的参数——参数的默认值 152 8.2.8 存储过程的参数——参数顺序总结 153 8.3 程序包 153 8.3.1 规范 153 8.3.2 主体 155 8.3.3 调用程序包中的函数/存储过程 157 8.3.4 程序包中的变量 158 8.4 本章实例 159 8.5 本章小结 161 8.6 习题 161 …… 第9章 游标(教学视频:36分钟) 162 第10章 触发器(教学视频:58分钟) 178 第11章 序列(教学视频:28分钟) 206 第12章 用户角色与权限控制(教学视频:45分钟) 215 第三篇 Oracle中的SQL 第13章 Oracle数据类型(教学视频:21分钟) 231 第14章 Oracle中的函数与表达式(教学视频:111分钟) 240 第15章 Oracle中的控制语句(教学视频:16分钟) 282 第16章 SQL查询(教学视频:55分钟) 290 第17章 SQL更新数据(教学视频:34分钟) 319 第四篇 Oracle编程高级应用 第18章 数据库速度优化与数据完整性(教学视频:32分钟) 332 第19章 数据一致性与事务管理(教学视频:46分钟) 341 第20章 并发控制(教学视频:35分钟) 356 第21章 Oracle中的正则表达式(教学视频:29分钟) 369 第五篇 Oracle与编程语言综合使用实例 第22章 Oracle在Java开发中的应用(教学视频:38分钟) 376 第23章 Oracle在C#开发中的应用(教学视频:12分钟) 391

17,377

社区成员

发帖
与我相关
我的任务
社区描述
Oracle 基础和管理
社区管理员
  • 基础和管理社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧