python代码中的mosquitto_pub命令没有在crontab中执行

时间:2015-04-03 10:14:04

标签: python-2.7 mosquitto

我正在使用Linux Debian,Mosquitto 1.3.5和Python 2.7.9脚本。

如果我在终端中运行Python脚本(使用我在crontab中编写的相同命令),则会运行mosquitto_pub命令。但它不能使用以下cron执行:

2,12,22,32,42,52 * * * * /usr/bin/python /home/user/ma.py

cron将启动脚本并执行脚本的第一部分(将一些数据写入csv文件),但不执行mosquitto_pub命令。

我的Python脚本的一部分:

liv = str(190 + float(parser.data[157]))
    try:
        ssl = '/home/user/file.pem'
        base = "mosquitto_pub -h host -p 8883 -t measures -q 2 --cafile " + ssl
        epoch = datetime.utcfromtimestamp(0)
        delta = datetime.strptime(dttime, "%Y-%m-%dT%H:%M:%SZ") - epoch
        ds = delta.total_seconds()
        mqttStr = base + " -m 'FILE_LL," + str(int(ds)) + ',' + liv + "'"
        subprocess.Popen(mqttStr, shell=True)
    except:
        print "It was not possible to send your data via mqtt.", sys.exc_info()[0], datetime.utcnow()

我尝试使用os.system,subprocess.call和subprocess.Popen,但命令没有启动。

提前感谢您的帮助。

1 个答案:

答案 0 :(得分:1)

好吧,我解决了这个问题。我不得不使用mosquitto_pub的完整路径:

/usr/local/bin/mosquitto_pub