运行 python 脚本在 mysql 在 raspberry pi 启动后自动启动

Running a python script automatically after mysql starts on raspberry pi boot

我写了一个 python 脚本,可以与 mysql 数据库通信。我通过创建 launcher.sh 文件使其在启动时自动启动:

#!/bin/sh
#launcher.sh
cd /
cd home/pi/
sudo python ser.py
cd /

并添加

@reboot sh /home/pi/launcher.sh >/home/pi/logs/cronlog 2>&1

到 crontab 的最后一行:

sudo crontab -e

当系统重新启动时,脚本会尝试开始工作,但无法连接到 mysql 数据库。当我通过连接 ssh 启动脚本时,一切正常。

如何在所有数据库服务启动后自动启动我的脚本?

我最近运行遇到了类似的问题。

一个穷人的解决方案 - 睡觉

通过使用睡眠命令,您可以给 MySQL 服务器启动时间(在大多数 Raspberry Pi 用例中,5 秒应该绰绰有余)。这不是最优雅的解决方案,但除非您正在做的事情可能会极大地影响 MySQL 服务器启动时间,否则应该这样做:

#!/bin/sh
#launcher.sh
sleep 5
cd /
cd home/pi/
sudo python ser.py
cd /

更高级的解决方案 - 检查 MySQL 服务器是否已启动的脚本

基本思路是尝试在循环内连接到本地 mysql 服务器并执行查询、退出,然后评估退出代码。如果退出代码是肯定的,运行 你的脚本部分,否则重试。

mysql -e "desc mysql.user" -u <user> -p<password> >/dev/null

你可以在这里找到一个非常好的脚本来做这样的事情: http://forum.osmc.tv/showthread.php?tid=14823