ORALCE数据泵自动同步思路

Oracle的数据泵是oracle自带的一种数据同步工具,自从10g版本后开始支持,能同步表结构、表数据等信息。对笔者来说,这是一个让人既爱又恨的工具:数据泵能顺利实现你期待的功能,解决绝大部分问题,可谓一个不可多得的助手;数据泵却又有着这样那样的bug让你抓狂,当然,从笔者这么多年的使用经验来看,这些bug仅会影响数据泵本身,而不会对数据库的稳定性造成影响。

在实现这个数据泵自动同步思路前,笔者是这样做的:

1、利用数据泵初始化表结构(排除约束索引)

2、把待导出的数据分成多份,利用数据泵的DATA_ONLY模式进行导出,并传输到目标端

3、一次性发起各种导入脚本

4、发起创建索引约束脚本

5、各种查漏补缺

这种方法解决了笔者大部分问题,直到遇到某个项目

1、客户整个同步时间非常敏感

2、源端文件系统空间紧张

3、目标端主机配置较低

  

所谓“穷则变,变则通,通则久”,在面临上述挑战后,笔者以及另一位合作的兄弟被逼出了解决方法。

笔者此处的自动初始化适用于下述场景:

1、数据泵待导出的表较多,其中数据量较大的表可分成多个批次

2、数据泵的源端以及目标端能通过某种协议进行通讯,如ssh协议、telnet协议

3、导出时间点不能非常严格(如所有数据并需同一个时间点导出)

下面是实施的重点

一、确认数据泵源端以及目标端的通讯方式

笔者采用ssh协议,配置目标端到源端的单边信任关系,最终确保下述两点:

1) 目标端能通过ssh执行源端命令,且无需输入密码

2) 目标端能通过scp命令从源端拷贝文件,且无需输入密码

二、确保对数据泵源端合理分批

下面为笔者的拆分方法:

1) 以用户为单位,按数据量进行拆分的,小用户一批,大用户则分成多批。

2) 通过数据量由大到小粗略拆分后,提取出数据量特别大的表、变更特别频繁的表单独成批

3) 拆分批次宁多勿少,多拆分几个批次,不会影响导出进度,甚至还能增加成功概率或者加快导出进度

4) 如果数据泵TABLE参数直接指定表名,那么单个批次总的字符数,不能超过数据泵TABLE参数限制(貌似是4096,待证实)

三、单独编写导出、传输、导入shell脚本

单个shell脚本中,通过传入的参数,自动生成数据泵等文件,并自动执行。

调用数据泵的操作中,不能使用nohup。

数据泵参数应当具备灵活性,如能指定并行数、导出目录等。

建议TABLE参数中指定对应的表名,这种方式效率相对高些,这是经验值。

四、编写调度脚本

建议在目标端进行总的调度。

建议控制源端的并发数,笔者把导出以及scp传输看作连贯的操作,源端导出或者scp的批次不超过4次。

成果展示

