把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无尽的。

热门文章

热工具

禅工作室 13.0.1
功能强大的PHP集成开发环境

MinGW - 适用于 Windows 的极简 GNU
这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。

mPDF
mPDF是一个PHP库,可以从UTF-8编码的HTML生成PDF文件。原作者Ian Back编写mPDF以从他的网站上“即时”输出PDF文件,并处理不同的语言。与原始脚本如HTML2FPDF相比,它的速度较慢,并且在使用Unicode字体时生成的文件较大,但支持CSS样式等,并进行了大量增强。支持几乎所有语言,包括RTL(阿拉伯语和希伯来语)和CJK(中日韩)。支持嵌套的块级元素(如P、DIV),

记事本++7.3.1
好用且免费的代码编辑器

Atom编辑器mac版下载
最流行的的开源编辑器