生产环境中oracle dba权限检查和回收相关命令汇总

一、oracle dba权限检查和回收的作用和意义

在Oracle数据库生产环境中,回收oracle dba权限的作用和意义重大,具体表现在以下三方面:

  1. 安全性:回收赋权检查和回收可以确保数据库中的权限控制得到有效管理。通过检查和回收权限,可以防止未经授权的用户访问敏感数据或执行危险操作。

  2. 数据完整性:回收赋权检查和回收可以帮助确保数据库中的数据完整性。通过检查和回收权限,可以防止未经授权的用户对数据进行修改、删除或插入操作,从而保护数据的完整性。

  3. 性能优化:回收赋权检查和回收可以帮助优化数据库的性能。通过检查和回收权限,可以及时清理无效或不再需要的权限,减少数据库的负担,提高数据库的性能。

二、oracle dba权限回收的风险也很大,需要谨慎操作

在Oracle数据库生产环境中,DBA回收赋权回收可能面临以下风险和挑战:

  1. 误操作风险:回收赋权操作可能由于误操作导致错误的权限回收,从而影响到正常的数据库操作。例如,回收了某个用户的必要权限,导致该用户无法执行其工作任务。

  2. 数据丢失风险:回收赋权操作可能会导致数据丢失的风险。如果不正确地回收了某个用户的权限,可能会导致该用户无法访问或操作其需要的数据,从而导致数据丢失或不一致。

  3. 安全漏洞风险:回收赋权操作可能会导致安全漏洞的风险。如果没有正确地回收某个用户的权限,可能会导致该用户仍然可以访问或操作敏感数据,从而造成安全漏洞。

  4. 复杂性挑战:回收赋权操作可能会面临复杂性的挑战。在大型数据库环境中,存在大量的用户和角色,进行权限回收需要仔细考虑每个用户的权限需求,以避免误操作或遗漏。

  5. 影响业务连续性:回收赋权操作可能会影响到业务的连续性。如果回收了某个用户的关键权限,可能会导致该用户无法继续执行其业务操作,从而影响到业务的正常进行。

因此,在进行DBA回收赋权回收时,需要谨慎操作,结合下面章节的检查命令,充分了解每个用户的权限需求,并进行充分的测试和验证,以减少风险和挑战。

三、oracle dba权限检查和回收相关命令汇总

说明:其中PRDUSER为具有dba权限的普通生产用户,使用revoke dba之后需要结合检查命令检查出来的普通权限,利用补充权限相关命令给PRDUSER授权除dba权限外的其他需要的业务操作相关的普通权限,才能做到回收dba权限而不影响原来正常的ddl和dml操作

序号

类型

场景

检查语句

补充权限

0

回收之前检查

select grantee,privilege from dba_sys_privs where grantee in ('PRDUSER');

select grantee,granted_role from dba_role_privs where grantee in ('PRDUSER');

1

同义词

主要针对多用户场景

SELECT * FROM DBA_SYNONYMS WHERE OWNER IN ('PRDUSER');

grant create any synonym to PRDUSER;
GRANT DROP ANY SYNONYM TO PRDUSER;

2

物化视图

主要针对多用户场景

select owner, mview_name from dba_mviews where owner in ('PRDUSER')

grant ALTER ANY MATERIALIZED VIEW to PRDUSER;
grant CREATE ANY MATERIALIZED VIEW to PRDUSER;
grant DROP ANY MATERIALIZED VIEW to PRDUSER;

3

序列化

主要针对多用户场景

select sequence_owner, sequence_name from dba_sequences where sequence_owner in ('PRDUSER')

grant select any sequence to PRDUSER;

可能会在插入另一个用户表的时候,其某一个字段是使用sequence方式自增的,如果没有sequence查询权限,可能拿不到自增值

4

跨库表的互访增删改查

主要针对多用胡场景

如果有多用户,相互之间有增删改查的操作的话

