Oracle Stream配置詳細步驟
1 引言
Oracle Stream功能是為提高資料庫的高可用性而設計的,在Oracle 9i及之前的版本這個功能被稱為Advance Replication。Oracle Stream利用高階佇列技術,透過解析歸檔日誌,將歸檔日誌解析成DDL及DML語句,從而實現
1 引言
Oracle Stream功能是為提高資料庫的高可用性而設計的,在Oracle 9i及之前的版本這個功能被稱為Advance Replication。Oracle Stream利用高階佇列技術,透過解析歸檔日誌,將歸檔日誌解析成DDL及DML語句,從而實現資料庫之間的同步。這種技術可以將整個資料庫、資料庫中的物件複製到另一資料庫中,透過使用Stream的技術,對歸檔日誌的挖掘,可以在對主系統沒有任何壓力的情況下,實現對資料庫物件級甚至整個資料庫的同步。
解析歸檔日誌這種技術現在應用的比較廣泛,Quest公司的shareplex軟體及DSG公司的realsync都是這樣的產品,一些公司利用這樣的產品做應用級的容災。但shareplex或是realsync都是十分昂貴的,因此你可以嘗試用Stream這個Oracle提供的不用額外花錢的功能。Oracle Stream對生產庫的影響是非常小的,從庫可以是與主庫不同的作業系統平臺,你可以利用Oracle Stream複製幾個從庫,從庫可用於查詢、報表、容災等不同的功能。本文不談技術細節,只是以手把手的方式一步一步的帶你把Stream的環境搭建起來,細節內容可以查聯機文件。
2 概述
主資料庫:
作業系統:Solaris 9
IP地址:192.168.10.35
資料庫:Oracle 10.2.0.2
ORACLE_SID:prod
Global_name:prod
從資料庫:
作業系統:AIX 5.2
IP地址:192.168.10.43
資料庫:Oracle 10.2.0.3
ORACLE_SID:h10g
Global_name:h10g
3 環境準備
3.1 設定初始化引數
使用pfile的修改init.ora檔案,使用spfile的透過alter system命令修改spile檔案。主、從資料庫分別執行如下的語句:
以下是引用片段:
Sqlplus ‘/ as sysdba’
alter system set aq_tm_processes=2 scope=both;
alter system set global_names=true scope=both;
alter system set job_queue_processes=10 scope=both;
alter system set parallel_max_servers=20 scope=both;
alter system set undo_retention=3600 scope=both;
alter system set nls_date_format='YYYY-MM-DD HH24:MI:SS' scope=spfile;
alter system set streams_pool_size=25M scope=spfile;
alter system set utl_file_dir='*' scope=spfile;
alter system set open_links=4 scope=spfile;
執行完畢後重啟資料庫。
3.2 將資料庫置為歸檔模式
設定log_archive_dest_1到相應的位置;設定log_archive_start為TRUE,即啟用自動歸檔功能;設定log_archive_format指定歸檔日誌的命令格式。
舉例:
以下是引用片段:
sqlplus ‘/ as sysdba’
alter system set log_archive_dest_1=’location=/yang/arch’ scope=spfile;
alter system set log_archive_start=TRUE scope=spfile;
alter system set log_archive_format=’ arch%t_%s_%r.arc’ scope=spfile;
shutdown immediate;
startup mount;
alter database archivelog;
alter database open;
資料庫置為歸檔模式後,可以按如下方式檢驗一下:
以下是引用片段:
SQL> archive log list
Database log mode Archive Mode
Automatic archival Enabled
Archive destination /yang/arch
Oldest online log sequence 534
Next log sequence to archive 536
Current log sequence 536
3.3 建立stream 管理使用者
3.3.1 建立主環境stream管理使用者
以下是引用片段:
#以sysdba身份登入
connect / as sysdba
#建立主環境的Stream專用表空間
create tablespace tbs_stream datafile '/yang/oradata/prod/tbs_stream01.dbf'
size 100m autoextend on maxsize unlimited segment space management auto;
#將logminer的資料字典從system表空間轉移到新建的表空間,防止撐滿system表空間
execute dbms_logmnr_d.set_tablespace('tbs_stream');
#建立Stream管理使用者
create user strmadmin identified by strmadmin
default tablespace tbs_stream temporary tablespace temp;
#授權Stream管理使用者
grant connect,resource,dba,aq_administrator_role to strmadmin;
begin
dbms_streams_auth.grant_admin_privilege(
grantee => 'strmadmin',
grant_privileges => true);
end;
/
3.3.2 建立從環境stream管理使用者
以下是引用片段:
#以sysdba身份登入
connect / as sysdba
#建立Stream專用表空間,我的從庫用了ASM,這一步也可以參見3.3.1
create tablespace tbs_stream datafile '+VGDATA/h10g/datafile/tbs_stream01.dbf'
size 100m autoextend on maxsize unlimited segment space management auto;
#同樣,將logminer的資料字典從system表空間轉移到新建的表空間,防止撐滿system表空間
execute dbms_logmnr_d.set_tablespace('tbs_stream');
#建立Stream管理使用者
create user strmadmin identified by strmadmin
default tablespace tbs_stream temporary tablespace temp;
#授權Stream管理使用者
grant connect,resource,dba,aq_administrator_role to strmadmin;
begin
dbms_streams_auth.grant_admin_privilege(
grantee => 'strmadmin',
grant_privileges => true);
end;
/
3.4 配置網路連線
3.4.1配置主環境tnsnames.ora
主資料庫(tnsnames.ora)中新增從資料庫的配置。
以下是引用片段:
H10G =
(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.10.43)(PORT = 1521))
)
(CONNECT_DATA =
(SID = h10g)
(SERVER = DEDICATED)
)
)
3.4.2配置從環境tnsnames.ora
以下是引用片段:
從資料庫(tnsnames.ora)中新增主資料庫的配置。
PROD =
(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.10.35)(PORT = 1521))
)
(CONNECT_DATA =
(SID = prod)
(SERVER = DEDICATED)
)
)
3.5 啟用追加日誌
可以基於Database級別或Table級別,啟用追加日誌(Supplemental Log)。在建立根據Schema粒度進行復制的Oracle Stream環境中,如果確認Schema下所有Table都有合理的主鍵(Primary Key),則不再需要啟用追加日誌。
以下是引用片段:
#啟用Database 追加日誌
alter database add supplemental log data;
#啟用Table追加日誌
alter table add supplement log group log_group_name(table_column_name) always;
3.6 建立DBlink
根據Oracle 10gR2 Stream官方文件,針對主資料庫建立的資料庫鏈的名字必須和從資料庫的global_name相同。
如果需要修改global_name,執行“alter database rename global_name to xxx”。
3.6.1建立主資料庫資料庫鏈
#以strmadmin身份,登入主資料庫。
connect strmadmin/strmadmin
#建立資料庫鏈
create database link h10g connect to strmadmin identified by strmadmin using 'h10g';
3.6.2建立從資料庫資料庫鏈
#以strmadmin身份,登入從資料庫。
connect strmadmin/strmadmin
#建立資料庫鏈
create database link prod connect to strmadmin identified by strmadmin using 'prod';
3.7 建立流佇列
3.7.1建立Master流佇列
以下是引用片段:
#以strmadmin身份,登入主資料庫。
connect strmadmin/strmadmin
begin
dbms_streams_adm.set_up_queue(
queue_table => 'prod_queue_table',
queue_name => 'prod_queue');
end;
/
3.7.2建立Backup流佇列
以下是引用片段:
#以strmadmin身份,登入從資料庫。
connect strmadmin/strmadmin
begin
dbms_streams_adm.set_up_queue(
queue_table => 'h10g_queue_table',
queue_name => 'h10g_queue');
end;
/
3.8 建立捕獲程式
以下是引用片段:
#以strmadmin身份,登入主資料庫。提醒一下,本文件以hr使用者做示例。
connect strmadmin/strmadmin
begin
dbms_streams_adm.add_schema_rules(
schema_name => 'hr',
streams_type => 'capture',
streams_name => 'capture_prod',
queue_name => 'strmadmin.prod_queue',
include_dml => true,
include_ddl => true,
include_tagged_lcr => false,
source_database => null,
inclusion_rule => true);
end;
/
3.9 例項化複製資料庫
在主資料庫環境中,執行如下Shell語句。如果從庫的hr使用者不存在,建立一個hr的空使用者。
exp file='/tmp/hr.dmp' object_consistent=y rows=y
imp file='/tmp/hr.dmp' ignore=y commit=y log='/tmp/hr.log' streams_instantiation=y fromuser=hr touser=hr
3.10 建立傳播程式
以下是引用片段:
#以strmadmin身份,登入主資料庫。
connect strmadmin/strmadmin
begin
dbms_streams_adm.add_schema_propagation_rules(
schema_name => 'hr',
streams_name => 'prod_to_h10g',
source_queue_name => 'strmadmin.prod_queue',
destination_queue_name => ,
include_dml => true,
include_ddl => true,
include_tagged_lcr => false,
source_database => 'prod',
inclusion_rule => true);
end;
/
#修改propagation休眠時間為0,表示實時傳播LCR。
begin
dbms_aqadm.alter_propagation_schedule(
queue_name => 'prod_queue',
destination => 'h10g',
latency => 0);
end;
/
3.11 建立應用程式
以下是引用片段:
#以strmadmin身份,登入從資料庫。
connect strmadmin/strmadmin
begin
dbms_streams_adm.add_schema_rules(
schema_name => 'hr',
streams_type => 'apply',
streams_name => 'apply_h10g',
queue_name => 'strmadmin.h10g_queue',
include_dml => true,
include_ddl => true,
include_tagged_lcr => false,
source_database => 'prod',
inclusion_rule => true);
end;
/
3.12 啟動STREAM
以下是引用片段:
#以strmadmin身份,登入從資料庫。
connect strmadmin/strmadmin
#啟動Apply程式
begin
dbms_apply_adm.start_apply(
apply_name => 'apply_h10g');
end;
/
#以strmadmin身份,登入主資料庫。
connect strmadmin/strmadmin
#啟動Capture程式
begin
dbms_capture_adm.start_capture(
capture_name => 'capture_prod');
end;
/
3.13 停止STREAM
以下是引用片段:
#以strmadmin身份,登入主資料庫。
connect strmadmin/strmadmin
#停止Capture程式
begin
dbms_capture_adm.stop_capture(
capture_name => 'capture_prod');
end;
/
#以strmadmin身份,登入從資料庫。
connect strmadmin/strmadmin
#停止Apply程式
begin
dbms_apply_adm.stop_apply(
apply_name => 'apply_h10g');
end;
/
3.14 清除所有配置資訊
要清楚Stream配置資訊,需要先執行3.13,停止Stream程式。
以下是引用片段:
#以strmadmin身份,登入主資料庫。
connect strmadmin/strmadmin
exec DBMS_STREAMS_ADM.remove_streams_configuration();
#以strmadmin身份,登入從資料庫。
connect strmadmin/strmadmin
exec DBMS_STREAMS_ADM.remove_streams_configuration();
4 測試場景
本文件建立了針對hr使用者的Stream 複製環境,如果沒有特別宣告,以下測試場景均以hr使用者身份執行。
4.1 建一張表測試
主資料庫
SQL> CREATE TABLE TTT(id NUMBER PRIMARY KEY,
2 name VARCHAR2(50)
3 )
4 /
Table created.
從資料庫
SQL> desc TTT
Name Null? Type
---------- -------- -------------
ID NOT NULL NUMBER
NAME VARCHAR2(50)
4.2 表中插入一行資料
主資料庫
SQL> insert into ttt values (1,'sdfsdfsdfsdf');
1 row created.
SQL> commit;
Commit complete.
SQL>
從資料庫
SQL> select * from TTT;
ID NAME
---------- --------------------
1 sdfsdfsdfsdf
4.3 變更一下表的結構,新增一列
主資料庫
SQL> ALTER TABLE TTT ADD(age NUMBER(2));
Table altered
從資料庫
SQL> desc TTT
Name Null? Type
----------- -------- --------------
ID NOT NULL NUMBER
NAME VARCHAR2(50)
AGE NUMBER(2)
4.4 將表換一個表空間
主資料庫
SQL> SELECT table_name,tablespace_name FROM user_tables
2 WHERE table_name='TTT';
TABLE_NAME TABLESPACE_NAME
------------------------------ ------------------------------
TTT USERS
SQL> ALTER TABLE TTT MOVE TABLESPACE tbs_stream;
Table altered
SQL> SELECT table_name,tablespace_name FROM user_tables
WHERE table_name='TTT';
TABLE_NAME TABLESPACE_NAME
------------------------------ ------------------------------
TTT TBS_STREAM
從資料庫
SQL> SELECT table_name,tablespace_name FROM user_tables
WHERE table_name='TTT';
TABLE_NAME TABLESPACE_NAME
------------------------------ ------------------------------
TTT TBS_STREAM
4.5 表上Name列建一索引
主資料庫
SQL> CREATE INDEX ttt_name_idx ON TTT(name);
Index created
從資料庫
SQL> SELECT table_name, index_name FROM user_indexes WHERE table_name = 'TTT';
TABLE_NAME INDEX_NAME
------------------------------ ------------------------------
TTT TTT_NAME_IDX
TTT SYS_C005721
4.6 Rebuild索引測試
主資料庫
SQL> ALTER INDEX ttt_name_idx REBUILD;
Index altered
從資料庫
SQL> SELECT table_name, index_name FROM user_indexes WHERE table_name = 'TTT';
TABLE_NAME INDEX_NAME
------------------------------ ------------------------------
TTT TTT_NAME_IDX
TTT SYS_C005721
4.7 索引換一個表空間測試
主資料庫
SQL> ALTER INDEX ttt_name_idx REBUILD TABLESPACE tbs_stream;
Index altered
從資料庫
SQL> SELECT table_name,index_name,tablespace_name FROM user_indexes
WHERE table_name = 'TTT';
TABLE_NAME INDEX_NAME TABLESPACE_NAME
------------------------------ ------------------------------ ------------------------------
TTT TTT_NAME_IDX TBS_STREAM
TTT SYS_C005721 USERS
4.8 刪除索引測試
主資料庫
SQL> DROP INDEX ttt_name_idx;
Index dropped
從資料庫
SQL> SELECT table_name,index_name,tablespace_name FROM user_indexes
WHERE table_name = ‘TTT’;
TABLE_NAME INDEX_NAME TABLESPACE_NAME
------------------------------ ------------------------------ ------------------------------
TTT SYS_C005721 USERS
4.9 刪除表測試
主資料庫
SQL> DROP TABLE ttt;
Table dropped
從資料庫
SQL> DESC ttt;
Object ttt does not exist.
4.10 建一張帶有LOB型別欄位的表測試
主資料庫
SQL> CREATE TABLE tttclob(id NUMBER PRIMARY KEY, memo CLOB);
Table created
從資料庫
SQL> DESC tttclob;
Name Null? Type
----------- -------- --------------
ID NOT NULL NUMBER
MEMO CLOB
4.11 表中插入一行資料
主資料庫
SQL> INSERT INTO tttclob VALUES(1,'clob_test');
1 row inserted
SQL> commit;
Commit complete
從資料庫
SQL> SELECT * FROM tttclob;
ID MEMO
---------- --------------------------------------------------------------------------------
1 clob_test
4.12 建立Type測試
主資料庫
SQL> CREATE or REPLACE TYPE ttttype;
2 /
Type created
從資料庫
SQL> SELECT * FROM user_types WHERE type_name='TTTTYPE';
TYPE_NAME TYPE_OID TYPECODE ATTRIBUTES METHODS PREDEFINED INCOMPLETE FINAL INSTANTIABLE SUPERTYPE_OWNER SUPERTYPE_NAME LOCAL_ATTRIBUTES LOCAL_METHODS TYPEID
------------------------------ -------------------------------- ------------------------------ ---------- ---------- ---------- ---------- ----- ------------ ------------------------------ ------------------------------ ---------------- ------------- --------------------------------
TTTTYPE 1B36AAF10DA8301DE040A8C0289A77B4 OBJECT 0 0 NO YES YES YES
4.13 刪除Type測試
主資料庫
SQL> DROP TYPE ttttype;
Type dropped
從資料庫
SQL> SELECT * FROM user_types WHERE type_name='TTTTYPE';
TYPE_NAME TYPE_OID TYPECODE ATTRIBUTES METHODS PREDEFINED INCOMPLETE FINAL INSTANTIABLE SUPERTYPE_OWNER SUPERTYPE_NAME LOCAL_ATTRIBUTES LOCAL_METHODS TYPEID
------------------------------ -------------------------------- -
5 問題診斷
5.1 如何知道捕捉(Capture)程式是否執行正常?
以strmadmin身份,登入主資料庫,執行如下語句:
SQL> SELECT CAPTURE_NAME,
2 QUEUE_NAME,
3 RULE_SET_NAME,
4 NEGATIVE_RULE_SET_NAME,
5 STATUS
6 FROM DBA_CAPTURE;
結果顯示如下:
CAPTURE_NAME QUEUE_NAME
------------------------------ ------------------------------
RULE_SET_NAME NEGATIVE_RULE_SET_NAME STATUS
------------------------------ ------------------------------ --------
CAPTURE_PROD PROD_QUEUE
RULESET$_14 ENABLED
ENABLED
如果STATUS狀態是ENABLED,表示Capture程式執行正常;
如果STATUS狀態是DISABLED,表示Capture程式處於停止狀態,只需重新啟動即可;
如果STATUS狀態是ABORTED,表示Capture程式非正常停止,查詢相應的ERROR_NUMBER、ERROR_MESSAGE列可以得到詳細的資訊;同時,Oracle會在跟蹤檔案中記錄該資訊。
5.2 如何知道Captured LCR是否有傳播GAP?
以strmadmin身份,登入主資料庫,執行如下語句:
SQL> SELECT CAPTURE_NAME, QUEUE_NAME, STATUS, CAPTURED_SCN, APPLIED_SCN
2 FROM DBA_CAPTURE;
結果顯示如下:
CAPTURE_NAME QUEUE_NAME STATUS
------------------------------ ------------------------------ --------
CAPTURED_SCN APPLIED_SCN
------------ -----------
CAPTURE_PROD PROD_QUEUE ENABLED
17023672 17023672
如果APPLIED_SCN小於CAPTURED_SCN,則表示在主資料庫一端,要麼LCR沒有被dequeue,要麼Propagation程式尚未傳播到從資料庫一端。
5.3 如何知道Appy程式是否執行正常?
以strmadmin身份,登入從資料庫,執行如下語句:
SQL> SELECT apply_name, apply_captured, status FROM dba_apply;
結果顯示如下:
APPLY_NAME APPLY_ STATUS
---------------------- ------ ----------------
APPLY_H10G YES ENABLED
如果STATUS狀態是ENABLED,表示Apply程式執行正常;
如果STATUS狀態是DISABLED,表示Apply程式處於停止狀態,只需重新啟動即可;
如果STATUS狀態是ABORTED,表示Apply程式非正常停止,查詢相應的ERROR_NUMBER、ERROR_MESSAGE列可以得到詳細的資訊;同時,可以查詢DBA_APPLY_ERROR檢視,瞭解詳細的Apply錯誤資訊。
6 結篇
透過如上的測試可以看出stream的功能還是十分強大的,透過配置Oracle Stream可以更大的提升資料庫的可用性和安全性,如此一個好用且不用花費高昂額外費用的功能還是很值得一用的。
本篇文章來源於:網貝建站 原文連結:
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/35489/viewspace-629913/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 【BUILD_ORACLE】Oracle RAC配置ASM Filter Driver(ASMFD)(二)詳細配置步驟UIOracleASMFilter
- 配置PLSQL Developer詳細步驟SQLDeveloper
- Github配置ssh key詳細步驟Github
- 【ASK_ORACLE】Relink RAC叢集詳細步驟Oracle
- 如何配置web伺服器的詳細步驟Web伺服器
- IN2003下JDK的詳細安裝配置步驟JDK
- 超詳細oracle 11g安裝步驟 win版本Oracle
- LVM建立的詳細步驟LVM
- OpenHarmony執行docker詳細步驟Docker
- docker安裝portainer詳細步驟DockerAI
- MySQL的安裝步驟(詳細)MySql
- Oracle從10g升級到11g詳細步驟Oracle
- 【ASK_ORACLE】Relink ASM單例項資料庫詳細步驟OracleASM單例資料庫
- CentOS7安裝及配置 Zabbix全步驟,超詳細教程CentOS
- CentOS 7 安裝MongoDB詳細步驟CentOSMongoDB
- Linux安裝jdk的詳細步驟LinuxJDK
- Linux安裝jdk的詳細步驟。LinuxJDK
- ubuntu 18.04安裝kalibr(詳細步驟)Ubuntu
- MyBatis的逆向工程詳細步驟操作MyBatis
- 安裝fbprophet模組詳細步驟
- Oracle 11g dataguard 配置簡約步驟Oracle
- CentOS 7.4安裝redis 4.0詳細步驟CentOSRedis
- .Net Core Web Api 框架搭建詳細步驟WebAPI框架
- CentOS 7上安裝WordPress詳細步驟CentOS
- Oracle Stream概述與配置Oracle
- oracle 大頁配置詳細介紹Oracle
- git如何生成ssh金鑰 git生成配置ssh金鑰key詳細步驟Git
- UBUNTU手動安裝JDK的詳細步驟UbuntuJDK
- Git學習2 --- Git安裝詳細步驟Git
- NodeJS入門(一)---nodejs詳細安裝步驟NodeJS
- CentOS 7.4下安裝nginx的詳細步驟CentOSNginx
- Virtualbox7安裝及使用詳細步驟
- 特別詳細的react專案搭建步驟React
- KeyShot9.3安裝教程(附詳細步驟)
- 使用.NET Core建立Windows服務詳細步驟Windows
- Centos MySQL資料庫遷移詳細步驟CentOSMySql資料庫
- doris編譯和安裝部署詳細步驟編譯
- Mac安裝Redis,詳細redis安裝步驟MacRedis
- 免費伺服器領取步驟(詳細)伺服器