在Python中会话终止时获取信号
我正在尝试编写一个Python demon,它会在会话结束时做出反应(例如,TTY关闭,因为bash已经退出,等等)。据我所知,应该在某个时候向流程发送一个SIGHUP(我对细节不太清楚),但到目前为止,我还没有捕捉到任何东西 下面是我的非功能性python尝试:在Python中会话终止时获取信号,python,linux,signals,Python,Linux,Signals,我正在尝试编写一个Python demon,它会在会话结束时做出反应(例如,TTY关闭,因为bash已经退出,等等)。据我所知,应该在某个时候向流程发送一个SIGHUP(我对细节不太清楚),但到目前为止,我还没有捕捉到任何东西 下面是我的非功能性python尝试: #!/usr/bin/env python import os import sys import signal import time def log_to_disk(signum, frame): with op
#!/usr/bin/env python
import os
import sys
import signal
import time
def log_to_disk(signum, frame):
with open("/tmp/SIGNAL", "w") as f:
f.write("Received %d!\n" % signum)
def fork():
try:
pid = os.fork()
if pid > 0:
# Exit parent
print "Parent exiting. Bye!"
sys.exit(0)
except OSError as e:
print "Error while forking! (%s)" % str(e)
sys.exit(1)
fork()
os.chdir('/')
os.setsid()
os.umask(0)
fork() # Second fork.
# Catch ALL the signals just in case.
for i in [x for x in dir(signal) if x.startswith("SIG")]:
try:
signum = getattr(signal, i)
signal.signal(signum, log_to_disk)
except Exception as e:
print "Couldn't handle %s (%s)." % (i, str(e))
while True:
time.sleep(10)
我正在做的是:我将SSH连接到服务器,在那里启动脚本,然后关闭SSH会话。然后我重新登录,希望已经创建了/tmp/SIGNAL
文件,但到目前为止运气不好。如果我使用kill
向进程发送信号,则会显示该文件,因此我假设这不是处理程序的问题。
我也只尝试过一次分叉和/或注释chdir/setsid/umask
部分,但我也没有收到任何结果。
我探索过的另一种途径是只分叉一次,并尝试定期向TTY写信,期望在TTY关闭时收到SIGTTOU
有人能帮我吗?我找到了一个解决方法,即检测何时
stdout
无法解析为TTY名称:
import os
import sys
import time
def fork():
try:
pid = os.fork()
if pid > 0:
# Exit parent
print "Parent exiting. Bye!"
sys.exit(0)
except OSError as e:
print "Error while forking! (%s)" % e.message
sys.exit(1)
fork()
os.chdir('/')
os.setsid()
os.umask(0)
fork() # Second fork.
while True:
time.sleep(1)
with open("/tmp/SIGNAL", "a+") as f:
try:
os.ttyname(1) # 1 = stdout
except:
f.write("The session has been shut down :)\n")
sys.exit(0)
我仍然不确定到底发生了什么:当我在ps
中查看Python进程时,TTY列显示了一个问号(?),因此我不知道它如何仍然能够在双叉之后解析其标准输出。
我还将把这个问题保留一段时间,以防有人想出一个在没有TTY的shell中工作的答案