oracle事件的特点,Oracle 20c 新特性:DIAGNOSTICS_CONTROL 对诊断事件的安全管控

原标题:Oracle 20c 新特性:DIAGNOSTICS_CONTROL 对诊断事件的安全管控

导读:在诊断Oracle数据库问题时,Oracle支持服务人员可能会指示您执行某些诊断操作。有些诊断操作是无害的。但是,如果不正确地执行其他操作,可能会产生不利影响。为了控制和监控执行此类诊断操作的人员,Oracle Database 20 引入了诊断控制的安全控制措施。

在诊断Oracle数据库问题时,Oracle支持服务人员可能会指示您执行某些诊断操作。有些诊断操作是无害的。但是,如果不正确地执行其他操作,可能会产生不利影响。为了控制和监控执行此类诊断操作的人员,Oracle Database 20 引入了诊断控制的安全控制措施。

这一改进是通过参数 DIAGNOSTICS_CONTROL 来引入的:

a05b6fae561c34ba72fe52f811a4a60b.png

潜在的不安全诊断操作在数据库中被内部识别出来。这些操作包括用ALTER SESSION或ALTER SYSTEM语句设置某些调试事件和调试操作。例如。

ALTERSESSIONSETEVENTS'1357 trace name context forever, level 2';

ALTERSYSTEMSETEVENTS'trace[vos]';

用户可以通过被授予ENABLE DIAGNOSTICS系统权限,或被授予DBA角色,或以SYSDBA身份认证,来授权用户执行潜在的不安全诊断操作。

DIAGNOSTICS_CONTROL初始化参数可以让你指定当一个未经授权的用户试图执行这些诊断操作时,数据库如何响应,可能的参数值是:

ERROR: 当未经授权的用户尝试执行一个潜在的不安全的诊断操作时,该尝试以错误 ORA-01031: 权限不足而失败。

WARNING:当未经授权的用户尝试执行潜在的不安全诊断操作时,尝试成功,但警告被写入警告日志。

IGNORE:当未经授权的用户尝试执行潜在的不安全诊断操作时,尝试成功,不会出现错误信息或警告。这是默认情况。

接下来让我们通过测试展示一下这个参数控制的效果。

首先创建一个测试用户:

Copyright( c) 1982, 2020, Oracle. Allrightsreserved.

LastSuccessfullogintime: FriApr24 2020 02 :51:08+00 :00

Connectedto:OracleDatabase20 cEnterpriseEditionRelease20 .0.0.0.0-ProductionVersion20 .2.0.0.0

SQL> showuserUSERis" EYGLE"SQL> createuserenmoidentifiedbyenmo;

Usercreated.

SQL> grantconnect, resourcetoenmo;

Grantsucceeded.

SQL> grantaltersessiontoenmo;

Grantsucceeded.

然后设置参数,以下在 CDB 以 SYS 用户执行:

SQL>show userUSER is "SYS"SQL>alter system setdiagnostics_control=ERROR;

System altered.

此时,在新建立的用户 ENMO 上执行 ALTER SESSION 修改诊断参数,可以看到终端直接收到了 ORA-01031 错误,阻止了用户执行:

SQL>connect enmo/enmo@enmoConnected.SQL>ALTER SESSION SET EVENTS '1357 trace name context forever, level 2';ERROR:ORA-01031: insufficient privilegesORA-49100: Failed to process event statement [1357 trace name context forever,level 2]

接下来在 CDB 修改参数:

SQL>alter system setdiagnostics_control=WARNING;System altered.

注意,修改参数的动作会记入告警日志:

SQL> ! tail -4alert*2020-04-24T02: 52: 25.957547+ 00: 00ALTER SYSTEM SET diagnostics_control= 'ERROR'SCOPE=BOTH;2020-04-24T02: 55: 51.341360+ 00: 00ALTER SYSTEM SET diagnostics_control= 'WARNING'SCOPE=BOTH;

此时回到 ENMO 用户的会话,重复执行 ALTER SESSION 可以看到执行成功:

SQL>ALTER SESSION SET EVENTS '1357 trace name context forever, level 2';Session altered.

观察告警日志,可以看到详细的信息都被记录下来,包括执行的用户、时间 等,但是操作被执行:

SQL> ! tail -6alert*2020-04-24T02: 57: 49.719833+ 00: 00ALTER SYSTEM SET diagnostics_control= 'WARNING'SCOPE=BOTH;2020-04-24T02: 57: 54.962153+ 00: 00ENMO( 4):User 'ENMO'has setthe following debug- event(s) onthe event- group'session':ENMO( 4): '1357 trace name context forever, level 2'ENMO( 4):To disable such messages, refer to documentation about parameter 'diagnostics_control'.

最后,在修改DIAGNOSTICS_CONTROL初始化参数时,请注意以下注意事项。

要使用ALTER SYSTEM命令修改这个参数,必须通过认证为SYSDBA。

在Oracle RAC环境中,目前无法通过在ALTER SYSTEM SET语句中指定SID子句在远程实例上修改此参数。

显然,通过 DIAGNOSTICS_CONTROL ,Oracle 让看不到、摸不着的诊断操作,变得有迹可循,可以跟踪,云和恩墨认为,这是 Oracle 细致入微的又一体现,对数据库安全进行了有益的管控和增强。

参考:https://docs.oracle.com/en/database/oracle/oracle-database/20/refrn/DIAGNOSTICS_CONTROL.html

墨天轮原文链接:https://www.modb.pro/db/24490(复制到浏览器中打开或者点击“阅读原文”)

144页!分享珍藏已久的数据库技术年刊

数据和云

ID:OraNews

在看”,谢谢!

点击下图查看更多 ↓

云和恩墨大讲堂 |一个分享交流的地方

万人交流社群

请备注:云和恩墨大讲堂

点个“在看”

你的喜欢会被看到❤返回搜狐,查看更多

责任编辑:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值