linux中执行crontab定时任务时无法连接sybase iq15.1数据库,shell脚本中的sybase iq的环境变量怎么设置
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了linux中执行crontab定时任务时无法连接sybase iq15.1数据库,shell脚本中的sybase iq的环境变量怎么设置相关的知识,希望对你有一定的参考价值。
手工执行shell的时候是可以连接数据库。并正确执行的。连接数据库脚本如下:
dbisql -c "uid=DBA;pwd=sql" -host 192.168.0.34 -port 2638 /home/gjt/query.sql
query.sql中就一个简单查询sql语句。网上都说到环境变量。有没有人弄过这个的,给个详细点的答案。谢谢!
如果执行的语句很长可以写个成脚本这样也方便管理
#!/bin/bash
source /home/git/.bash_profile #先加载你可以执行这条命令的.bash_profile,在测试一下。
dbisql -c "uid=DBA;pwd=sql" -host 192.168.0.34 -port 2638 /home/gjt/query.sql 参考技术A 在执行dbisql -c "uid=DBA;pwd=sql" -host 192.168.0.34 -port 2638 /home/gjt/query.sql
query.sql这句话前面,先加载上sybase用户的环境变量。
source $SYBASE/SYBASE.sh本回答被提问者采纳 参考技术B 1,连接数据库的脚本给 可执行权限chmod +x 你的脚本
2,crontab编辑好之后请重启的你crond 服务
你可以测试下看看!
如何让linux定时任务crontab按秒执行
如何让linux定时任务crontab按秒执行?
linux定时任务crontab最小执行时间单位为分钟
如果想以秒为单位执行,应该如何设置呢?
思路
正常情况是在crontab中直接定义要执行的任务,现在我们在中间添加一个脚本文件
自定义一个脚本文件,循环执行要执行的任务,循环中使用sleep来控制间隔秒数
在crontab中添加一个任务,设置为每分钟都执行这个脚本
就是用crontab控制分钟,用脚本内的循环来控制秒
示例
(1) 定义目标任务
用php写了一个测试任务,向文件中写一个时间信息
文件路径 /root/test.php
<?php
file_put_contents(‘/root/run.log‘, date(‘Y-m-d H:i:s‘)."\r\n", FILE_APPEND);
?>
(2)编写执行任务的脚本
文件路径 /root/test.sh
#!/bin/bash
#间隔的秒数,就是要几秒执行一次
#不能大于60
step=2
for (( i = 0; i < 60; i=(i+step) )); do
$(php ‘/root/test.php‘)
sleep $step
done
exit 0
(3)添加定时任务
crontab -e
* * * * * /root/test.sh
重启定时任务服务
service crond restart
(4)查看效果
tail -f /root/run.log
可以看到按秒打印了信息
以上是关于linux中执行crontab定时任务时无法连接sybase iq15.1数据库,shell脚本中的sybase iq的环境变量怎么设置的主要内容,如果未能解决你的问题,请参考以下文章
crontab内环境变量问题(crontab定时任务执行脚本异常)
linux中打包备份脚本,手动执行可以正常打包,使用crontab -e 添加到系统定时任务中执行就无法打包
alpine linux中如何使用crontab执行定时任务