同样环境下,600GB的数据量(仅估算TABLE,不估算INDEX),同步时间由12~13小时减少到3~4小时。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在Oracle数据库中,使用数据工具进行备份是一种自动备份的方法。数据Oracle数据库提供的一种数据导入导出工具,可以将数据库对象(如表、触发器、视图等)和数据以二进制方式进行导出成为一个二进制文件,然后再将其导入到其他数据库中。 在Windows操作系统下,使用数据进行自动备份可以通过编写脚本来实现。首先,需要创建一个批处理文件(.bat),在该文件中编写备份命令。例如,可以使用expdp命令来导出指定的数据库对象和数据。 在批处理文件中,可以设置备份所需的参数,如导出文件路径、备份方式(全备份或增量备份)、导出对象等。此外,还可以设置备份的定时任务,例如使用Windows的计划任务来定期执行该批处理文件。 在设置好批处理文件后,可以使用Windows计划任务来定期执行该文件,以实现自动备份功能。可以根据需求设置备份的频率,如每天、每周、每月等。 当计划任务执行时,系统会自动运行批处理文件,并执行其中的备份命令。备份完成后,可以查看备份文件是否生成,并进行相应的验证工作,确保备份的准确性和完整性。 总之,在Oracle Windows环境下,使用数据进行自动备份需要编写批处理文件,并设置计划任务来定期执行该文件。这样可以实现数据库的自动备份,保证数据的安全性和可靠性。 ### 回答2: 在Oracle数据库中,可以通过数据实现自动备份。数据Oracle提供的一种高性能、可扩展的工具,可以用来导出和导入数据库对象和数据。 在Windows环境下,我们可以使用数据的expdp命令来进行备份。使用expdp命令需要系统管理员权限。 首先,需要打开命令提示符窗口,然后进入Oracle的安装目录下的bin目录。在该目录下,执行以下命令来登录到Oracle数据库: ``` sqlplus / as sysdba ``` 接着,可以执行以下命令来创建一个用于备份的目录: ``` CREATE DIRECTORY backup_dir AS 'C:\backup'; ``` 这里的C:\backup是备份文件存放的路径。 然后,执行以下命令来创建一个备份作业: ``` BEGIN DBMS_SCHEDULER.CREATE_JOB ( job_name => 'backup_job', job_type => 'EXPORT', job_action => 'expdp \"/ as sysdba\" directory=backup_dir dumpfile=database_backup.dmp logfile=backup.log SCHEMAS=<您要备份的SCHEMA> exclude=STATISTICS'); END; / ``` 这里的database_backup.dmp是备份文件的名称,backup.log是备份日志的名称,<您要备份的SCHEMA>是您希望备份的数据库模式。 最后,可以执行以下命令来运行备份作业: ``` BEGIN DBMS_SCHEDULER.RUN_JOB('backup_job'); END; / ``` 这样,就可以自动进行数据库备份了。根据备份数据库的大小和系统性能,备份过程可能需要一些时间。 需要注意的是,进行自动备份之前,需要根据实际情况修改相关的目录和备份文件的配置信息,并且确保有足够的存储空间来存放备份文件。另外,定期检查备份文件的完整性和可恢复性也是很重要的。 ### 回答3: 在Oracle数据库中,我们可以使用数据自动备份数据。在Windows操作系统上,您可以按照以下步骤来设置自动备份。 首先,您需要创建一个脚本文件,以便执行数据备份操作。您可以使用文本编辑器(如Notepad)来创建这个文件,并将其保存为一个批处理文件(.bat)。 脚本文件的内容应包括以下命令: ``` SET ORACLE_SID=<您的数据库SID> SET ORACLE_HOME=<您的Oracle软件目录> SET BACKUP_DIR=<您要存储备份文件的目录> expdp <用户名>/<密码> DIRECTORY=<备份文件目录> DUMPFILE=<备份文件名> LOGFILE=<日志文件名> ``` 在上述命令中,<您的数据库SID>是指您要备份的数据库实例的系统标识符。例如,如果您的数据库SID为ORCL,则将其替换为ORCL。 <您的Oracle软件目录>是指您安装Oracle数据库软件的目录路径。 <您要存储备份文件的目录>是指您希望将备份文件存储的文件夹的路径。 <用户名>和<密码>是您连接到数据库所使用的有效用户名和密码。 <备份文件目录>是指您要将备份文件存储在哪个目录中。 <备份文件名>是要备份文件的名称。 <日志文件名>是要记录备份操作日志的文件名。 保存好脚本文件后,您可以使用Windows任务计划程序来设置自动备份。打开计划任务程序,创建一个新的基本任务。在任务设置向导中,您可以选择设置任务的触发器,例如每天、每周或每月的特定时间自动执行备份任务。在操作设置中,指定要运行的脚本文件的路径。然后按照向导完成设置。 完成所有设置后,计划任务程序将会自动按照您的配置来执行数据备份操作,实现自动化备份。 通过这种方式,您可以在Windows操作系统上使用数据自动备份Oracle数据库。这样,您便可以定期备份数据,更好地保护数据库的安全性和完整性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值