42-Oracle 23 ai 安全新特性(Audit统一审计)

小伙伴们业务和安全运维中需要数据库审计都是由哪些模块来实现的,专门的第三方产品吗?在医疗领域防统方等业务场景和数据库的审计集合很是紧密。

在Oracle逐个版本的演进中,Oracle 23ai 的审计特性在安全领域的重大革新,延续传统审计仅支持可用,新的完全使用统一审计功能,维度更多,策略灵活。

一、Oracle审计技术架构演进

  1. 标准审计(9i-19c)​
  • 原理​:基于语句、权限、对象三层监控:
    • 语句审计​:跟踪特定SQL类型(如AUDIT TABLE监控所有DDL)
    • 权限审计​:记录系统权限使用(如AUDIT DELETE ANY TABLE)
    • 对象审计​:针对特定对象操作(如AUDIT INSERT ON hr.employees)
  • 存储​:记录存于SYS.AUD$表或操作系统文件(由AUDIT_TRAIL=DB/OS控制)
    • 审计记录可存于数据库表​(如SYS.AUD$或12c+的UNIFIED_AUDIT_TRAIL)或操作系统文件​(路径由AUDIT_FILE_DEST参数指定)
    • 支持扩展记录(AUDIT_TRAIL=DB_EXTENDED可捕获完整的SQL文本及绑定变量)
  1. 细粒度审计(FGA,9i+)​
  • 行级监控​:通过DBMS_FGA.ADD_POLICY定义基于内容的审计策略(如监控salary > 10000的查询)
  • 局限​:仅支持SELECT语句,DML操作无法覆盖
  1. 统一审计(12c+)​
  • 架构革新​:合并标准审计与FGA,策略统一管理,通过策略化配置(如CREATE AUDIT POLICY)实现集中管理,显著提升效率:
CREATE AUDIT POLICY policy_name ACTIONS SELECT ON hr.employees;--Audit policy created.
  • 性能优化​:审计日志集中存储在UNIFIED_AUDIT_TRAIL视图,查询效率提升
  • Oracle强烈建议12.2及以上版本用户立即迁移至统一审计。

、技术特点

1. 精准可控
  • 可限定审计范围:按用户(BY user)、操作结果(WHENEVER SUCCESSFUL/NOT SUCCESSFUL)或频率(BY ACCESS/SESSION)精细化控制
  • ​特权操作强制审计​:启用AUDIT_SYS_OPERATIONS=TRUE后,所有SYS及SYSDBA操作必被记录(存于OS文件,防篡改)
​2. ​低侵入高兼容
  • 审计策略独立于应用逻辑,无论用户通过程序或工具(如SQL*Plus)访问,行为均被捕获
  • 符合C2级安全标准及GDPR、PCI DSS等法规要求,直接支撑合规审计
3. ​性能可调优
  • 支持审计表分区、定期清理日志,避免存储膨胀
  • 敏感操作聚焦(如列级或FGA策略)减少冗余日志,平衡安全与性能

三、23ai全新审计架构

1. 传统审计彻底弃用
  • 删除默认传统审计配置
  • 以下参数被废弃(设置时触发ORA-32004/ORA-32006警告):
  • AUDIT_TRAIL, AUDIT_SYS_OPERATIONS, AUDIT_FILE_DEST, AUDIT_SYSLOG_LEVEL
2. 强制统一审计模式
  • 取消uniaud_on/uniaud_off选项,统一审计始终启用
  • 预定义策略默认激活​:
    • - ORA_SECURECONFIG(安全配置变更)
    • - ORA_LOGIN_LOGOUT(登录登出)
    • - ORA_DV_SCHEMA_CHANGES(字典敏感列访问)
    • - ORA_DV_DEFAULT_PROTECTION(数据库保险箱变更)
    • - ORA$DICTIONARY_SENS_COL_ACCESS(字典敏感列访问)

四、Oracle 23ai核心新特性

1. ​列级精准审计
  • 原理​:仅监控指定敏感列的操作(如salary更新)
