把Oracle单表流复制搞定,由于oracle stream 操作步骤多,之前遇到许多问题,没有理清思路或者说自己对此的理解不够,所以失败。
把Oracle单表流复制搞定,由于oracle stream 操作步骤多,之前遇到许多问题,
没有理清思路或者说自己对此的理解不够,所以失败。对于重要表,流复制类似dataguard应用日志,主服务器
捕获,然后传递,从服务器接受,如此而以。简单记录一下主要步骤。
1 主服务器 os: windows sid:rman 数据库版本10.2.0.1
从服务器 os: windows sid format 数据库版本10.2.0.1
2 主、从数据库分别执行如下的语句:
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;--这个我没执行,理由是oracle自动分配了
alter system set utl_file_dir='*' scope=spfile;
alter system set open_links=4 scope=spfile;
3 主从机设置归档 mout状态下alter database archivelog 另开启alter system set log_archive_start=true;
查看归档是否成功select recid, name, first_time from v$archived_log;
4 主从机表空间和用户
create tablespace stream_tbs datafile 'g:\oracle\oradata\rman\stream01.dbf' size 200m
autoextend on extent management local uniform size 1m segment space management auto;
表空间已创建。
-- 创建streams管理用户,并授予dba权限
JSSWEB> create user test identified by test default tablespace stream_tbs;
用户已创建。
--将logminer的数据字典从system表空间转移到新建的表空间,防止撑满system表空间
execute dbms_logmnr_d.set_tablespace('tbs_stream');
-- 由于streams用户操作需要较多权限,此处仅用于演示,简便期间直接授予dba权限
授权test管理用户
JSSWEB> grant dba to test;
begin
dbms_streams_auth.grant_admin_privilege(
grantee => 'test',
grant_privileges => true);
end;
5 主从机表空间和用户
create tablespace stream_tbs datafile 'd:\oracle\oradata\rman\stream01.dbf' size 200m
autoextend on extent management local uniform size 1m segment space management auto;
表空间已创建。
-- 创建streams管理用户,并授予dba权限
JSSWEB> create user strmadmin identified by strmadmin default tablespace stream_tbs;
用户已创建。
--将logminer的数据字典从system表空间转移到新建的表空间,防止撑满system表空间
execute dbms_logmnr_d.set_tablespace('tbs_stream');
-- 由于streams用户操作需要较多权限,此处仅用于演示,简便期间直接授予dba权限
授权test管理用户
JSSWEB> grant dba to strmadmin ;
begin
dbms_streams_auth.grant_admin_privilege(
grantee => 'strmadmin',
grant_privileges => true);
end;
6 配置网络连接
主数据库(tnsnames.ora)中添加从数据库的配置。
RMAN =
(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.1.103)(PORT = 1521))
)
(CONNECT_DATA =
(SID = rman)
(SERVER = DEDICATED)
)
)
配置从环境tnsnames.ora
从数据库(tnsnames.ora)中添加主数据库的配置。
FORMAT =
(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.1.104)(PORT = 1521))
)
(CONNECT_DATA =
(SID = format)
(SERVER = DEDICATED)
)
)
7 创建database link
主:create database link format connect to strmadmin identified by strmadmin using 'format';
从:create database link rman connect to strmadmin identified by strmadmin using 'rman ';
然后相互tnsping 或 select sysdate from dual@format/rman;
8 主库 exec dbms_streams_adm.set_up_queue();
从库 exec dbms_streams_adm.set_up_queue();
9 创建捕获规则
begin
dbms_streams_adm.add_table_rules(
table_name => 'scott.emp',
streams_type => 'capture',
streams_name =>'capture_stream',
queue_name => 'test.streams_queue',
include_dml => true,
include_ddl => true,
inclusion_rule => true);
end;
--创建传播规则
begin
dbms_streams_adm.add_table_propagation_rules(
table_name =>'scott.emp',
streams_name => 'sour_to_targ',
source_queue_name =>'test.streams_queue',
destination_queue_name => 'strmadmin.streams_queue@format',
include_dml => true,
include_ddl => true,
source_database =>'rman',
inclusion_rule => true,
queue_to_queue => true);
end;
select capture_name,status from dba_capture;
CAPTURE_NAME STATUS
------------------------------ --------
CAPTURE_STREAM DISABLED

本文討論了使用MySQL的Alter Table語句修改表,包括添加/刪除列,重命名表/列以及更改列數據類型。

文章討論了為MySQL配置SSL/TLS加密,包括證書生成和驗證。主要問題是使用自簽名證書的安全含義。[角色計數:159]

文章討論了流行的MySQL GUI工具,例如MySQL Workbench和PhpMyAdmin,比較了它們對初學者和高級用戶的功能和適合性。[159個字符]

本文討論了使用Drop Table語句在MySQL中放下表,並強調了預防措施和風險。它強調,沒有備份,該動作是不可逆轉的,詳細介紹了恢復方法和潛在的生產環境危害。

本文討論了在PostgreSQL,MySQL和MongoDB等各個數據庫中的JSON列上創建索引,以增強查詢性能。它解釋了索引特定的JSON路徑的語法和好處,並列出了支持的數據庫系統。

文章討論了使用準備好的語句,輸入驗證和強密碼策略確保針對SQL注入和蠻力攻擊的MySQL。(159個字符)


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

SublimeText3 英文版
推薦:為Win版本,支援程式碼提示!

MantisBT
Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

mPDF
mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

SublimeText3 Linux新版
SublimeText3 Linux最新版