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

杨廷琨(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,数据源的不同也正是前端的不同。

原文发布于微信公众号 - 数据和云(OraNews)

原文发表时间:2016-04-15

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏MasiMaro 的技术博文

OLEDB事务

学过数据的人一般都知道事务的重要性,事务是一种对数据源的一系列更新进行分组或者批处理以便当所有更新都成功时同时提交更新,或者任意一个更新失败时进行回滚将数据库中...

1444
来自专栏从零开始的linux

mycat实现mysql的读写分离

环境 ip角色端口128.0.0.101master3306128.0.0.102slave3306128.0.0.103mycat8066 前提两台机器已经做...

3466
来自专栏杨建荣的学习笔记

Oracle 12cR2中的ADG会话保留特性

Oracle 12cR2中有一个不错的特性,那就是Active Data Guard会话保留,原本的叫法是Preserving Active Data Guar...

2815
来自专栏我的博客

Sqlite使用说明

安装apt-get install slqite .databases List names and files of attached databases(列...

3314
来自专栏Linyb极客之路

MySQL数据库“十宗罪”(十大经典错误案例)

Too many connections(连接数过多,导致连接不上数据库,业务无法正常进行)

1222
来自专栏散尽浮华

mysqldump数据导出问题和客户端授权后连接失败问题

1,使用mysqldump时报错(1064),这个是因为mysqldump版本太低与当前数据库版本不一致导致的。 mysqldump: Couldn't exe...

2329
来自专栏猿人谷

Oracle RAC基本维护指令

所有实例和服务的状态 $ srvctl status database -d orcl Instance orcl1 is running on node l...

2127
来自专栏乐沙弥的世界

RAC 环境下修改归档模式

    RAC环境下的归档模式切换与单实例稍有不同,主要是共享存储所产生的差异。在这种情况下,我们可以将RAC数据库切换到非集群状态下,仅仅在一个实例上来实施归...

902
来自专栏沃趣科技

复制状态与变量记录表 | performance_schema全方位介绍

不知不觉中,performance_schema系列快要接近尾声了,今天将带领大家一起踏上系列第六篇的征程(全系共7个篇章),在这一期里,我们将为大家全面讲解p...

1623
来自专栏杨建荣的学习笔记

系统级alias vs Oracle ADR功能(r5笔记第35天)

Oracle在11g中推出的新特性ADR,即Automatic Diagnostic Repository 个人理解这个工具就是能够高效的把一些日志文件轻松管理...

3558

扫码关注云+社区