exec sudo和/或发送信号给孩子

我想执行一个应用程序(gnutls-cli)作为另一个用户并向它发送一个信号(SIGALRM)。 不幸的是,这是行不通的:

sudo -u myuser gnutls-cli -p smtp imap.gmail.com --starttls & sudo -u myuser kill -ALRM $! 

gnutls-cli是sudo进程的一个subprocess,那就是我得到了如下进程树:

 \_ sudo -u myuser gnutls-cli -p smtp imap.gmail.com --starttls \_ gnutls-cli -p smtp imap.gmail.com --starttls 

这意味着信号被发送到外部sudo进程。 显然这根本不起作用。

有没有办法让sudo直接执行subprocess或将信号转发给subprocess?

谢谢

快速浏览sudo和sudoers的手册页,没有什么明显的解决这个问题,但是我可以提供一个替代解决scheme吗?

将原始程序包装在一个脚本中,该脚本将生成的pid#保存到一个pidfile中,稍后可以参考。 例如:

/home/myuser/scripts/gnutls-cli-wrapper.sh:

 gnutls-cli $@ & echo $! > /home/myuser/var/gnutls-cli.pid 

那么,从sudo你可以运行:

 sudo -u myuser /home/myuser/scripts/gnutls-cli-wrapper.sh -p smtp imap.gmail.com --starttls & 

之后,

 sudo -u myuser kill -ALRM $(cat /home/myuser/var/gnutls-cli.pid) 

我希望你觉得这有帮助。