免费注册 查看新帖 |

Chinaunix

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

【已解决】crontab无法运行脚本中的oracle命令,可以手动运行成功 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2012-03-09 17:28 |只看该作者 |倒序浏览
本帖最后由 chuxianbing 于 2012-03-14 22:13 编辑

各位大侠,我写了一个脚本文件,需要定时查询数据库并导出数据,以下是脚本内容:
#!/bin/bash
db_user=mpas                                    #DB USER                                                                                                     
db_pwd=mpas                                     #DB PASSWORD                                                                                                
db_serv=orcl                                    #DB SERVICE NAME                                                                                             
record="sjb_increment`date -d "1 days ago" +%Y%m%d`.csv"  #按时间命名文件                                                                             
spool_file="/home/oracle/mytest"                #存储路径                                                                                       
echo $spool_file                                                                                                                                             
db_conn_cmd=$db_user/$db_pwd@$db_serv           #DB_LINK                                                                                                     
echo $db_conn_cmd>>/home/oracle/mytest/cxb.txt                                                                                                               
db_conn_cmd_sqlplus="sqlplus -s $db_conn_cmd"   #SQLPLUS LINK                                                                                               
echo `date`>>/home/oracle/mytest/cxb.txt                                                                                                                     
echo "start spool file "                                                                                                                                    
$db_conn_cmd_sqlplus<<EOF                                                                                                                                    
set echo off                                                                                                                                                
set feedback off                                                                                                                                             
set newpage none                                                                                                                                             
set linesize 500                                                                                                                                             
set verify off
set pagesize 0
set term off
set trims on
set linesize 600
set heading off
set timing off
set verify off
set numwidth 38
spool $spool_file/$record
@$spool_file/sjb_increment.sql;
spool off
EOF
echo "end.."

手动运行可以执行成功,能导出查询数据,但是在crontab下定时后却不能执行sql语句了。
哪位高手知道怎么解决?
跪求

论坛徽章:
71
15-16赛季CBA联赛之同曦
日期:2018-08-23 15:41:42辰龙
日期:2014-08-15 09:07:43狮子座
日期:2014-06-03 13:55:33亥猪
日期:2014-06-02 11:17:08巨蟹座
日期:2014-05-06 10:02:03午马
日期:2014-05-04 08:18:27亥猪
日期:2014-04-29 11:11:32技术图书徽章
日期:2014-04-24 15:51:26技术图书徽章
日期:2014-04-17 11:01:53辰龙
日期:2014-04-15 12:45:46亥猪
日期:2014-04-11 09:06:23射手座
日期:2014-04-01 15:28:10
2 [报告]
发表于 2012-03-09 17:30 |只看该作者
你手动是怎么执行的?crontab是怎么写得?

论坛徽章:
1
2015亚冠之吉达阿赫利
日期:2015-09-09 16:42:38
3 [报告]
发表于 2012-03-09 17:36 |只看该作者
回复 1# chuxianbing


    oracle的环境变量没设

论坛徽章:
0
4 [报告]
发表于 2012-03-09 18:05 |只看该作者
oracle还要怎么设置变量呢?
我手动运行脚本是可以执行的哎
回复 3# jiaogeshahaone


   

论坛徽章:
0
5 [报告]
发表于 2012-03-09 18:06 |只看该作者
20 15 * * * /home/oracle/mytest/ss.sh

回复 2# zhaopingzi


   

论坛徽章:
71
15-16赛季CBA联赛之同曦
日期:2018-08-23 15:41:42辰龙
日期:2014-08-15 09:07:43狮子座
日期:2014-06-03 13:55:33亥猪
日期:2014-06-02 11:17:08巨蟹座
日期:2014-05-06 10:02:03午马
日期:2014-05-04 08:18:27亥猪
日期:2014-04-29 11:11:32技术图书徽章
日期:2014-04-24 15:51:26技术图书徽章
日期:2014-04-17 11:01:53辰龙
日期:2014-04-15 12:45:46亥猪
日期:2014-04-11 09:06:23射手座
日期:2014-04-01 15:28:10
6 [报告]
发表于 2012-03-09 18:30 |只看该作者
1.你这脚本是oralce用户执行的吧?
2.你的crontab写到root用户下了,还是oracle用户下了?
3.全限

论坛徽章:
0
7 [报告]
发表于 2012-03-09 18:36 |只看该作者
crontab在root用户下
脚本是调用oracle用户(我也不确定)
我是root用户登录进来编辑脚本的


回复 6# zhaopingzi


   

论坛徽章:
71
15-16赛季CBA联赛之同曦
日期:2018-08-23 15:41:42辰龙
日期:2014-08-15 09:07:43狮子座
日期:2014-06-03 13:55:33亥猪
日期:2014-06-02 11:17:08巨蟹座
日期:2014-05-06 10:02:03午马
日期:2014-05-04 08:18:27亥猪
日期:2014-04-29 11:11:32技术图书徽章
日期:2014-04-24 15:51:26技术图书徽章
日期:2014-04-17 11:01:53辰龙
日期:2014-04-15 12:45:46亥猪
日期:2014-04-11 09:06:23射手座
日期:2014-04-01 15:28:10
8 [报告]
发表于 2012-03-09 18:39 |只看该作者
脚本应该是ORACLE用户执行的
你切到oralce用户
编辑个临时文件1
$cat 1
20 15 * * * /home/oracle/mytest/ss.sh

$crontab  1

论坛徽章:
33
ChinaUnix元老
日期:2015-02-02 08:55:39CU十四周年纪念徽章
日期:2019-08-20 08:30:3720周年集字徽章-周	
日期:2020-10-28 14:13:3020周年集字徽章-20	
日期:2020-10-28 14:04:3019周年集字徽章-CU
日期:2019-09-08 23:26:2519周年集字徽章-19
日期:2019-08-27 13:31:262016科比退役纪念章
日期:2022-04-24 14:33:24
9 [报告]
发表于 2012-03-09 21:10 |只看该作者
回复 5# chuxianbing


在ss.sh里面source一下oracle的环境变量

论坛徽章:
0
10 [报告]
发表于 2012-03-13 14:14 |只看该作者

感谢
source一下确实可以了
现在另一个问题是,我另外加了一个自动上传到FTP上,然后再把本地文件删除的功能,结果crontab-e里定时后,导致是可以从数据库取出数据,生成到$file_name文件里,但是不能ftp上传和删除,能帮我看看什么原因么?
#!/bin/bash
source /home/oracle/.bash_profile
db_user=mpas                                    
db_pwd=mpas                                    
db_serv=orcl                                    
file_name="sjb`date -d "1 days ago" +%Y%m%d`.csv"  
file_path="/home/oracle/mytest"               
ftp_user=sjb
ftp_pwd=sjb
ftp_host=192.168.204.92
db_conn_cmd=$db_user/$db_pwd@$db_serv           
db_conn_cmd_sqlplus="sqlplus -s $db_conn_cmd"   
$db_conn_cmd_sqlplus<<EOF
set echo off
set feedback off
set newpage none
set linesize 500
set verify off
set pagesize 0
set term off
set trims on
set linesize 600
set heading off
set timing off
set verify off
set numwidth 38
spool $file_path/$file_name
@$file_path/sjb_day.sql;
spool off
EOF

if [  -f $file_name ]
then
/usr/bin/ftp -n <<FTPEOF
open ${ftp_host}
user $ftp_user $ftp_pwd
put $file_name $file_name
bye
FTPEOF
rm -if ./$file_name
fi
回复 9# Shell_HAT


   
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP