cron 不执行带有变量的命令

Val*_*kyi 1 command-line cron variable

我有一些执行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')
Run Code Online (Sandbox Code Playgroud)

测试:

echo $v2
18
Run Code Online (Sandbox Code Playgroud)

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
Run Code Online (Sandbox Code Playgroud)

因此,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
Run Code Online (Sandbox Code Playgroud)

然后通常只执行第一个 curl(在数据库中创建的新笔记)。在接下来 - 执行的第二个微服务( 53 09 * * * java -jar parsdescription-0.0.1-SNAPSHOT.jar )中,但没有在第二个curl命令中执行,并且没有保存在description3.log文件中 - 他是一个空的。

为什么这在控制台中有效,但在 crontab 中无效?

thr*_*rig 5

每个 cron 作业都是一个唯一的 shell 实例,不与任何其他 cron 作业共享状态,因此

51 09 * * * value=42
Run Code Online (Sandbox Code Playgroud)

value只接受那份工作,然后退出,并value随后消失。相比之下,shell 会话在连续的行上保持状态。您将需要一个运行所有代码或其他设计的 cron 作业;单个 cron 作业可能看起来像

51 09 * * * /path/to/your/script
Run Code Online (Sandbox Code Playgroud)

然后该文件/path/to/your/script应该是可执行的并包含

#!/bin/bash
java -jar /root/parser-0.0.1-SNAPSHOT.jar
value=$(curl -d '{"query":"java-middle", ...
Run Code Online (Sandbox Code Playgroud)

等等。

如果您需要在不同的 cron 作业之间共享数据,则需要通过某种 IPC(进程间通信)方法(文件系统、数据库等)共享该信息。