Database Vault(DBV)和領域管理
DB:11.2.0.4
在安裝時,選擇安裝元件Database Vault(在選擇企業版、標準版的介面)
建立完資料庫後,使用DBCA->資料庫配置,新增Database Vault,會要求建立DBV相關賬號。
提示,要在DBCA正式開始新增DBV前(進度條介面還沒出來前),重啟資料庫(會有彈出視窗作如此提示)。要啟動到open狀態。
完成後,可以登入https://hostname:port/dva進入Web管理頁面(記住,裡面登入要輸入資料庫主機地址和監聽器埠號)。
DBV將建立3個賬戶實現職責分離:
安全管理員:DBV物件所有者,DV_OWNER,DV_ADMIN
賬戶管理員:負責管理賬戶命令,DV_ACCTMGR。sys使用者不再能建立使用者。
執行管理員:負責授權,並保護安全相關的引數修改。sys使用者將是唯一在該領域的使用者。
領域管理
建立領域
使用角色為DV_OWNER的使用者,
新增領域的保護物件
領域帶來的許可權變化
1. 如果有角色對領域所保護的物件有許可權,那麼因為DBA有GRANT許可權,因此DBA可以把自己GRANT該角色並使用SET ROLE切換到該角色來繞開領域的保護。
應對該問題的方法是:將該角色一道加入領域的保護
2. 領域針對的是對系統ANY許可權。意味著光有領域授權,沒有ANY許可權是無用的;同樣如果是對物件object的許可權,領域與此無關。
3. 領域管理員自身不能被賦予領域許可權,也無法直接訪問資料庫物件。
4. 在有物件被領域保護後,物件所有者仍然可以對該物件執行SELECT, DML, EXECUTE操作,但DDL,GRANT操作被禁止。
5. 授予使用者賬戶管理領域物件的許可權:
管理領域的角色有兩種:領域管理員和領域參與者。前者可以:
1)授予、撤銷領域保護物件的許可權
2)授予、撤銷領域保護的角色
a. 使用角色為DV_ACCTMGR得賬戶建立角色
b. 使用sys賬戶賦予應用程式管理員ANY許可權
c. 賦予領域許可權
d. 然後使用BATMAN, ROBIN賬戶登入對領域內物件執行管理任務。
如執行DDL語句,GRANT/REVOKE語句, 角色管理等。
使用安全應用程式角色(SAR)管理領域內的物件
與上例的領域擁有者/參與者針對系統許可權不同,SAR主要是針對物件許可權
摘抄原書:
在安裝時,選擇安裝元件Database Vault(在選擇企業版、標準版的介面)
建立完資料庫後,使用DBCA->資料庫配置,新增Database Vault,會要求建立DBV相關賬號。
提示,要在DBCA正式開始新增DBV前(進度條介面還沒出來前),重啟資料庫(會有彈出視窗作如此提示)。要啟動到open狀態。
完成後,可以登入https://hostname:port/dva進入Web管理頁面(記住,裡面登入要輸入資料庫主機地址和監聽器埠號)。
DBV將建立3個賬戶實現職責分離:
安全管理員:DBV物件所有者,DV_OWNER,DV_ADMIN
賬戶管理員:負責管理賬戶命令,DV_ACCTMGR。sys使用者不再能建立使用者。
執行管理員:負責授權,並保護安全相關的引數修改。sys使用者將是唯一在該領域的使用者。
領域管理
建立領域
使用角色為DV_OWNER的使用者,
點選(此處)摺疊或開啟
-
BEGIN
-
dbms_macadm.create_realm(
-
realm_name => 'Cust_Card_realm'
-
, description => 'Protect customer and card details information'
-
, enabled => dbms_macutl.g_yes
-
, audit_options => dbms_macutl.g_realm_audit_fail
-
);
-
END;
- /
點選(此處)摺疊或開啟
-
BEGIN
-
dbms_macadm.add_object_to_realm (
-
realm_name => 'Cust_Card_realm'
-
,object_owner => 'HK'
-
,object_name => '%'
-
,object_type => '%'
-
);
-
END;
-
/
-
-
BEGIN
-
dbms_macadm.add_object_to_realm (
-
realm_name => 'Cust_Card_realm'
-
,object_owner => 'SOE'
-
,object_name => 'ORDERS'
-
,object_type => 'TABLE'
-
);
-
END;
- /
領域帶來的許可權變化
1. 如果有角色對領域所保護的物件有許可權,那麼因為DBA有GRANT許可權,因此DBA可以把自己GRANT該角色並使用SET ROLE切換到該角色來繞開領域的保護。
應對該問題的方法是:將該角色一道加入領域的保護
點選(此處)摺疊或開啟
-
BEGIN
-
dbms_macadm.add_object_to_realm (
-
realm_name => 'Cust_Card_realm'
-
,object_owner => 'SOE'
-
,object_name => 'SELECT_SOE_ROLE'
-
,object_type => 'ROLE'
-
);
-
END;
- /
3. 領域管理員自身不能被賦予領域許可權,也無法直接訪問資料庫物件。
4. 在有物件被領域保護後,物件所有者仍然可以對該物件執行SELECT, DML, EXECUTE操作,但DDL,GRANT操作被禁止。
5. 授予使用者賬戶管理領域物件的許可權:
管理領域的角色有兩種:領域管理員和領域參與者。前者可以:
1)授予、撤銷領域保護物件的許可權
2)授予、撤銷領域保護的角色
a. 使用角色為DV_ACCTMGR得賬戶建立角色
點選(此處)摺疊或開啟
-
SQL> show user
-
USER is "DBVACCMGR"
-
SQL>
-
SQL> create user batman identified by batman;
-
-
User created.
-
-
SQL> create user robin identified by robin;
-
- User created.
點選(此處)摺疊或開啟
-
SQL> connect / as sysdba
-
Connected.
-
SQL> grant dba to batman;
-
-
Grant succeeded.
-
-
SQL> grant dba to robin;
-
- Grant succeeded.
點選(此處)摺疊或開啟
-
--領域管理員
-
BEGIN
-
dbms_macadm.add_auth_to_realm (
-
realm_name => 'Customer_Card_realm'
-
, grantee => 'BATMAN'
-
, rule_set_name => NULL
-
, auth_options => dbms_macutl.g_realm_auth_owner );
-
END;
-
/
-
--領域參與者
-
BEGIN
-
dbms_macadm.add_auth_to_realm (
-
realm_name => 'Customer_Card_realm'
-
, grantee => 'ROBIN'
-
, rule_set_name => NULL
-
, auth_options => dbms_macutl.g_realm_auth_participant );
-
END;
- /
d. 然後使用BATMAN, ROBIN賬戶登入對領域內物件執行管理任務。
如執行DDL語句,GRANT/REVOKE語句, 角色管理等。
使用安全應用程式角色(SAR)管理領域內的物件
與上例的領域擁有者/參與者針對系統許可權不同,SAR主要是針對物件許可權
摘抄原書:
點選(此處)摺疊或開啟
-
dbvowner@aos> -- create the DBV Secure Application Role
dbvowner@aos> BEGIN
dbms_macadm.create_role(
role_name => 'SALES_ARCHIVE_ROLE'
, enabled => 'Y'
, rule_set_name => 'Is System Maintenance Allowed'
);
END;
/
PL/SQL procedure successfully completed.
dbvowner@aos> -- protect the role in the Sales History realm
dbvowner@aos> BEGIN
dbms_macadm.add_object_to_realm (
realm_name => 'Sales History'
,object_owner => 'SH'
,object_name => 'SALES_ARCHIVE_ROLE'
-
,object_type => 'ROLE'
);
END;
/
PL/SQL procedure successfully completed.
- --檢視當前SAR角色
-
sys@aos>SELECT *
FROM dba_application_roles
WHERE role = 'SALES_ARCHIVE_ROLE';
ROLE SCHEMA PACKAGE
------------------- --------- ------------------
SALES_ARCHIVE_ROLE DVSYS DBMS_MACSEC_ROLES
1 row selected.
- --使用領域所有者賬戶為SAR授予物件許可權
-
mary@aos> -- grant the require object privileges
mary@aos> -- to the DBV Secure Application Role
mary@aos> GRANT DELETE ON sh.channels TO sales_archive_role;
Grant succeeded.
mary@aos> GRANT DELETE ON sh.costs TO sales_archive_role;
Grant succeeded.
mary@aos> GRANT DELETE ON sh.countries TO sales_archive_role;
Grant succeeded.
mary@aos> GRANT DELETE ON sh.customers TO sales_archive_role;
Grant succeeded.
mary@aos> GRANT DELETE ON sh.products TO sales_archive_role;
Grant succeeded.
mary@aos> GRANT DELETE ON sh.promotions TO sales_archive_role;
Grant succeeded.
mary@aos> GRANT DELETE ON sh.sales TO sales_archive_role;
Grant succeeded.
mary@aos> -- grant the DBV Secure Application Role
mary@aos> -- to the account SCOTT
mary@aos> GRANT sales_archive_role TO scott;
Grant succeeded.
- --驗證
-
scott@aos> -- show the date and time of day factors that affect
scott@aos> -- the DBV Rule Set that controls the role enablement
scott@aos>SELECT TO_CHAR(SYSDATE,'DAY') "DAY_OF_WEEK",
TO_CHAR(SYSDATE,'HH24') "HOUR_OF_DAY"
FROM DUAL;
DAY_OF_WEEK HO
------------------------------------ --
MONDAY 10
1 row selected.
scott@aos> -- attempt to use the privileges granted to the
scott@aos> -- role to demonstrate the privileges are not enabled
scott@aos> -- by default as with a normal Oracle role.
scott@aos> -- We will test deleting records greater than 10 years old
scott@aos>DELETE sh.sales WHERE time_id < (SYSDATE-(365*10));
DELETE sh.sales WHERE time_id < (SYSDATE-(365*10))
*
ERROR at line 1:
ORA-01031: insufficient privileges
scott@aos> -- attempt to enable the role outside of the
scott@aos> -- authorized system maintenance timeframe
scott@aos>EXEC dvsys.dbms_macsec_roles.set_role('SALES_ARCHIVE_ROLE');
BEGIN dvsys.dbms_macsec_roles.set_role('SALES_ARCHIVE_ROLE'); END;
*
ERROR at line 1:
ORA-47305: Rule Set violation on SET ROLE (Is System Maintenance Allowed)
ORA-06512: at "DVSYS.DBMS_MACUTL", line 38
ORA-06512: at "DVSYS.DBMS_MACUTL", line 381
ORA-06512: at "DVSYS.DBMS_MACSEC", line 242
ORA-06512: at "DVSYS.ROLE_IS_ENABLED", line 4
ORA-06512: at "DVSYS.DBMS_MACSEC_ROLES", line 24
ORA-06512: at line 1
-
scott@aos> -- show the date and time of day factors that affect
scott@aos> -- the DBV Rule Set that controls the role enablement
scott@aos>SELECT TO_CHAR(SYSDATE,'DAY') "DAY_OF_WEEK",
TO_CHAR(SYSDATE,'HH24') "HOUR_OF_DAY"
FROM DUAL;
DAY_OF_WEEK HO
------------------------------------ --
FRIDAY 17
1 row selected.
scott@aos> -- attempt to enable the role, which will succeed
scott@aos>EXEC dvsys.dbms_macsec_roles.set_Role('SALES_ARCHIVE_ROLE');
PL/SQL procedure successfully completed.
scott@aos> -- attempt to use the privileges granted to the
scott@aos> -- role by deleting records greater than 10 years old
scott@aos>DELETE sh.sales WHERE time_id < (SYSDATE-(365*10));
221651 rows deleted.
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/22621861/viewspace-1393649/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- ORACLE database vaultOracleDatabase
- 關於Oracle Database Vault介紹OracleDatabase
- DBV 的使用
- 使用 Docker 和 Traefik 搭建 VaultDocker
- dbv segment_id
- DBV:冷備份的校驗和恢復
- 《實現領域驅動設計》筆記——領域、子域和限界上下文筆記
- 區塊鏈的應用領域—物聯網和物流領域(二)區塊鏈
- SAP:2019年差旅和費用管理領域的六大看點
- 結合領域事件和微服務的實現領域驅動設計 - Alagarsamy事件微服務
- 位元組面試:領域、子域、核心域、通用域和支撐域怎麼劃分?面試
- DDD-領域物件與領域服務物件
- DDD領域驅動設計:領域事件事件
- 領域驅動模型DDD(三)——使用Saga管理事務模型
- RocketMQ系列2:領域模型和技術概念MQ模型
- 機器人領域期刊和會議(2)機器人
- 自動生成特定領域模型和圖表模型
- 領域驅動設計戰術模式--領域事件模式事件
- 讀書系列-《解構領域驅動》-領域概念
- 戲說領域驅動設計(廿五)——領域事件事件
- 實景三維在園區管理領域的應用
- #L190830 電信領域之管理經濟學初探
- 加拿大如何在社保數字領域內實施產品管理和團隊拓撲?
- 商業分析BA領域的MVP、MMF和MLPMVP
- 幻影成像的實現方式和應用領域
- 產品領域MVP、MMP和MLP概念區別MVP
- 領域事件和整合事件沒那麼高大上事件
- 領域驅動設計戰術模式--領域服務模式
- 戲說領域驅動設計(廿一)——領域服務
- secrets 管理工具 Vault 的介紹、安裝及使用
- 解讀 KubeCon EU 2019 應用管理領域的新看點
- 伺服器領域,Linux和Windows有何區別?伺服器LinuxWindows
- 淺談領域模型模型
- ABP框架領域層框架
- nodejs應用領域NodeJS
- Linux 應用領域Linux
- DDD劃分領域、子域,核心域,支撐域的目的
- 聊一聊中臺和DDD(領域驅動設計)
- 資料領域,甲方和乙方分工的18個原則