共计 4858 个字符,预计需要花费 13 分钟才能阅读完成。
导读 | Oracle Database,又名 Oracle RDBMS,或简称 Oracle。是甲骨文公司的一款关系数据库管理系统。它是在数据库领域一直处于领先地位的产品。可以说 Oracle 数据库系统是目前世界上流行的关系数据库管理系统,系统可移植性好、使用方便、功能强,适用于各类大、中、小、微机环境。它是一种高效率、可靠性好的 适应高吞吐量的数据库解决方案。 |
Oracle 参数设置之 set 与 reset 的实际案例
环境:Oracle 10.2.0.5 RAC
需求:节点 1 的 aq_tm_processes 要求恢复默认,节点 2 设置要求保持不变
- 1. 构建测试环境
- 2. 测试方案
- 3. 总结
背景介绍:
从 10.2 官档可以查到 aq_tm_processes 参数,看到该参数的默认值是 0,我们姑且叫做它为默认 0.
然后,在实际上发现,这个默认 0 和我们手工将其 SET 设置成 0,效果是完全不一样的。
与同事交流此事,最终得知一个技术细节:
Oracle 中,使用 SET 设置参数值实际上是少做很多事情的,如果你想恢复 Oracle 的默认值,最有效的办法就是 RESET 该值,这样,才会一切都按照 Oracle 默认的设计。
具体来看现在的场景,如果你对参数 aq_tm_processes 设置为 0. 那和本来的默认 0 是完全不一样的。
如果是设置 0,所有 q00 小工进程都会关闭不会再启动。如果是默认 0,q00 小工进程是可以启动的。
目前生产的参数内容是类似这样,有全局设置,有实例 1 的设置,如下:
*.aq_tm_processes=1
jy1.aq_tm_processes=0
我们知道,针对实例的设置优先级是高的,也就是说这样设置的效果就是实例 1 该参数是 0,实例 2 该参数是 1.
即:实例 1 无法启动 q00 小工进程,实例 2 可以启动 q00 小工进程。
构建测试环境模拟生产:
先设置 aq_tm_processes 为 1:
alter system set aq_tm_processes = 1 scope=both sid='*';
--create pfile='/tmp/pfile11.ora' from spfile;
此时参数文件中就会有这样的设置:
*.aq_tm_processes=1
再设置实例 1 的 aq_tm_processes 为 0
alter system set aq_tm_processes = 0 scope=both sid='jy1';
--create pfile='/tmp/pfile12.ora' from spfile;
此时参数文件中就会有这样的设置:
*.aq_tm_processes=1
jy1.aq_tm_processes=0
此时就模拟了生产环境的现状。下面来看下实际的操作过程:
SQL>
SQL> alter system set aq_tm_processes = 1 scope=both sid='*';
System altered.
SQL> create pfile='/tmp/pfile11.ora' from spfile;
File created.
SQL> show parameter aq
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
aq_tm_processes integer 1
SQL> !ps -ef|grep q00
oracle 1462 27385 0 15:27 pts/1 00:00:00 /bin/bash -c ps -ef|grep q00
oracle 1464 1462 0 15:27 pts/1 00:00:00 grep q00
oracle 26534 1 0 15:08 ? 00:00:00 ora_q002_jy1
oracle 31538 1 0 15:21 ? 00:00:00 ora_q000_jy1
SQL>
SQL> alter system set aq_tm_processes = 0 scope=both sid='jy1';
System altered.
SQL> create pfile='/tmp/pfile12.ora' from spfile;
File created.
SQL> show parameter aq
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
aq_tm_processes integer 0
SQL> !ps -ef|grep q00
oracle 2044 27385 0 15:28 pts/1 00:00:00 /bin/bash -c ps -ef|grep q00
oracle 2046 2044 0 15:28 pts/1 00:00:00 grep q00
SQL>
可以看到,确实设置为 0 之后 q00 进程就消失了,即使再重启实例也是一样的,q00 进程不再会启动。
现在我们要做的就是保障不更改节点 2 的设置情况下,将节点 1 的 aq_tm_processes 恢复默认。
alter system reset aq_tm_processes scope=spfile sid='jy1';
create pfile='/tmp/pfile13.ora' from spfile;
重启节点 1 验证?确认是否可以实现需求?
具体实际操作如下:
SQL> alter system reset aq_tm_processes scope=spfile sid='jy1';
System altered.
SQL> create pfile='/tmp/pfile13.ora' from spfile;
File created.
SQL> show parameter aq
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
aq_tm_processes integer 0
SQL> !ps -ef|grep q00
oracle 3801 27385 0 15:32 pts/1 00:00:00 /bin/bash -c ps -ef|grep q00
oracle 3803 3801 0 15:32 pts/1 00:00:00 grep q00
SQL> startup force
ORACLE instance started.
Total System Global Area 599785472 bytes
Fixed Size 2098112 bytes
Variable Size 301993024 bytes
Database Buffers 289406976 bytes
Redo Buffers 6287360 bytes
Database mounted.
Database opened.
SQL> show parameter aq
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
aq_tm_processes integer 1
SQL> !ps -ef|grep q00
oracle 4228 1 0 15:33 ? 00:00:00 ora_q000_jy1
oracle 4232 1 0 15:33 ? 00:00:00 ora_q002_jy1
oracle 5021 27385 0 15:35 pts/1 00:00:00 /bin/bash -c ps -ef|grep q00
oracle 5023 5021 0 15:35 pts/1 00:00:00 grep q00
SQL>
可以看到,答案明显是:不可以。
因为这样只会将实例 1 的参数 reset,但是由于之前还有全局参数 *��所以重启实例 1 后会发现,aq_tm_processes 参数会是 1。
也就是说,针对实例 1 的设置去掉了,自然会沿袭整体的设置。
有了上面的基础,就有了实现需求的思路:
我们想下,如果把全局参数也 reset,会影响到节点 2 之前的设置,那么这样,只能将节点 2 的值单独设定,然后再 reset 全局参数。
alter system set aq_tm_processes = 1 scope=both sid='jy2';
--create pfile='/tmp/pfile14.ora' from spfile;
alter system reset aq_tm_processes scope=spfile sid='*';
--create pfile='/tmp/pfile15.ora' from spfile;
重启节点 1 验证??确认是否可以实现需求?
具体实际操作如下:
SQL> alter system set aq_tm_processes = 1 scope=both sid='jy2';
System altered.
SQL> create pfile='/tmp/pfile14.ora' from spfile;
File created.
SQL> alter system reset aq_tm_processes scope=spfile sid='*';
System altered.
SQL> create pfile='/tmp/pfile15.ora' from spfile;
File created.
SQL> startup force
ORACLE instance started.
Total System Global Area 599785472 bytes
Fixed Size 2098112 bytes
Variable Size 301993024 bytes
Database Buffers 289406976 bytes
Redo Buffers 6287360 bytes
Database mounted.
Database opened.
SQL> show parameter aq
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
aq_tm_processes integer 0
SQL> !ps -ef|grep q00
oracle 7446 1 1 15:40 ? 00:00:00 ora_q000_jy1
oracle 7448 1 0 15:40 ? 00:00:00 ora_q001_jy1
oracle 7450 1 0 15:40 ? 00:00:00 ora_q002_jy1
oracle 7452 1 0 15:40 ? 00:00:00 ora_q003_jy1
oracle 7480 27385 0 15:41 pts/1 00:00:00 /bin/bash -c ps -ef|grep q00
oracle 7482 7480 0 15:41 pts/1 00:00:00 grep q00
SQL>
可以看到,真实操作测试验证的答案和预想的一致:可以。
注:所有创建 pfile 的步骤都可以去掉。当时是因为想确认理论是否正确才给每一步后加了这个操作。
那么总结归纳下,实际在客户环境下,就是应该做以下三个步骤完成需求:
-- 保障节点 2 的设置不变
alter system set aq_tm_processes=1 scope=spfile sid='jy2';
--reset 节点 1 的设置
alter system reset aq_tm_processes scope=spfile sid='jy1';
--reset 全局的设置
alter system reset aq_tm_processes scope=spfile sid='*';
本文知识点总结:其实只需下面这 3 个知识点清楚就 ok 了:
reset 操作实际只是将这个值从 spfile 中移除;
针对某个实例级别的设置优先级高于整体设置;
注意 Oracle 对于 SET 参数值这种方式,实际上少做了很多事情,简单理解就是默认 0 和设置 0 不一样。