Gammu smsd runonreceive返回0,但没有程序输出

Gammu-smsd runonreceive returns 0 but no program output

本文关键字:程序 输出 smsd runonreceive 返回 Gammu      更新时间:2023-10-16

我编写了一个C应用程序,它可以获取一些传感器数据并将其放入字符串中。此字符串被传递给gammu-smsd-inject以供smsd传输。作为参考,我的应用程序使用fork()&wait()。程序等待gammu-smsd注入终止,然后自行退出。

我的程序运行得很好:如果我从bash提示符手动运行它,它会获取传感器数据,调用gammu-smsd-inject并退出。短信出现在数据库发件箱中,在我收到手机短信后不久。

我已经将程序的绝对路径添加到SMSD的runonreceive指令中。当我向SMSD发送文本时,它会在收件箱中收到,从日志文件中我可以看到运行我的程序的守护程序。然后,日志文件声明进程(我的程序)已成功退出(0),但我从未收到任何短信,也没有向数据库的发件箱或sentems表添加任何内容。

知道可能发生了什么吗?我还没有发布代码清单,因为它很长,但它是可用的。

我唯一能想到的可能会发生的是,gammu-smsd注入可能在有机会执行任何SQL操作之前就被终止了(由树上某个父进程终止)。这难道不会创建一个非零退出代码吗?

所以问题是哪个用户在运行程序。当我从bash手动运行我的应用程序时,它会使用我的用户ID启动它,但当SMSD守护进程运行它时,它使用不同的ID启动,这出于某种原因导致了问题。我认为这是用于访问mysql数据库的用户ID的问题,但显然不是。简言之,我实际上并不知道问题出在哪里,但通过将登录名的UID分配给子进程,一切都突然正常了。