### crond 执行ORACLE rman备份脚本失败的几种情况及解决 在日常的数据库管理工作中,通过Linux系统的crond来安排Oracle RMAN备份任务是一种常见的做法。然而,在实际操作过程中,有时会遇到crond无法正常执行Oracle RMAN备份脚本的情况。本文将详细介绍这些常见问题及其解决方法。 #### 一、crond配置文件格式问题 1. **问题描述**: 在crond的配置文件`/etc/crontab`中,计划任务命令的执行格式如果设置不当,则会导致Oracle RMAN备份脚本无法正常执行。具体来说,crond的执行身份通常是root,而Oracle RMAN备份脚本却需要以oracle用户的身份运行。因此,如果配置文件中的格式不正确,就可能引起执行失败的问题。 2. **示例**: ```plaintext SHELL=/bin/bash PATH=/sbin:/bin:/usr/sbin:/usr/bin MAILTO=oracle HOME=/ # Example of job definition: # .---------------- minute (0 - 59) # |.------------- hour (0 - 23) # ||.---------- day of month (1 - 31) # |||.------- month (1 - 12) OR jan,feb,mar,apr # ||||.---- day of week (0 - 6) (Sunday = 0 or 7) OR sun,mon,tue,wed,thu,fri,sat # ||||| # ***** user-name command to be executed 30 10 * * 0 root su oracle /home/oracle/backupfull.sh 10 10 * * 1 root su oracle /home/oracle/backuplevel1.sh 10 10 * * 2 root su oracle /home/oracle/backuplevel1.sh # 30 09 * * 3 root /home/oracle/backuplevel2.sh # 30 09 * * 3 oracle /home/oracle/backuplevel2.sh 30 09 * * 3 root su oracle /home/oracle/backuplevel2.sh 30 10 * * 4 root su oracle /home/oracle/backuplevel1.sh 00 10 * * 5 root su oracle /home/oracle/backuplevel2.sh 30 10 * * 6 root su oracle /home/oracle/backupfull.sh ``` 如上所示,红色注释部分的写法都是不正确的。第一种不正确的写法中,直接使用root用户执行备份脚本,但由于备份脚本需要oracle用户的权限,因此这种方式是无效的。第二种不正确的写法则是直接使用oracle用户执行脚本,但crond的默认执行身份是root,这种情况下也无法成功执行。 3. **正确写法**: 使用`su`命令切换到oracle用户,并执行备份脚本。例如: ```plaintext 30 09 * * 3 root su - oracle -c '/home/oracle/backuplevel2.sh' ``` 这样的写法确保了首先以root身份启动crond任务,然后通过`su - oracle`命令切换到oracle用户,并执行备份脚本。 #### 二、crontab文件所有者问题 1. **问题描述**: 即使crontab文件中的计划任务内容正确无误,但如果该文件的所有者不是root,而是其他用户(如oracle),也会导致crond无法执行Oracle RMAN备份脚本。 2. **示例**: 假设您在一台服务器上配置了一个crontab文件,该文件的所有者为oracle,而不是root。当您尝试在另一台服务器上使用这个文件时,可能会遇到执行失败的情况。 ```plaintext [root@odba oracle]# ll /etc/crontab -rw-r--r-- 1 oracle oinstall 8527 7月 26 09:38 /etc/crontab ``` 在crond的日志文件`/var/log/cron`中,可以看到以下错误信息: ```plaintext Aug 7 09:20:13 odba CROND[7429]: (root) CMD(/usr/lib64/sa/sa1 11) Aug 7 10:20:18 odba crond[7421]: (CRON) INFO (Shutting down) Aug 7 10:20:19 odba crond[7457]: (CRON) STARTUP (1.4.4) Aug 7 10:20:19 odba crond[7457]: (CRON) INFO (RANDOM_DELAY will be scaled with factor 75% if used.) Aug 7 10:20:19 odba crond[7457]: (root) WRONG FILE OWNER (/etc/crontab) ``` 3. **解决方法**: 将crontab文件的所有者更改为root: ```bash [root@odba oracle]# chown root:root /etc/crontab ``` 更改所有权后,再次查看日志文件确认问题是否已解决。 通过正确配置crond的任务执行格式以及确保crontab文件的所有者为root,可以有效避免crond执行Oracle RMAN备份脚本失败的问题。希望这些解决方案能够帮助您顺利进行数据库备份工作。
- 粉丝: 1
- 资源: 4
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助