Oracle表空间加密全过程极简实验

news/2024/9/23 19:23:55/

加密前

准备加密HR Schema中的表。

SQL> col table_name for a20
SQL> select table_name, tablespace_name from all_tables where owner='HR';TABLE_NAME           TABLESPACE_NAME               
-------------------- ------------------------------
DEPARTMENTS          USERS                         
EMPLOYEES            USERS                         
JOBS                 USERS                         
JOB_HISTORY          USERS                         
LOCATIONS            USERS                         
REGIONS              USERS                         
COUNTRIES                                          7 rows selected. 

除COUNTRIES表的显示为null外,其余都是USERS表空间。

查文档:

NULL for partitioned, temporary, and index-organized tables

果然,他是IOT表:

SQL> select table_name from dba_tables where owner='HR' and iot_type = 'IOT';TABLE_NAME          
--------------------
COUNTRIES

其表空间也是USERS:

SQL> select tablespace_name from dba_segments where segment_name = 'COUNTRIES';TABLESPACE_NAME               
------------------------------
USERS

USERS表空间还没有加密:

SQL> select tablespace_name, encrypted from user_tablespaces;TABLESPACE_NAME                ENC
------------------------------ ---
SYSTEM                         NO 
SYSAUX                         NO 
UNDOTBS1                       NO 
TEMP                           NO 
USERS                          NO 

表空间对应的数据文件:

SQL> select file_name, bytes from dba_data_files where tablespace_name = 'USERS';FILE_NAME                                                         BYTES
------------------------------------------------------------ ----------
/opt/oracle/oradata/ORCLCDB/ORCLPDB1/users01.dbf             2313420800

没加密时,电话号码可以查到:

$ strings /opt/oracle/oradata/ORCLCDB/ORCLPDB1/users01.dbf |more
}|{z
ORCLCDB
USERS
AAAAAAAA
DEF,
555,
Middle East and Africa,
Asia,
Americas,
Europe
AAAAAAAA
AAAAAAAA
BelgiumArgentina
Nigeria
Malaysia
Denmark
Israel
Kuwait
Mexico
Netherlands
Switzerland
Brazil
Egypt
Zambia
Germany
France
United KingdomSingapore
ZimbabweAustralia
India
China
Canada
United States of America
Japan
Italy
AAAAAAAA
Mariano Escobedo 9991
11932
Mexico City
Distrito Federal,
Pieter Breughelstraat 837
3029SK
...$ strings /opt/oracle/oradata/ORCLCDB/ORCLPDB1/users01.dbf |grep -i 6666
603.123.6666
205-167-6666
243-589-6666
697-394-6666
355-689-6666
489-117-6666
489-117-6666

加密中

秘钥配置

还没配:

SQL> show parameter wallet_rootNAME                                 TYPE        VALUE
------------------------------------ ----------- ------------------------------
wallet_root                          string
SQL> show parameter tde_configurationNAME                                 TYPE        VALUE
------------------------------------ ----------- ------------------------------
tde_configuration                    string

为简化,key store我们选用software keystore,即wallet。复杂生产环境(多数据库配置,ADG环境)还是建议用Key Vault。

具体配的过程参见Oracle 透明数据加密(TDE)的常见任务中的配置Key Store创建Key Store部分。

加密表空间

也可以参见Oracle 透明数据加密(TDE)的常见任务中的加解密PDB中的表空间部分。

在线加密:

SQL> alter tablespace users encryption online encrypt;Tablespace altered.Elapsed: 00:00:40.91

在线解密:

SQL> alter tablespace users encryption online decrypt;Tablespace altered.Elapsed: 00:00:18.61

离线加密:

ALTER TABLESPACE users OFFLINE NORMAL;
SQL> alter tablespace users encryption offline encrypt;Tablespace altered.Elapsed: 00:00:09.46

离线解密:

SQL> alter tablespace users encryption offline decrypt;Tablespace altered.Elapsed: 00:00:05.77

再离线加密一次,然后表空间在线:

SQL> alter tablespace users encryption offline encrypt;Tablespace altered.Elapsed: 00:00:08.94ALTER TABLESPACE users ONLINE;

加密后

加密完成了,查看状态:

SQL> select TS#, ENCRYPTIONALG, ENCRYPTEDTS, STATUS, CON_ID from V$ENCRYPTED_TABLESPACES;TS# ENCRYPT ENC STATUS         CON_ID
---------- ------- --- ---------- ----------5 AES128  YES NORMAL              3SQL> select name from v$tablespace where ts# = 5;NAME
------------------------------
USERSSQL> show con_idCON_ID
------------------------------
3SQL> select ENCRYPTED from user_tablespaces where TABLESPACE_NAME = 'USERS';ENC
---
YES

数据文件的大小不变:

SQL> select file_name, bytes from dba_data_files where tablespace_name = 'USERS';FILE_NAME                                                         BYTES
------------------------------------------------------------ ----------
/opt/oracle/oradata/ORCLCDB/ORCLPDB1/users01.dbf             2313420800

验证

电话号码看不到了:

$ strings /opt/oracle/oradata/ORCLCDB/ORCLPDB1/users01.dbf |grep -i 6666
$ echo $?
1$ strings /opt/oracle/oradata/ORCLCDB/ORCLPDB1/users01.dbf |more
}|{z
ORCLCDB
USERS
?4fc
u]DRZ
>o"%
/ g~198
afkY}
@)5;
=M}'
,k2<R
Jjt
>+|}/
XE[{
6Kh!
{+4?
4d&6o9
p0kM
Tody
N{ _M
^l_'
P,Dsc
A?L&
J`"W
$<ej
6.`'
BB2X
NuX`j
\7rR
JkPI
P0=h4
ym#}d
.Ov];}B
...

http://www.ppmy.cn/news/1463899.html

相关文章

RabbitMQ02-RebbitMQ简介及交换器

一. AMQP协议 什么是AMQP协议 AMQP(Advanced Message Queuing Protocol,高级消息队列协议):它是进程之间传递异步消息的网络协议 AMQP工作过程 发布者通过发布消息&#xff0c;通过交换机&#xff0c;交换机根据路由规则将收到的消息分发交换机绑定的下消息队列&#xff0c;最…

【Spring Boot】深度复盘在开发搜索引擎项目中重难点的整理,以及遇到的困难和总结

&#x1f493; 博客主页&#xff1a;从零开始的-CodeNinja之路 ⏩ 收录文章&#xff1a;【Spring Boot】深度复盘在开发搜索引擎项目中重难点的整理&#xff0c;以及遇到的困难和总结 &#x1f389;欢迎大家点赞&#x1f44d;评论&#x1f4dd;收藏⭐文章 目录 什么是搜索引…

爬虫案例-亚马逊反爬流程分析梳理(验证码突破)(x-amz-captcha)

总体概览&#xff1a;核心主要是需要突破该网站的验证码&#xff0c;成功后会返回我们需要的参数后再去请求一个中间页&#xff08;类似在后台注册一个session&#xff09;&#xff0c;最后需要注意一下 IP 是不能随意切换的 主要难点&#xff1a; 1、梳理整体反爬流程 2、验证…

第53期|GPTSecurity周报

GPTSecurity是一个涵盖了前沿学术研究和实践经验分享的社区&#xff0c;集成了生成预训练Transformer&#xff08;GPT&#xff09;、人工智能生成内容&#xff08;AIGC&#xff09;以及大语言模型&#xff08;LLM&#xff09;等安全领域应用的知识。在这里&#xff0c;您可以找…

oracle.jdbc.OracleDatabaseException: ORA-00911: 无效字符

先吐槽一句&#xff0c;oracle 真坑啊&#xff01; 一个很正常的sql 语句一直报 ORA-00911: 无效字符 &#xff0c;拿到数据库去执行一点问题没有&#xff0c;一运行代码就报错&#xff0c;然后一个字符一个字符的对比&#xff0c;竟然是因为sql 结尾的一个 ";" 导致…

rk3568_mutex

文章目录 前言1、什么是mutex?1.1mutex互斥体API函数二、实验2.1实验目的2.2源码2.3结果图前言 本文记录的是rk3568开发板基础上做的mutex实验 1、什么是mutex? mutex是互斥体,它是比信号量semaphore更加专业的机制。 在我们编写Linux驱动的时候遇到需要互斥的地方建议使用…

在VS Code中进行Java的单元测试

在VS Code中可以使用 Test Runner for Java扩展进行Java的测试执行和调试。 Test Runner for Java的功能 Test Runner for Java 结合 Language Support for Java by Red Hat 和 Debugger for Java这两个插件提供如下功能&#xff1a; 运行测试&#xff1a; Test Runner for …

微信小程序自定义头部

1.在对应界面的json文件&#xff0c;将navigationStyle属性设置为“custom” "navigationStyle":"custom" 2. 状态栏的高度可以通过 wx.getSystemInfo() 获取。 胶囊按钮的信息可以通过 wx.getMenuButtonBoundingClientRect() 获取。 导航栏高度状态栏…