0

返璞归真:获取Oracle初始化参数设定的N种方法

杨廷琨 2016-04-15
104


杨廷琨(yangtingkun)

云和恩墨 CTO

高级咨询顾问,Oracle ACE 总监,ITPUB Oracle 数据库管理版版主

参数文件是Oracle数据库文件中级别最低,也是最基本的文件,但是也是数据库实例启动第一个涉及的文件。如果参数文件缺失或者某些参数设置错误,数据库就无法启动。


不要小看这个参数文件,其中隐藏的学问并不少,接下来让我们一一细数关于参数文件的点点滴滴。


多种查询初始化参数方法


查询初始化参数的方法很多,比如 SHOW PARAMETER,或查询 V$PARAMETER 等,这里简单总结一下。


首先初始化参数的设置的方法就有很多种:

  1. 可以通过 ALTER SYSTEM SET SCOPE = MEMORY 的方式仅设置内存的修改;

  2. 也可以通过 ALTER SYSTEM SET SCOPE = SPFILE 只修改 SPFILE 的值;

  3. 当然也可以同时修改 SPFILE 和 MEMORY 中的设置。

还有一种初始化参数可以设置延迟生效,也就是说这个修改只对以后连接到数据库的会话生效,而对当前会话以及其他已经连接到 Oracle 的会话不会生效。

如果再考虑 RAC 环境,数据库中存在多个启动实例的情况,那么查询数据库初始化参数就更加复杂了。


所幸 Oracle 提供的查询初始化参数方法也有很多种途径、方法和来源,请和我们一起熟悉一下以下种种:

SHOW PARAMETERS

SHOW SPPARAMETERS

CREATE PFILE

V$PARAMETER

V$PARAMETER2

V$SYSTEM_PARAMETER

V$SYSTEM_PARAMETER2

V$SPPARAMETER


以下对这些方法分别进行说明:

  • SHOW PARAMETERS 是 SQLPLUS 工具提供的查询初始化参数的方法,这个方法查询的初始化参数是当前会话生效的初始化参数。


  • SHOW SPPARAMETERS 也是 SQLPLUS 工具提供的方法,用来查询当前会话生效的 SPFILE 参数包含的初始化参数。这个命令在11g 以后 sqlplus 版本中有效。


  • CREATE PFILE 命令不像其他方法那样直观,这种方法可以将 SPFILE 中或当前内存中设置的初始化文件保存到 PFILE 文件中,然后就可以通过文本编辑工具直观的看到 SPFILE 中或当前内存中设置了哪些初始化参数。虽然这种方法看上去比较麻烦,但是这种方法列出的参数都是用户设置的参数,所有默认值的参数并不会列出来,因此看到的结果要比其他方法直观得多。在11g 以后的版本允许 CREATE PFILE FROM MEMORY。


  • V$PARAMETER 视图提供了当前会话可见的初始化参数的设置,如果像查询 RAC 数据库的所有实例的设置,可以查询 GV$PARAMETER 视图。


  • V$PARAMETER2 视图和 V$PARAMETER 差不多,唯一的区别在于对于包括多值的初始化参数,从这个视图会返回多条记录,每条记录对应一个值。同样的,对于 RAC 环境可以查询 GV$PARAMETER2 视图。


  • V$SYSTEM_PARAMETER 视图记录当前实例生效的初始化参数设置。注意这里是实例生效而不是会话生效。同样,GV$SYSTEM_PARAMETER 则包含了所有实例生效的初始化参数信息。


  • V$SYSTEM_PARAMETER2 视图与 V$SYSTEM_PARAMETER 视图的关系和 V$PARAMETER2 视图与 V$PARAMETER视 图的关系一样,都是对于包含多个值的参数采用了分行处理的方式。


  • V$SPPARAMETER 记录了来自 SPFILE 文件中初始化参数。如果参数在 SPFILE 文件中没有设置,则字段 ISSPECIFIED 对应的值为 FALSE。同样可以查询 GVSPPARAMETER 参数来显示 RAC 环境所有实例的设置。


首先看一下V$PARAMETER和V$PARAMETER2的区别,这个区别同样适用于V$SYSTEM_PARAMETER和V$SYSTEM_PARAMETER2:


SQL> SELECT NAME, VALUE FROM V$PARAMETER
 2  MINUS
 3  SELECT NAME, VALUE FROM V$PARAMETER2;

NAME                                     
---------------------------------------- 
control_files                            

VALUE

--------------------------------------------------

E:\ORACLE\ORADATA\YTK102\CONTROL01.CTL, E:\ORACLE\ORADATA\YTK102\CONTROL02.CTL, E:\ORACLE\ORADATA\YTK102\CONTROL03.CTL


SQL> SELECT NAME, VALUE FROM V$PARAMETER2
 2  MINUS
 3  SELECT NAME, VALUE FROM V$PARAMETER;

NAME                                     VALUE
---------------------------------------- --------------------------------------------------
control_files                            E:\ORACLE\ORADATA\YTK102\CONTROL01.CTL
control_files                            E:\ORACLE\ORADATA\YTK102\CONTROL02.CTL
control_files                            E:\ORACLE\ORADATA\YTK102\CONTROL03.CTL

现在这两个视图的结果一目了然了。进一步的研究可以看到底层的数据源来自两个不同的位置,V$PARAMETER来自x$ksppcv ,V$PARAMETER2来自x$ksppcv2,数据源的不同也正是前端的不同。


如何加入"云和恩墨大讲堂"微信群

搜索 盖国强(Eygle) :eeygle,或者扫描下面二维码,备注:云和恩墨大讲堂,即可入群。每周与千人共享免费技术分享,与讲师在线讨论。

近期文章

诗和远方:云和恩墨大讲堂期刊第四期

删繁就简-云和恩墨的一道面试题解析

用SQL解一道数学题:Gauss和Poincare

新年贺礼:云和恩墨大讲堂期刊发行

2015 Oracle 十大热门文章精选

Oracle 12c ASM 防火防盗新特性揭秘

DBA入门之路:学习与进阶之经验谈

DBA入门之路:关于日常工作的建议

资源下载

(帐号:OraNews)回复关键字获取最新学习资源

2016YHEMSZ ,云和恩墨大讲堂2016深圳交流会PPT;

2016GOPSZ ,2016深圳全球运维大会PPT;

DBALife ,"DBA的一天"精品海报大图;

12cArch ,“Oracle 12c体系结构”精品海报大图;

DBA01 ,《Oracle DBA手记》第一本图书下载;

YunHe “云和恩墨大讲堂”案例文档下载地址;


最后修改时间:2020-05-08 00:20:50
「喜欢文章,快来给作者赞赏墨值吧」
文章转载自杨廷琨,如果涉嫌侵权,请发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论

数据库资讯
最新 热门 更多
本月热门
近期活动
全部
暂无活动,敬请期待...
相关课程
全部