没有合适的资源?快使用搜索试试~ 我知道了~
首页Oracle学习手册:技术大牛整理精华
Oracle学习手册:技术大牛整理精华
3星 · 超过75%的资源 需积分: 10 2 下载量 6 浏览量
更新于2024-07-25
1
收藏 45.36MB PDF 举报
"Oracle技术大牛 TianleSoftware 整理的《Oracle 学习手册》是一个详尽的文档集合,包含了他在学习Oracle数据库过程中遇到的问题及解决方案,总计超过千页,内容更新至2012年。这个手册源于作者的个人博客,并经过分类和整理,方便读者查阅。文档中引用了多位知名Oracle专家如eygle、君三思、谭怀远、陈吉平等人的著作和博客,旨在为Oracle初学者提供指导。手册中可能存在一些排版问题和理解误差,作者鼓励读者发现错误后通过邮件与他交流以便及时更新。此外,手册还提供了多个Oracle DBA交流群的QQ号码,便于读者交流学习。"
这篇文档是Oracle数据库学习的重要资源,涵盖了作者多年学习和实践的经验总结。以下是一些关键知识点:
1. **Oracle基础知识**:手册可能包括Oracle数据库的基本概念,如数据模型、表空间、段、区和块等,以及SQL语言的基础操作,如DML(INSERT, UPDATE, DELETE)和DDL(CREATE, ALTER, DROP)。
2. **数据库管理**:可能涵盖数据库的创建、备份恢复、性能优化、安全设置、用户管理和权限管理等方面的知识。
3. **Oracle架构**:可能深入解析Oracle的物理和逻辑结构,包括实例、进程、内存结构和数据文件等。
4. **故障排查**:可能会介绍如何诊断和解决常见的Oracle问题,如死锁、性能瓶颈、错误日志分析等。
5. **数据库性能调优**:可能包含索引优化、查询优化、存储优化等,以及使用工具如SQL*Plus、 tkprof 和企业管理器等进行性能监控和分析。
6. **存储过程和函数**:可能会涉及PL/SQL编程,包括编写存储过程、函数、触发器和游标。
7. **数据库复制与集群**:可能涵盖Oracle的逻辑和物理复制技术,如逻辑复制(Materialized Views, Streams)、物理复制(RMAN, Data Guard)以及RAC(Real Application Clusters)集群的配置和管理。
8. **安全性**:可能讲解如何设置用户权限、角色管理、审计策略,以及如何应对SQL注入等安全威胁。
9. **故障转移和高可用性**:可能会讨论Oracle的灾难恢复策略,如闪回、数据保护和业务连续性方案。
10. **最佳实践**:作者可能分享了一些他在实际工作中总结的最佳实践,帮助读者避免常见错误,提高工作效率。
此手册对于Oracle初学者和有一定经验的DBA来说,都是宝贵的参考资料,它不仅包含了理论知识,还融入了实践经验,有助于读者深入理解和掌握Oracle数据库系统。
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页未读,继续阅读
2013-02-25 上传
2023-04-20 上传
2426 浏览量
2013-08-14 上传
2013-08-21 上传
2013-01-08 上传
2013-09-30 上传
点击了解资源详情
点击了解资源详情
qinfeng19889166
- 粉丝: 15
- 资源: 215
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
最新资源
- 前端协作项目:发布猜图游戏功能与待修复事项
- Spring框架REST服务开发实践指南
- ALU课设实现基础与高级运算功能
- 深入了解STK:C++音频信号处理综合工具套件
- 华中科技大学电信学院软件无线电实验资料汇总
- CGSN数据解析与集成验证工具集:Python和Shell脚本
- Java实现的远程视频会议系统开发教程
- Change-OEM: 用Java修改Windows OEM信息与Logo
- cmnd:文本到远程API的桥接平台开发
- 解决BIOS刷写错误28:PRR.exe的应用与效果
- 深度学习对抗攻击库:adversarial_robustness_toolbox 1.10.0
- Win7系统CP2102驱动下载与安装指南
- 深入理解Java中的函数式编程技巧
- GY-906 MLX90614ESF传感器模块温度采集应用资料
- Adversarial Robustness Toolbox 1.15.1 工具包安装教程
- GNU Radio的供应商中立SDR开发包:gr-sdr介绍
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功