没有合适的资源?快使用搜索试试~ 我知道了~
首页Oracle学习手册:TianleSoftware整理
Oracle学习手册:TianleSoftware整理
需积分: 10 1 下载量 68 浏览量
更新于2024-07-24
收藏 45.36MB PDF 举报
"Oracle详细讲解,TianleSoftware的Oracle学习手册v1.0,作者分享了自己在Oracle学习过程中的经验和文档,整理了各类Oracle相关的博客内容,引用了许多前辈的资料,包括eygle、君三思、谭怀远、陈吉平等人的作品。手册旨在方便个人查阅和学习,但也可能存在理解和排版上的不足。作者承诺,若发现侵权或错误,会及时修正。此外,提供了多个Oracle DBA交流群的信息。"
Oracle是世界上最广泛使用的数据库管理系统之一,以其稳定性、性能和功能强大而著称。这篇“Oracle详细讲解”是作者TianleSoftware基于其个人的学习经历和实验,整理的一份学习手册。手册内容涵盖了许多关键的Oracle概念和技术,可能包括但不限于:
1. **Oracle基础知识**:介绍Oracle数据库的基本架构,如数据块、区、表空间等,以及数据库实例和进程的工作原理。
2. **SQL与PL/SQL**:详述SQL语言在Oracle中的应用,包括DML(数据操纵语言)、DDL(数据定义语言)和DCL(数据控制语言),以及Oracle特有的PL/SQL编程语言。
3. **性能优化**:讨论如何通过索引、分区、统计信息收集等手段提升查询性能,以及SQL优化器的工作机制。
4. **备份与恢复**:讲解Oracle的RMAN(恢复管理器)工具,以及如何制定备份策略和执行灾难恢复。
5. **高可用性与故障切换**:涉及RAC(Real Application Clusters)集群技术,以及逻辑复制方案如Data Guard。
6. **安全性**:介绍Oracle的角色、权限管理和审计功能,以及如何保障数据库安全。
7. **存储与内存管理**:分析SGA(系统全局区域)和PGA(程序全局区域),以及Oracle的数据存储结构。
8. **故障诊断与监控**:讲述如何使用AWR(自动工作负载 repository)和ASH(活动会话历史)报告进行性能分析。
这份学习手册不仅包含了作者的个人理解和实践,还引用了Oracle领域的专家如eygle、君三思等人的著作,提供了一个综合的学习资源。然而,由于是个人整理,可能存在理解和信息更新不及时的问题,读者在学习时应结合官方文档和其他权威资源以获取最准确的信息。同时,作者提供的DBA交流群信息为学习者提供了一个互动和讨论的平台,有助于深化理解和解决问题。
请注意,由于原文档部分内容缺失,以上知识点的阐述可能不够全面,实际的手册可能包含更多详细内容和实例。对于初学者,这份手册可以作为入门的参考资料,但对于深入学习和专业实践,还需要配合官方文档和其他专业书籍。
Tianlesoftware 学习 Oracle Blog: http://blog.csdn.net/tianlesoftware
DBA1 群:62697716(满); DBA2 群:62697977(满); DBA3 群:62697850(满); DBA 超级群:63306533
DBA4 群:83829929(满); DBA5 群:142216823 DBA6 群:158654907
2.5.1. SPFILE
丢失
....................................................................................................................... 526
2.5.2. Controlfile
全部丢失
......................................................................................................... 526
2.5.3 UNDO
损坏的情况
........................................................................................................ 526
2.5.3.1 方法一: 使用 system segment ................................................................................................. 527
2.5.3.2.方法二:跳过损坏的 segment ................................................................................................. 527
2.5.4. Redo Log File
损坏
............................................................................................................ 528
2.5.3.1 CURRENT 情况 ....................................................................................................................... 528
2.5.3.2 非 CURRENT 情况 .................................................................................................................. 529
2.5.5.
非系统表空间损坏
.......................................................................................................... 529
2.5.6.
数据文件损坏
................................................................................................................. 530
2.5.7.
基于时间点
/SCN/
日志序列的不完全恢复
.................................................................... 530
2.5.7.1 基于时间点 ............................................................................................................................... 530
2.5.7.2 基于 SCN: ................................................................................................................................. 531
2.5.7.3 基于日志序列 ........................................................................................................................... 531
2.5.8.
非
catalog
下完全恢复
.................................................................................................... 531
2.6 前滚(ROLL FORWORD)和回滚(ROLL BACK) .......................................................................... 532
2.6.1
什么时候需要实例恢复
................................................................................................... 532
2.6.1.1 Clean shutdown 时 .................................................................................................................... 532
2.6.1.2 非正常 shutdown ..................................................................................................................... 533
2.6.1.3 crash recovery 顺序问题 .......................................................................................................... 533
2.6.2 Crash Recovery
过程
......................................................................................................... 533
2.6.3
为什么数据库的实例恢复是先前滚再回滚
................................................................... 534
三. RMAN....................................................................................................................................... 534
四. DATA GUARD ............................................................................................................................ 537
五. RAC .......................................................................................................................................... 731
5.1 集群环境下的一些特殊问题 ................................................................................................. 731
5.1.1
并发控制
.......................................................................................................................... 731
5.1.2
健忘症
(Amnesia) .............................................................................................................. 731
5.1.3
脑裂
(Split Brain) ................................................................................................................ 731
5.1.4 IO
隔离
(Fencing) ............................................................................................................ 732
5.2 RAC 并发 ............................................................................................................................... 732
5.2.1 GRD
(
Global Resource Directory
)
................................................................................ 733
5.3. RAC 架构 .................................................................................................................................. 733
5.3.1 SGA
的变化
....................................................................................................................... 733
5.3.2
后台进程的变化
.............................................................................................................. 733
5.3.2.1 LMSn ....................................................................................................................................... 734
5.3.2.2 LMD ......................................................................................................................................... 734
5.3.2.3 LCK........................................................................................................................................... 734
5.3.2.4 LMON ...................................................................................................................................... 734
5.3.2.5 DIAG ........................................................................................................................................... 734
5.3.2.6 GSD ............................................................................................................................................. 734
5.3.3
文件
.................................................................................................................................. 734
Tianlesoftware 学习 Oracle Blog: http://blog.csdn.net/tianlesoftware
DBA1 群:62697716(满); DBA2 群:62697977(满); DBA3 群:62697850(满); DBA 超级群:63306533
DBA4 群:83829929(满); DBA5 群:142216823 DBA6 群:158654907
5.3.3.1 spfile ........................................................................................................................................... 735
5.3.3.2 Redo Thread ............................................................................................................................... 735
5.3.3.3 Archived Log ............................................................................................................................... 735
1)使用 NFS ..................................................................................................................................... 735
2)实例间归档(CIA: Cross Instance Archive) ............................................................................. 736
3)使用 ASM .................................................................................................................................... 736
5.3.3.4 Undo Tablespace ........................................................................................................................ 736
5.3.4 SCN(System Change Number) ............................................................................................ 736
5.3.5 Cache Fusion
,
GCS
,
GES
关系
........................................................................................ 736
5.4 RAC 集群 ................................................................................................................................. 737
5.4.1 Clusterware ........................................................................................................................ 737
5.4.2 Clusterware
组成
.............................................................................................................. 737
5.4.2.1 磁盘文件 ............................................................................................................................. 737
5.4.2.2 Clusterware 后台进程 ......................................................................................................... 738
5.4.3 VIP
原理和特点
................................................................................................................ 740
5.4.4 Clusterware
的日志体系
.................................................................................................. 741
5.5 RAC FAILOVER ............................................................................................................................. 742
5.5.1
.
Client-Side Connect Time Failover ................................................................................... 742
5.5.2
.
Client-Side TAF(Transparent Application Failover) .......................................................... 743
5.5.3. Client-Side TAF
配置示例
.................................................................................................. 744
5.3.3.1 主机信息如下 ............................................................................................................................ 744
5.3.3.2 Node1 配置 ................................................................................................................................ 744
5.3.3.3 NODE2 配置 ............................................................................................................................... 745
5.3.3.4 在 node1 和 node2 的 tnsnames.ora 文件添加如下内容 ........................................................ 745
5.3.3.5 在所有节点设置 remote listener .............................................................................................. 746
5.3.3.6 在客户端设置的 tnsnames.ora 设置 TAF ................................................................................. 746
5.5.4
.
Service-Side TAF .............................................................................................................. 747
5.5.4.1 用 DBCA 配置 Service .............................................................................................................. 747
5.5.4.2 用 srvctl 命令配置 Service....................................................................................................... 748
5.5.4.3 配置 Service 的注意事项 ........................................................................................................ 749
5.5.5 Service-Side TAF
手工配置示例
..................................................................................... 749
5.6 RAC LOADBALANCE ...................................................................................................................... 754
5.6.1 Connection Balancing ......................................................................................................... 754
5.6.1.1 客户端均衡(Client-Side LB) ................................................................................................. 755
5.6.1.2 服务器端均衡(Server-Side LB) ............................................................................................ 755
5.6.1.3 两种 LB 的配置方法 ................................................................................................................ 757
5.6.2
利用
Service
分散负载
..................................................................................................... 757
5.7 RAC 启动和关闭 ..................................................................................................................... 759
5.7.1.
检查共享设备
................................................................................................................. 759
5.7.1.1 如果使用 ocfs2 的,检查 ocfs2 状态 ..................................................................................... 759
5.7.1.2. 如果使用 raw device. .............................................................................................................. 759
5.7.1.3. 检查 ASM ................................................................................................................................. 759
5.7.2
.自动启动
RAC
并检查相关进程
.................................................................................... 759
5.7.3
.手动启动
RAC ................................................................................................................. 762
Tianlesoftware 学习 Oracle Blog: http://blog.csdn.net/tianlesoftware
DBA1 群:62697716(满); DBA2 群:62697977(满); DBA3 群:62697850(满); DBA 超级群:63306533
DBA4 群:83829929(满); DBA5 群:142216823 DBA6 群:158654907
5.8 ORACLE RAC 常用维护工具和命令.......................................................................................... 764
5.8.1
节点层
............................................................................................................................... 764
5.8.2
网络层
............................................................................................................................... 764
5.8.3
集群层
............................................................................................................................... 766
5.8.3.1 CRSCTL ........................................................................................................................................ 766
5.8.3.1.1 检查 CRS 状态 ................................................................................................................. 767
5.8.3.1.2 配置 CRS 栈是否自启动 ................................................................................................. 767
5.8.3.1.3 启动,停止 CRS 栈 ......................................................................................................... 768
5.8.3.1.4 查看 Votedisk 磁盘位置 .................................................................................................. 768
5.8.3.1.5 查看和修改 CRS 参数 ..................................................................................................... 768
5.8.3.1.6 跟踪 CRS 模块,提供辅助功能 ...................................................................................... 768
5.8.3.1.7 维护 Voting disk ................................................................................................................ 770
5.8.3.2 OCR 命令系列 ............................................................................................................................ 770
5.8.3.2.1 ocrdump ............................................................................................................................. 771
5.8.3.2.2 ocrcheck ............................................................................................................................. 771
5.8.3.2.3 ocrconfig ............................................................................................................................ 772
5.8.3.2.4 使用 ocrconfig 导出,导入进行备份和恢复 ................................................................. 772
5.8.3.2.5 移动 OCR 文件位置 ......................................................................................................... 774
5.8.4
应用层
.............................................................................................................................. 775
5.8.4.1 crs_stat ....................................................................................................................................... 775
5.8.4.2 onsctl .......................................................................................................................................... 777
5.8.4.2.1 ONS 配置内容 .................................................................................................................. 777
5.8.4.2.2 配置 ONS .......................................................................................................................... 778
5.8.4.2.3 onsctl 命令 ........................................................................................................................ 778
5.8.4.3 srvctl ........................................................................................................................................... 780
5.8.4.3.1 使用 config 查看配置 ....................................................................................................... 781
5.8.4.3.2 使用 add 添加对象 ......................................................................................................... 782
5.8.4.3.3 使用 enable/disable 启动,禁用对象 ............................................................................ 783
5.8.4.3.4 使用 remove 删除对象 ................................................................................................... 784
5.8.4.3.5 启动,停止对象与查看对象 ........................................................................................... 784
5.8.4.3.6 跟踪 srvctl ......................................................................................................................... 785
5.8.4.4 初始化 OCR 和 Voting Disk ...................................................................................................... 785
5.8.4.5 官网的命令说明 ....................................................................................................................... 787
5.8.4.6 crs_stat 完整显示进程名脚本 ................................................................................................. 789
六. 常用脚本............................................................................................................................... 1206
6.1 查看表空间使用率 ................................................................................................................. 1206
6.2 获取当前 TRACE 文件路径脚本 .............................................................................................. 1207
6.3 发送邮件的存储过程 ............................................................................................................. 1207
6.4 AWR 自动收集并发送邮箱 PYTHON 脚本 ............................................................................... 1216
6.4.1
准备工作
......................................................................................................................... 1216
6.4.2
生成
AWR
报告
SQL
脚本
.............................................................................................. 1221
6.4.3
自动上传
AWR
的
Python
脚本
..................................................................................... 1222
6.4.4
将
Python
添加到
crontab ............................................................................................. 1224
Tianlesoftware 学习 Oracle Blog: http://blog.csdn.net/tianlesoftware
DBA1 群:62697716(满); DBA2 群:62697977(满); DBA3 群:62697850(满); DBA 超级群:63306533
DBA4 群:83829929(满); DBA5 群:142216823 DBA6 群:158654907
6.5 查看 SEGMENT 中 BLOCK 的存储信息 ...................................................................................... 1224
6.6 ORACLE 用 SQLPROMPT 修改 SQLPLUS 提示符 ........................................................................... 1227
6.6.1
方法一:使用定义的变量
............................................................................................. 1228
6.6.2
方法二:使用
sql
语句拼接
......................................................................................... 1229
七. 性能优化............................................................................................................................... 1242
7.1 软解析 和 硬解析 ................................................................................................................. 1242
7.1.1 SQL
解析过程
.............................................................................................................. 1242
7.1.2
.解析过程详解
.............................................................................................................. 1242
7.1.2.1 语法检测................................................................................................................................. 1242
7.1.2.2 语义检查................................................................................................................................. 1242
7.1.2.3 解析(Parse) ............................................................................................................................. 1243
7.1.2.3.1 Parse 主要分为两种: .................................................................................................... 1243
7.1.2.3.2 解析的两个步骤 ............................................................................................................ 1243
7.1.2.4 执行 sql ................................................................................................................................... 1245
7.2 绑定变量 ................................................................................................................................. 1245
7.2.1 Band Variable
说明
...................................................................................................... 1245
7.2.2
.
OLAP
和
OLTP
系统中的绑定变量
............................................................................. 1246
7.2.3
.
Bind peaking.................................................................................................................. 1247
7.2.4
绑定变量
使用示例
..................................................................................................... 1248
7.3 CBO 和 RBO ............................................................................................................................ 1250
7.3.1 RBO
基于规则的优化器
................................................................................................. 1250
7.3.2 CBO
基于成本的优化器
.................................................................................................. 1251
7.3.2.1 CBO 说明 ................................................................................................................................. 1251
7.3.3.2 优化器模式 ............................................................................................................................. 1252
7.3.3.2.1 修改 CBO 模式的三种方法 ............................................................................................ 1252
7.3.3.2.2 查看 CBO 模式 ............................................................................................................... 1253
7.3.3.2.3 优化器模式具体说明..................................................................................................... 1253
7.3.3 optimizer_index_cost_adj
参数
....................................................................................... 1254
7.3.4
在
CBO
下写
SQL
语句的注意事项
................................................................................ 1254
7.4 10053 事件 .............................................................................................................................. 1256
7.4.1 10053
事件说明
............................................................................................................. 1256
7.4.2
示例:
............................................................................................................................ 1257
7.4.3
查看生成的
trace
文件
.................................................................................................. 1258
7.5 10046 事件 .............................................................................................................................. 1264
7.5.1 10046
事件说明
............................................................................................................. 1264
7.5.2
对当前
session
使用
10046
事件
.................................................................................. 1264
7.5.3
对其他的会话进行跟踪
.................................................................................................. 1265
7.5.3.1 用 SQL_TRACE 跟踪 ................................................................................................................ 1265
7.5.3.2 使用 10046 事件跟踪 ............................................................................................................ 1265
7.6 SQL TRACE .................................................................................................................................. 1266
7.7 统计信息 ................................................................................................................................. 1267
7.7.1. Statistic
说明
.................................................................................................................. 1267
7.7.2
统计信息的收集
.......................................................................................................... 1268
Tianlesoftware 学习 Oracle Blog: http://blog.csdn.net/tianlesoftware
DBA1 群:62697716(满); DBA2 群:62697977(满); DBA3 群:62697850(满); DBA 超级群:63306533
DBA4 群:83829929(满); DBA5 群:142216823 DBA6 群:158654907
7.7.2.1 查看该 Job 信息 .................................................................................................................... 1268
7.2.2.2 监控参数 STATISTICS_LEVEL .................................................................................................. 1269
7.2.2.3 停用该 Job .............................................................................................................................. 1269
7.2.3.4 系统用户统计信息的收集 ...................................................................................................... 1269
7.7.3.
统计信息的存储位置
.................................................................................................... 1270
7.3.3.1 表的统计信息 ......................................................................................................................... 1271
7.3.3.2 索引列的统计信息 ................................................................................................................. 1271
7.3.3.3 列的统计信息 ......................................................................................................................... 1271
7.3.3.4 测试:表只有分析了之后,num_rows 才会有值 ............................................................... 1271
7.7.4
直方图(
histograms
)
................................................................................................. 1272
7.7.4.1 Height-Balanced Histograms ................................................................................................. 1273
7.7.4.2 Frequency Histograms ........................................................................................................... 1274
7.7.5 DBMS_STATS
包
使用说明
........................................................................................... 1276
7.7.5.1 DBMS_STATS 包的几个常用功能:性能的收集,设置,删除 ............................................. 1277
7.7.5.1.1 GATHER_TABLE_STATS 存储过程 ............................................................................... 1277
7.7.5.1.2 GATHER_SCHEMA_STATS 存储过程 ............................................................................ 1283
7.7.5.1.3 DBMS_STATS.GATHER_INDEX_STATS 存储过程 ........................................................... 1287
7.7.5.2 DBMS_STATS 包管理功能 ........................................................................................................ 1289
7.7.5.2.1 获取分析数据 ................................................................................................................ 1289
7.7.5.2.2 设置分析数据 ................................................................................................................ 1290
7.7.5.2.3 删除分析数据 ................................................................................................................ 1290
7.7.5.2.4 保存分析数据 ................................................................................................................ 1291
7.7.5.2.5 导入和导出分析数据..................................................................................................... 1291
7.7.5.2.6 锁定分析数据 ................................................................................................................ 1292
7.7.5.2.7 分析数据的恢复 ............................................................................................................ 1292
7.7.6
动态采样
...................................................................................................................... 1293
7.7.6.1 什么是动态采样 ..................................................................................................................... 1293
7.7.6.2 动态采样的级别 ..................................................................................................................... 1296
7.7.6.2.1 Level 0 .............................................................................................................................. 1297
7.7.6.2.2 Level 1 .............................................................................................................................. 1297
7.7.6.2.3 Level 2 .............................................................................................................................. 1297
7.7.6.2.4 Level 3 .............................................................................................................................. 1297
7.7.6.2.5 Level 4 .............................................................................................................................. 1297
7.7.6.2.6 Level 5,6,7,8,9 ...................................................................................................... 1297
7.7.6.2.7 Level 10 ............................................................................................................................ 1297
7.7.6.3 什么时候使用动态采样 ......................................................................................................... 1297
7.8 HINT .......................................................................................................................................... 1298
7.8.1
和优化器相关的
Hint ..................................................................................................... 1300
7.8.1.1 ALL_ROWS 和 FIRST_ROWS(n) -- CBO 模式 .................................................................... 1300
7.8.1.2 RULE Hint -- RBO 模式 ....................................................................................................... 1300
7.8.2
访问路径相关的
Hint ...................................................................................................... 1301
7.8.2.1 FULL Hint .................................................................................................................................. 1301
7.8.2.2 INDEX Hint ................................................................................................................................ 1301
7.8.2.3 NO_INDEX Hint ......................................................................................................................... 1302
剩余1430页未读,继续阅读
2018-09-30 上传
2013-10-16 上传
2013-01-26 上传
2023-06-01 上传
2023-12-19 上传
2023-06-02 上传
2023-04-30 上传
2024-10-25 上传
2023-09-16 上传
eric-po
- 粉丝: 0
- 资源: 1
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
最新资源
- Java集合ArrayList实现字符串管理及效果展示
- 实现2D3D相机拾取射线的关键技术
- LiveLy-公寓管理门户:创新体验与技术实现
- 易语言打造的快捷禁止程序运行小工具
- Microgateway核心:实现配置和插件的主端口转发
- 掌握Java基本操作:增删查改入门代码详解
- Apache Tomcat 7.0.109 Windows版下载指南
- Qt实现文件系统浏览器界面设计与功能开发
- ReactJS新手实验:搭建与运行教程
- 探索生成艺术:几个月创意Processing实验
- Django框架下Cisco IOx平台实战开发案例源码解析
- 在Linux环境下配置Java版VTK开发环境
- 29街网上城市公司网站系统v1.0:企业建站全面解决方案
- WordPress CMB2插件的Suggest字段类型使用教程
- TCP协议实现的Java桌面聊天客户端应用
- ANR-WatchDog: 检测Android应用无响应并报告异常
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功