-- 创建策略审计sal、ename列的SELECT操作
CREATE AUDIT POLICY employee_pii_access ACTIONS SELECT(sal, ename) ON scott.emp;
-- 追加审计sal列的UPDATE操作
ALTER AUDIT POLICY employee_pii_access ADD ACTIONS UPDATE(sal) ON scott.emp;
-- 审计empid列的INDEX操作
CREATE AUDIT POLICY employee_pii_access1 ACTIONS INDEX(empid) ON scott.emp;
--以上为示例
CREATE AUDIT POLICY emp_salary_policyACTIONS UPDATE(salary), SELECT(salary) ON hr.employees;
--Audit policy created.-- 仅审计薪资字段
AUDIT POLICY emp_salary_policy;
--Audit succeeded.-- 1. 创建测试表(SYSDBA)
CREATE TABLE employees (id      NUMBER PRIMARY KEY,name    VARCHAR2(50),salary  NUMBER
);
INSERT INTO employees VALUES (1, 'Alice', 10000);-- 2. 创建审计策略(SYSDBA)
CREATE AUDIT POLICY audit_salary ACTIONS SELECT(salary) ON employees;  -- 仅监控 salary 查询
AUDIT POLICY audit_salary;-- 3. 模拟用户查询
SELECT salary FROM employees WHERE id=1;  -- 被审计
SELECT name FROM employees WHERE id=1;    -- 不被审计-- 4. 查看审计记录
SELECT event_timestamp, dbusername, sql_text 
FROM unified_audit_trail 
WHERE object_name='EMPLOYEES';
2. ​区块链表集成
  • 原理​:
    • 通过CREATE BLOCKCHAIN TABLE创建防篡改表,每行生成SHA-256哈希链
  • 场景​:金融交易日志、医疗存证等司法取证场景
CREATE BLOCKCHAIN TABLE audit_logs (log_id      NUMBER GENERATED ALWAYS AS IDENTITY,action      VARCHAR2(50),user_name   VARCHAR2(30)
)
NO DROP UNTIL 30 DAYS IDLE
NO DELETE UNTIL 16 DAYS AFTER INSERT  -- 添加此行,保留期最少16天
HASHING USING "SHA2_512" VERSION "v1";  -- 指定哈希算法可以有不同的版本(必填)
--Table created.
INSERT INTO audit_logs (action, user_name) VALUES ('SALARY_UPDATE', 'ADMIN');
COMMIT;
--
INSERT INTO audit_logs (action, user_name) VALUES ('SALARY_UPDATE', 'ADMIN');
1 row created.
SYS@FREE> COMMIT;
Commit complete.

五、统一审计策略检查 

SELECT POLICY_NAME, AUDIT_CONDITION, OBJECT_NAME 
FROM audit_unified_policies 
WHERE OBJECT_TYPE = 'Table'; -- 检查已启用的表级策略

、传统审计的兼容性与过渡

  • 升级兼容性​23ai保留现有传统审计配置,继续生成审计记录,但禁止新增或修改传统审计设置(仅允许删除)。
  • 迁移强制要求
    • 禁用所有传统审计设置:执行 NOAUDIT 命令
    • 关闭传统审计参数:
AUDIT_TRAIL = None
AUDIT_SYS_OPERATIONS = False

 FGA策略处理​细粒度审计(FGA)策略自动迁移,审计记录将输出至统一审计线索。

、迁移操作指南

  1. 基础场景
  • 启用核心预定义策略:ORA_SECURECONFIG + ORA_LOGIN_LOGOUT
  • 关闭传统审计参数
迁移价值​:通过统一审计实现精细化管控(如列级操作追踪),同时降低传统审计的维护成本。预定义策略的强制启用大幅提升基础安全水位。

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

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

相关文章

Python 爬虫入门 Day 4 - 模拟登录爬虫与 Session 维持

Python 第二阶段 - 爬虫入门 🎯 今日目标 学习什么是 Cookie / Session,为什么要维持登录状态掌握 requests.Session 用法模拟登录一个带登录表单的网站获取登录后的页面内容 📘 学习内容详解 🔐 什么是 Session? …

新零售系统商城开发全解析

一、新零售系统商城概述​ (一)新零售的概念​ 新零售依托互联网与物联网技术,以数据驱动为核心,打破线上线下的界限,构建起一体化的全新零售模式。它不再局限于传统的销售渠道,而是通过整合线上电商平台、线下实体店铺以及现代物流配送等多方面资源,实现商品、服务、…

c++基础入门——c++初识

我看的是B站黑马程序员的课《C教程》。准备用这个专栏记录一下学习笔记。 这套c课程的课程安排如下: 阶段内容目标案例第一阶段C基础语法入门对c有初步了解,能够有基础编程能力通讯录管理系统第二阶段c核心编程介绍c面向对象编程,为大型项目…

【css】设置了margin-top为负数,div被img覆盖的解决方法

文章目录 场景默认情况下&#xff0c;层叠顺序是如何工作的&#xff1f;为什么 img 会覆盖 div&#xff1f;解决方法 场景 <img src"image.jpg"> <div>Content</div>有代码如上&#xff0c;img src是一个https网络图片链接。 若div的margin-top为…

4 Studying《ARM System Developer’s Guide》1-7

目录 Preface Chapter1 ARM Embedded Systems 1.1 The RISC design philosophy 1.2 The ARM Design Philosophy 1.3 Embedded System Hardware 1.4 Embedded System Software 1.5 Summary Chapter2 ARM Processor Fundamentals 2.1 Registers 2.2 Current Program St…

Vue3 + Axios + Ant Design Vue 请求封装详解教程(含 Token 鉴权、加密、下载)

Vue3 Axios Ant Design Vue 请求封装详解教程&#xff08;含 Token 鉴权、加密、下载&#xff09; 一、完整源码&#xff08;请先阅读&#xff09; import { message, Modal } from ant-design-vue; import axios from axios; import { localRead } from //utils/local-util…

SQL注入安全研究

​据OWASP 2023报告显示&#xff0c;SQL注入连续15年位居Web安全威胁榜首&#xff0c;在应用漏洞中占比34.1%​​ ​NIST统计显示&#xff1a;2022-2023年高危SQL注入漏洞同比增长27%&#xff0c;企业平均修复成本达$320,000​ 一、漏洞本质与技术原理解析 1. SQL注入核心机理…

Ubuntu最新版本(Ubuntu22.04LTS)安装nfs服务器

NFS&#xff08;Network File System&#xff09;是一种允许不同计算机之间共享文件的网络文件系统。 在Ubuntu 22.04 LTS中&#xff0c;您可以使用以下步骤安装并配置NFS服务器。 一、安装NFS服务器 在Ubuntu 22.04 LTS中&#xff0c;您可以使用以下命令安装NFS服务器&…

学习笔记丨数字信号处理(DSP)的应用——图像处理篇

&#x1f4cc; DSP在图像处理中的应用&#xff1a;核心技术解析 数字信号处理&#xff08;DSP&#xff09;是图像处理的核心技术之一&#xff0c;广泛应用于增强、压缩、分析和识别等领域。以下是DSP在图像处理中的关键应用及技术细节&#xff1a; 目录 &#x1f50d; 图像增…

Kafka Broker处理消费者请求源码深度解析:从请求接收到数据返回

在Kafka生态体系中&#xff0c;消费者从Broker拉取消息是实现数据消费的关键环节。Broker如何高效处理消费者请求&#xff0c;精准定位并返回对应分区数据&#xff0c;直接决定了整个消息系统的性能与稳定性。接下来&#xff0c;我们将聚焦Kafka Broker端&#xff0c;深入剖析其…

Objective-C与Swift混合编程

Objective-C与Swift混合编程的基本概念 Objective-C与Swift混合编程是指在同一项目中同时使用两种语言进行开发。这种混合编程方式在迁移旧项目或利用Swift新特性时非常有用。两种语言可以相互调用&#xff0c;但需要遵循特定的规则和桥接机制。 设置混合编程环境 在Xcode项…

