Oracle 单表流复制 stream
把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

熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

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

MySQL在Web應用中的主要作用是存儲和管理數據。 1.MySQL高效處理用戶信息、產品目錄和交易記錄等數據。 2.通過SQL查詢,開發者能從數據庫提取信息生成動態內容。 3.MySQL基於客戶端-服務器模型工作,確保查詢速度可接受。

InnoDB使用redologs和undologs確保數據一致性和可靠性。 1.redologs記錄數據頁修改,確保崩潰恢復和事務持久性。 2.undologs記錄數據原始值,支持事務回滾和MVCC。

MySQL与其他编程语言相比,主要用于存储和管理数据,而其他语言如Python、Java、C 则用于逻辑处理和应用开发。MySQL以其高性能、可扩展性和跨平台支持著称,适合数据管理需求,而其他语言在各自领域如数据分析、企业应用和系统编程中各有优势。

MySQL索引基数对查询性能有显著影响:1.高基数索引能更有效地缩小数据范围,提高查询效率;2.低基数索引可能导致全表扫描,降低查询性能;3.在联合索引中,应将高基数列放在前面以优化查询。

MySQL的基本操作包括創建數據庫、表格,及使用SQL進行數據的CRUD操作。 1.創建數據庫:CREATEDATABASEmy_first_db;2.創建表格:CREATETABLEbooks(idINTAUTO_INCREMENTPRIMARYKEY,titleVARCHAR(100)NOTNULL,authorVARCHAR(100)NOTNULL,published_yearINT);3.插入數據:INSERTINTObooks(title,author,published_year)VA

MySQL適合Web應用和內容管理系統,因其開源、高性能和易用性而受歡迎。 1)與PostgreSQL相比,MySQL在簡單查詢和高並發讀操作上表現更好。 2)相較Oracle,MySQL因開源和低成本更受中小企業青睞。 3)對比MicrosoftSQLServer,MySQL更適合跨平台應用。 4)與MongoDB不同,MySQL更適用於結構化數據和事務處理。

InnoDBBufferPool通過緩存數據和索引頁來減少磁盤I/O,提升數據庫性能。其工作原理包括:1.數據讀取:從BufferPool中讀取數據;2.數據寫入:修改數據後寫入BufferPool並定期刷新到磁盤;3.緩存管理:使用LRU算法管理緩存頁;4.預讀機制:提前加載相鄰數據頁。通過調整BufferPool大小和使用多個實例,可以優化數據庫性能。

MySQL通過表結構和SQL查詢高效管理結構化數據,並通過外鍵實現表間關係。 1.創建表時定義數據格式和類型。 2.使用外鍵建立表間關係。 3.通過索引和查詢優化提高性能。 4.定期備份和監控數據庫確保數據安全和性能優化。
