Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/linux/23.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
在Python中会话终止时获取信号_Python_Linux_Signals - Fatal编程技术网

在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

我正在尝试编写一个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 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中工作的答案