grant SELECT ANY TABLE to PRDUSER;
grant INSERT ANY TABLE to PRDUSER;
grant UPDATE ANY TABLE to PRDUSER;
grant DELETE ANY TABLE to PRDUSER;
grant LOCK ANY TABLE to PRDUSER;
grant UNDER ANY TABLE to PRDUSER;
grant COMMENT ANY TABLE to PRDUSER;

如果有跨用户表truncate的话,1. 是 授权drop any table,但是这个风险太大了, 2. 是创建一个存储过程,授权存储过程的执行权限,执行 truncate操作。

5

存储过程debug

grant debug connect session to PRDUSER;

这个理论上不应该给吧,产品环境未来不允许debug操作。

6

系统字典视图无法访问

grant select any dictionary to PRDUSER

7

删除会话的权限

创建一个删除会话的存储过程,授予执行权限

create or replace procedure kill_session ( v_sid number, v_serial number ) as v_varchar2 varchar2(100);

begin execute immediate 'ALTER SYSTEM KILL SESSION ''' || v_sid || ',' || v_serial || '''';

end;

/

grant execute on kill_session to PRDUSER;

8

基础授权

unlimited tablepsace

revoke dba之后,必做的一个动作

grant unlimited tablespace to PRDUSER;

9

其他授权

grant create session to PRDUSER;

grant create any procedure to PRDUSER;

grant execute any procedure to PRDUSER;

grant create table to PRDUSER;

grant drop any table to PRDUSER;

GRANT CREATE VIEW TO PRDUSER;

grant create any type to PRDUSER;

grant create trigger to PRDUSER;

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/133296.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

目标检测YOLO系列从入门到精通技术详解100篇-【目标检测】机器视觉

目录 前言 几个高频面试题目 像素和像元如何选择?

RK356X Android13.0 HDMI和喇叭同时出声音

补丁适用范围:RK356X Android13.0 Android默认音频输出逻辑,不接HDMI默认喇叭音频输出,若检测到HDMI接入后,关闭喇叭输出,开启HDMI音频输出,但是BOX产品的使用场景需要插入HDMI后,喇叭仍然输出,可加入此补丁 $ vim frameworks/base/services/core/java/com/android/s…

Django初窥门径-自定义用户模型

前言 自定义用户模型在Django应用中是一个重要的话题,它涉及到如何根据您的项目需求以及特定的用户身份验证和授权需求来调整用户模型。在以下前言中,我将讲述为什么自定义用户模型是如此重要以及其潜在的优势: 随着Web应用的不断发展&…

科智牧RFID|生猪养殖信息化管理RFID方案提供

以RFID技术为手段,以网络技术和数据库技术为支撑,构建生猪的养殖信息化管理方案,为养殖企业建立完善的生猪档案系统,实现养殖企业信息化管理,做到生猪养殖环节从饲料、养殖、防疫、治疗的信息记录与管理,也…

[计算机网络]认识“协议”

认识“协议” 文章目录 认识“协议”序列化和反序列化网络计算器引入Sock类设计协议编写服务端类启动服务端编写客户端类启动客户端程序测试 序列化和反序列化 在网络体系结构中,应用层的应用程序会产生数据,这个数据往往不是简单的一段字符串数据&…

社科赛斯预测考研趋势,竞争白热化后,稳上岸还是冲名校?

对于考研党来说,择校应该是备考过程中最纠结的一件事情了。这几年来影响院校选择的情况愈加复杂多变,单一志愿的限制下,如何预测报名走向,如何选择院校才能够成功上岸,不像是一个人的战斗,更像是一场几百万…

利用h5py加速数据集读取

直接使用: def store_in_h5(images, output_filename):with h5py.File(output_filename, w) as hf:data_group hf.create_group(data)label_group hf.create_group(label)for i, (data_patches, label_patches) in enumerate(images):for j, (data, label) in en…

按键精灵中的函数使用

1. 命令名称:Function 函数 ; 2. 命令功能:定义一个函数 ; 3. 语法格式: Function 函数名([自定义参数1, 自定义参数2, ...]) 执行语句 [函数名返回值]End Function 4. 参数说明: 函…

什么是4A架构

4A架构通常在软件工程或系统架构领域中提到,特别是与企业级应用和系统设计相关。但是,“4A”这个术语可能有不同的解释,具体取决于上下文。以下是几种可能的含义: 身份认证(Authentication)、授权&#xff…

飞书开发学习笔记(二)-云文档简单开发练习

飞书开发学习笔记(二)-云文档简单开发练习 一.云文档飞书开发环境API 首先还是进入开放平台 飞书开放平台:https://open.feishu.cn/app?langzh-CN 云文档相关API都在“云文档”目录中,之下又有"云空间",“文档”,“电子表格”&a…

CSS的概念和基本用法

CSS的作用: 页面美化和布局控制。 1.概念: Cascading Style Sheets 层叠样式表。 层叠:多个样式可以作用在同一个html的元素上,同时生效。 2.好处: (1).功能强大 (2).将内容展示和样式控制分离 * 降低耦合度&#xf…

Java选择与循环

1.选择 前言:什么是选择呢?在我们的人生中处处面临着选择,比如说在学校你可以选择玩,摆烂,当然也可以选择努力写代码,刷题。什么样的选择就会面临什么样的结果。 其实程序和人生一样:顺序中夹杂…

简单代理模式

代理模式 代理模式(Proxy),为其他对象提供一种代理以控制对这个对象的访问。 结构图如下: ISubject接口,定义了RealSubject和Proxy的共用接口方法,这样就可以在任何使用RealSubject的地方使用Proxy代理。 ISubject接口 public…

sed续与awk(粗糙版)

s:sed d 替换功能,改 s:替换字符串 格式是:sed -n s/需要替换的原内容/替换后的内容/(ps:数字是替换每行中的第几个,g代表是全内容替换)p 替换的文件地址 例如: c:整行替换 y:字符替换,替换前后的字符串…

【洛谷 P5143】攀爬者 题解(结构体排序)

攀爬者 题目背景 HKE 考完 GDOI 之后跟他的神犇小伙伴们一起去爬山。 题目描述 他在地形图上标记了 N N N 个点,每个点 P i P_i Pi​ 都有一个坐标 ( x i , y i , z i ) (x_i,y_i,z_i) (xi​,yi​,zi​)。所有点对中,高度值 z z z 不会相等。HKE…

idea使用lombok编译问题

idea编译报错问题如下: java: You arent using a compiler supported by lombok, so lombok will not work and has been disabled.Your processor is: com.sun.proxy.$Proxy26Lombok supports: OpenJDK javac, ECJ解决方案:在idea配置中File->Setti…

挑战100天 AI In LeetCode Day02(1)

挑战100天 AI In LeetCode Day02(1) 一、LeetCode介绍二、LeetCode 热题 HOT 100-32.1 题目2.2 题解 三、面试经典 150 题-33.1 题目3.2 题解 一、LeetCode介绍 LeetCode是一个在线编程网站,提供各种算法和数据结构的题目,面向程序…

IOS自带的OCR识别功能

一、识别身份证 interface IDCardScanViewController () <AVCaptureMetadataOutputObjectsDelegate> property (nonatomic, strong) AVCaptureSession *captureSession; end implementation IDCardScanViewController - (void)viewDidLoad { [super viewDidLoad…

【GitHub】Watch、Star、Fork、Follow 有什么区别?

目录 一、前言二、区别1. Watch2. Star3. Fork4. Follow 一、前言 GitHub 是最受欢迎的代码托管平台之一&#xff0c;拥有大量的开源代码可供学习。 Github 中也有类似 “点赞”、“收藏”、“加关注” 的功能。 下面介绍下&#xff0c;GitHub 中 Watch、Star、Fork、Follow 有…

c语言进阶部分详解(《高质量C-C++编程》经典例题讲解及柔性数组)

上篇文章我介绍了介绍动态内存管理 的相关内容&#xff1a;c语言进阶部分详解&#xff08;详细解析动态内存管理&#xff09;-CSDN博客 各种源码大家可以去我的github主页进行查找&#xff1a;唔姆/比特学习过程2 (gitee.com) 今天便接“上回书所言”&#xff0c;来介绍《高质…