IDE深度集成+实时反馈:企业级软件测试方案Parasoft如何重塑汽车巨头的测试流程

在汽车行业数字化转型的浪潮中&#xff0c;全球第四大汽车集团Stellantis曾面临严峻的测试效率挑战&#xff1a;开发与测试流程脱节、团队对“测试左移”策略的抵触、TDD&#xff08;测试驱动开发&#xff09;推进困难……这些痛点直接导致质量保障滞后&#xff0c;拖慢产品交付…

【Linux】Linux异步I/O -libaio

一、libaio 原理概述 1.1 libaio 介绍 libaio&#xff08;Linux Asynchronous I/O&#xff09;是 Linux 内核提供的异步 I/O 库&#xff0c;其核心原理是&#xff1a; 异步提交&#xff1a;应用程序通过 io_submit 提交 I/O 请求后立即返回&#xff0c;不阻塞进程事件通知&a…

git submodule 和git repo介绍

这是一个 Git 子模块&#xff08;submodule&#xff09;管理问题。当一个 Git 仓库&#xff08;主仓库&#xff09;中包含多个其他 Git 仓库&#xff08;子仓库&#xff09;时&#xff0c;最推荐的做法是使用 Git 子模块 或 Git 子树&#xff08;subtree&#xff09; 进行管理。…

识别网络延迟与带宽瓶颈

识别网络延迟与带宽瓶颈 在分布式系统与微服务架构日益普及的背景下,网络性能成为影响系统响应速度与服务可用性的重要因素。网络延迟和带宽瓶颈是两类最常见的网络性能障碍。准确识别这两类瓶颈,有助于系统架构师从根源优化服务质量,保障系统在高并发、高流量场景下依然具…

Linux内网穿透(frp)

目标&#xff1a;让我的VMware虚拟机某个服务拥有自己的外网访问地址 FRP 服务端&#xff08;公网服务器&#xff09;配置 1. 下载 FRP 登录公网服务器&#xff0c;执行以下命令下载并解压 FRP&#xff1a; # 下载对应版本&#xff08;以Linux 64位为例&#xff09; wget h…

《Vuejs设计与实现》第 9 章(简单 diff 算法)

目录 9.1 减少 DOM 操作的性能开销 9.2 DOM 复用与 key 的作用 9.3 找到需要移动的元素 9.4 如何移动元素 9.5 添加新元素 9.6 移除不存在的元素 9.7 总结 当新旧 vnode 的子节点都是一组节点时&#xff0c;为了以最小的性能开销完成更新操作&#xff0c;需要比较两组子…

队列,环形缓冲区实现与应用:适用于GD32串口编程或嵌入式底层驱动开发

环形缓冲区实现与应用&#xff1a;从基础到实践 在嵌入式系统和实时数据处理场景中&#xff0c;环形缓冲区&#xff08;Circular Buffer&#xff09;是一种非常常用的的数据结构&#xff0c;它能有效地管理数据的读写操作&#xff0c;尤其适用于数据流的临时存储与转发。 今天…

WHAT - Expo Go 和 development build

文章目录 1. 什么是 Expo Go?简介作用限制2. 什么是 Development Build(开发构建)?简介功能创建方式3. 它们有什么区别?总结建议怎么从 Expo Go 迁移到开发构建一、什么是“迁移”?二、迁移步骤总览三、详细操作步骤1. 安装 expo-dev-client2. 配置 eas.json(Expo 应用服…

Keepalived 配置 VIP 的核心步骤

Keepalived 配置 VIP 的核心步骤主要涉及安装软件、主备节点配置及服务管理。以下是具体操作指南: 一、安装 Keepalived ‌Ubuntu/Debian 系统‌ sudo apt update sudo apt install keepalived ‌CentOS/RHEL 系统‌ sudo yum install keepalived 注:需确保已配置 EPE…