当前位置: 首页 > 图文教程 > 数据库 > Oracle > Oracle数据库自动备份的具体实现步骤

Oracle
Oracle 9i轻松取得建表和索引的DDL语句
Oracle 8x监控sysdba角色用户登陆情况
PB7 连接 Oracle 的设置方法
Oracle数据库的备份及恢复策略研究
Oracle三种上载文件技术
Oracle建立二进制文件索引的方法
Oracle数据库及应用程序优化开发者网络Oracle
Oracle PL/SQL入门慨述
Oracle PL/SQL入门案例实践
基于Oracle的面向对象技术入门基础简析开发者网络Oracle
PL/SQL编程经验小结开发者网络Oracle
Oracle的数据字典技术简析
基于Oracle的高性能动态SQL程序开发
Oracle9i取得建表和索引的DDL语句
PL/SQL实现Oracle数据库任务调度
Oracle 9i 数据库异常关闭后的启动
Oracle与SQL Server在企业应用的比较
Oracle捕获问题SQL解决CPU过渡消耗
Oracle平台应用数据库系统的设计与开发
Oracle使用PL/SQL操作COM对象

Oracle数据库自动备份的具体实现步骤


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-09-30   浏览: 55 ::
收藏到网摘: n/a

本文主要描述了Oracle数据库自动备份的具体实现步骤,具体内容请参考下文:

错误提示1:

message file rman.msb not found
verify that oracle_home is set properly
......

错误的主要原因:

自动执行的不能够识别相应的命令,需要在自动备份脚本中显式的声明Oracle的环境变量。

错误提示2:

standard in must be a tty
......

错误的主要原因:

不能在cron使用su或者管道等操作,必须将su命令移动到相关的shell脚本中。

错误提示3:

argument value description----------------
target quoted-string connect-string for target
databasecatalog quoted-string connect-string
for recovery catalognocatalog none if specified,
then no recovery catalogcmdfile quoted-string
name of input command filelog quoted-string
name of output message log filetrace
quoted-string name of output debugging
message log fileappend none if specified,
log is opened in append modedebug optional-args
activate debuggingmsgno none show rman-nnnn prefix
for all messagessend quoted-string send a command
to the media managerpipe string building block for
pipe namestimeout integer number of seconds to wait
for pipe inputchecksyntax none check the
command file for syntax errors-------------
--both single and double quotes (" or ") are accepted
for a quoted-string.quotes are not required unless the
string contains embedded white-space. rman-00571:
=======================================rman-00569: =============== error message stack follows ======rman-00571: ================================
rman-00556: could not open cmdfile "backup_ar.rcv" ......

错误原因:

需要在cmdfile中指明绝对路径,不能因为shell脚本调用的cmdfile是在同一个目录下就可以直接使用文件名或者直接使用./

正确示例代码:

1、#cron文件

0 12,18 * * * /home/oracle/bak_sh/backup_ar.sh

#表示每天12,18点对数据库归档日至进行全备份

2、入口shell文件,文件名:backup_ar.sh

export oracle_home=
/home/u01/app/oracle/oracle/product
/10.2.0/db_1export oracle_sid=testexport
lang=en_us.utf-8/home/u01/app/oracle
/oracle/product/10.2.0/db_1/bin/rman cmdfile = backup_ar.rcv

3、rman备份脚本

connect target /connect catalog rman/rman
@rmanrun{allocate channel d1 device type
disk;sql "alter system archive log current";
backup archivelog all delete input forma