免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1962 | 回复: 5
打印 上一主题 下一主题

[SCO UNIX] 用crontab备份SCO unix5.05下的oracle数据库!! [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2006-08-07 17:45 |只看该作者 |倒序浏览
系统:sco unix 5.05
数据库:oracle 817

数据库用户:zd、common

备份文件目录:
/dbf/dmpbak/zd

/dbf/dmpbak/cm



备份的执行文件目录:
/oracle/bin下的exp_t
exp_t的权限是-rwxr-xr-x

exp_t的内容:
ORACLE_HOME=/oracle
ORACLE_SID=ora7
ORACLE_TERM=ansi
export ORACLE_HOME ORACLE_SID ORACLE_TERM
MENU5PATH=$ORACLE_HOME/forms30/admin/resource
export MENU5PATH
ORATERMPATH=$ORACLE_HOME/forms30/admin/resource
export ORATERMPATH
NLS_LANG=American_America.ZHS16CGB231280
export NLS_LANG
ORA_NLS=/oracle/ocommon/nls/admin/data
export ORA_NLS
home1='/dbf/dmpbak'
dt1=`date "+%H%M"`
echo ' ' >'$home1/'new_record
file_name="$home1"/zd/zd"$dt1"
echo $file_name >>'$home1'/new_record
$ORACLE_HOME/bin/exp zd/zdzd file=$file_name.dmp owner=zd grants=y buffer=204800 rows=y indexes=y compress=y
file_name="$home1"/cm/cm"$dt1"
echo $file_name >>'$home1'/new_record
$ORACLE_HOME/bin/exp common/cmcm file=$file_name.dmp owner=common grants=y buffer=204800 rows=y indexes=y compress=y
file='/dbf/dmpbak/new_record'
backup_dir='/oracle/sec_back'
if [ -d $backup_dir ]
then
for i in `cat $file`
do
cp $i $backup_dir/
done
echo ' '>$file
fi



编辑/usr/spool/cron/crontabs目录下的crontab文件
使用命令:
cron -u root -e

增加行:
45 8 * * * /oracle/bin/exp_t
45 9 * * * /oracle/bin/exp_t

意思是每天早晨8:45和9:45备份数据库
在/etc目录下启动
cron
提示 cannot start cron;
****CRON  ABORTED***
使用
ps -ef |grep cron
查看进程,并使用
kill -HUP 进程号
杀死进程
然后删除/usr/lib/cron下的FIFO文件
执行/etc/cron启动成功
但是到时间没有备份数据,exp_t这个文件我也试验过的,手工执行没问题,备份成功,但是就是crontab进行无法调用它,不知道为什么?请高手指教,谢谢

[ 本帖最后由 jmr 于 2006-8-7 19:02 编辑 ]

论坛徽章:
0
2 [报告]
发表于 2006-08-07 18:27 |只看该作者
看不懂。。。

论坛徽章:
0
3 [报告]
发表于 2006-08-07 19:00 |只看该作者
????????????????????????????

论坛徽章:
0
4 [报告]
发表于 2006-08-08 02:31 |只看该作者
一般来说,c r o n不能运行相应的脚本,用户将会收到一个邮件说明其中的原因,你看一下吧。我感觉可能是你的作业没有成功提交给cron进程。

[ 本帖最后由 我老婆黑社会 于 2006-8-8 02:35 编辑 ]

论坛徽章:
0
5 [报告]
发表于 2006-08-09 01:02 |只看该作者
不要去编辑/usr/spool/cron/crontabs目录下的crontab文件,在当前用户下用crontab -e命令加入作业试试

论坛徽章:
0
6 [报告]
发表于 2006-08-15 21:20 |只看该作者

可以这样

oracle环境变量没有完全带入执行shell建议详细检查一下
通过crontab -e比较好一点
如果实在不行可以通过job命令写一个循环同样达到目的
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP