如何从python程序发送信号?

use*_*107 19 python linux signals

我有这个代码监听USR1信号

import signal
import os
import time

def receive_signal(signum, stack):
    print 'Received:', signum

signal.signal(signal.SIGUSR1, receive_signal)
signal.signal(signal.SIGUSR2, receive_signal)

print 'My PID is:', os.getpid()

while True:
    print 'Waiting...'
    time.sleep(3)
Run Code Online (Sandbox Code Playgroud)

这在我发送信号时有效 kill -USR1 pid

但是我如何从上面的python脚本中发送相同的信号,以便在10秒后自动发送USR1并接收它,而不必打开两个终端来检查它?

moo*_*ima 40

你可以使用os.kill():

os.kill(os.getpid(), signal.SIGUSR1)
Run Code Online (Sandbox Code Playgroud)

将它放在您要从中发送信号的代码中的任何位置.

  • 这对于让 docker 容器提交 seppuku 很有用 (2认同)

Rob*_*obᵩ 5

如果您愿意接受SIGALRM而不是SIGUSR1,请尝试:

signal.alarm(10)
Run Code Online (Sandbox Code Playgroud)

否则,您需要启动另一个线程:

import time, os, signal, threading
pid = os.getpid()
thread = threading.Thread(
  target=lambda: (
    time.sleep(10),
    os.kill(pid, signal.SIGUSR1)))
thread.start()
Run Code Online (Sandbox Code Playgroud)

因此,这个程序:

import signal
import os
import time

def receive_signal(signum, stack):
    print 'Received:', signum

signal.signal(signal.SIGUSR1, receive_signal)
signal.signal(signal.SIGUSR2, receive_signal)
signal.signal(signal.SIGALRM, receive_signal)  # <-- THIS LINE ADDED

print 'My PID is:', os.getpid()

signal.alarm(10)                               # <-- THIS LINE ADDED

while True:
    print 'Waiting...'
    time.sleep(3)
Run Code Online (Sandbox Code Playgroud)

产生这个输出:

$ python /tmp/x.py 
My PID is: 3029
Waiting...
Waiting...
Waiting...
Waiting...
Received: 14
Waiting...
Waiting...
Run Code Online (Sandbox Code Playgroud)