我有一些执行java项目的逻辑;当我输入它时,这一切都在终端控制台中工作,但在 cron 调度程序中却没有:
运行第一个微服务并从 POST 请求中获取变量:
java -jar /root/parser-0.0.1-SNAPSHOT.jar
value=$(curl -d '{"query":"java-middle", "turnOff":true}' -H "Content-Type: application/json" -X POST http://localhost:8080/explorer)
v2=$(echo ${value} | jq '.id')
测试:
echo $v2
18
18 - 来自数据库的 id,我在下一个请求中使用它:(首先运行新的微服务)
java -jar parsdescription-0.0.1-SNAPSHOT.jar
value=$(curl -d '{"explorerId":'$v2', "turnOff":true}' -H "Content-Type: application/json" -X POST http://localhost:8080/descriptions) >> /var/log/description3.log 2>&1
因此,curl执行正常,数据库确实填充了一些数据,并且在值中我得到了正确的值。
但是,当我创建一个 crontab 计划时:
50 09 * * * java -jar /root/parser-0.0.1-SNAPSHOT.jar
51 09 * * * value=$(curl -d '{"query":"java-middle", "turnOff":true}' -H "Content-Type: application/json" -X POST http://localhost:8080/explorer)
52 09 * * * v2=$(echo ${value} | jq '.id')
53 09 * * * java -jar parsdescription-0.0.1-SNAPSHOT.jar
54 09 * * * value=$(curl -d '{"explorerId":'$v2', "turnOff":true}' -H "Content-Type: application/json" -X POST http://localhost:8080/descriptions) >> /var/log/description3.log 2>&1
然后只正常执行第一个 curl (在数据库中创建新注释)。在下一个 - 执行的第二个微服务( 53 09 * * * java -jar parsdescription-0.0.1-SNAPSHOT.jar )中,但在第二个curl命令中没有执行任何内容,并且在description3.log文件中没有任何内容 - 他是一个空的。
为什么这在控制台中有效,但在 crontab 中无效?
每个 cron 作业都是一个唯一的 shell 实例,不与任何其他 cron 作业共享状态,所以
只为那个工作设置
value
,然后退出,value
然后丢失。相比之下,shell 会话在连续的行上保持状态。您将需要一个运行所有代码或其他设计的单个 cron 作业;单个 cron 作业可能看起来像然后该文件
/path/to/your/script
应该是可执行的并包含等等。
如果您需要在不同的 cron 作业之间共享数据,则需要通过某种 IPC(进程间通信)方法(文件系统、数据库等)共享信息。