(OpenWRT) Mqtt 服务命令无法通过 C、Lua 工作

我在路由器上安装了 mqtt,并使用 WEB UI 进行控制。 这里是我在 mosquitto.conf 中添加的几行:

user root
allow_anonymous false
password_file /etc/mosquitto/passwd

这里是 lua 脚本的一部分。

如果 mqttOnOff == "1" then // mqttOnOff 在 WEB UI 上设置。
    os.execute("service mosquitto enable")
    os.execute("echo \"mosquitto 服务已启用\" > /dev/console")
    os.execute("service mosquitto stop")
    os.execute("echo \"mosquitto 服务已停止\" > /dev/console")
    os.execute("service mosquitto start")
    os.execute("echo \"mosquitto 服务已启动\" > /dev/console")
elseif mqttOnOff == "0" then
    os.execute("service mosquitto disable")
    os.execute("echo \"mosquitto 服务已禁用\" > /dev/console")
    os.execute("service mosquitto stop")
    os.execute("echo \"mosquitto 服务已停止\" > /dev/console")
else
    os.execute("echo \"mqttOnOff 值返回错误\" > /dev/console")
end

每当我将 mqttOnOff 的值设置为 1 时,我可以在控制台上看到以下行

mosquitto 服务已启用
mosquitto 服务已停止
mosquitto 服务已启动

如果我将值设置为 0,则可以看到...

mosquitto 服务已禁用
mosquitto 服务已停止

无论如何,这意味着服务命令正在使用 os.execute() 执行 然而,它不起作用。

每当我用手工在控制台上输入这些命令时,它就可以工作。它能够很好地停止、启动、重启、启用、禁用。

但是每次使用 lua 的 os.execute 都无法工作。

我手动启动 mosquitto 并使用 WEB UI 设置为启用(启动)并检查 PID,PID 显示相同(应该不同,因为命令有服务 mosquitto stop 和 _start_)。如果我使用 WEB UI 设置为禁用(启动),它不会停止。

手动停止 mosquitto 并使用 WEB UI 设置为启用,不会启动。

因此,我使用了 C,而不是 lua。机制相同。只是用 system() 函数,因为它是 C。

如果 (mqttOnOff == 1)
{
    system("service mosquitto enable");
    system("echo enable > /dev/console");
    system("service mosquitto stop");
    system("echo stop > /dev/console");
    system("service mosquitto start");
    system("echo start > /dev/console");
}
else if (mqttOnOff == 0)
{
    system("service mosquitto disable");
    system("echo disable > /dev/console");
    system("service mosquitto stop");
    system("echo stop > /dev/console");
}

跟 lua 一样,我可以看到

enable
stop
start

当我通过 WEB UI 设置时,即使手动执行此编译的 C 文件,结果也是相同的。mqtt 无法启动。

有什么解决方法吗?

原文链接 https://stackoverflow.com/questions/70588480

点赞
stackoverflow用户16756362
stackoverflow用户16756362

解决方案!!

由于service不可执行,所以我使用mosquitto命令直接执行mosquitto。

https://forum.openwrt.org/t/mqtt-service-command-is-not-working-via-c-lua/116434/2

2022-01-05 08:49:41