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语句。网上都说到环境变量。有没有人弄过这个的,给个详细点的答案。谢谢!

一般crontab无法执行,基本跟权限、路径和profile有关。
如果执行的语句很长可以写个成脚本这样也方便管理
#!/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 添加到系统定时任务中执行就无法打包

Linux 定时任务 Crontab按秒执行

alpine linux中如何使用crontab执行定时任务

alpine linux中如何使用crontab执行定时任务

crontab定时任务语法及应用