0

我正在使用 python-daemon,但我在守护进程中有一个线程来偶尔检查串口:

context = daemon.DaemonContext(pidfile=daemon.pidfile.TimeoutPIDLockFile('/var/run/gpstemp.pid'),
                          uid = 0,
                          gid = 4,
                          umask = 0o002,
                          stdout = sys.stdout,  # change these for deployment
                          stderr =sys.stderr,   # change these for deployment
                          chroot_directory= None,
                          working_directory='/home/debian/gpstemp'
app = App()
with context:
    app.run()

线程运行这个:

class App():
    def __init__(self, port = 5556):
    ...
        # Handle all those threading things
        self.__sem = Lock()
        self.interval = 60.0  # interval between time updates in seconds
        self.worker = Thread(target = self._get_datetime_worker)
    def run(self):
        self.worker.start()
...
    def _get_datetime_worker(self):
        while not self.exit.is_set():
            self._get_datetime()
            self.exit.wait(self.interval)

我正在使用 systemctl 使用 .service 文件来启动和停止它。当我运行时: sudo systemctl stop myservice

它在返回前等待 60 秒。我如何通过 systemctl 立即终止服务中的线程。我考虑将上下文传递给应用程序,然后重新定义:

 context.signal_map = {
     signal.SIGTERM: app.shutdown,
     signal.SIGHUP: app.shutdown,
     }

然后向 App 添加一个关闭方法:

def shutdown(self, *args):
    self.exit.set()
    self.worker.join()

但是,这不会让上下文破坏 PID 并且不会正确退出上下文。我还应该在关闭方法中添加什么以使事情正常工作?

库尔特

4

1 回答 1

3

我是否正确理解您在杀死主程序时也想杀死线程?您可以通过设置来做到这一点daemon=True

def run(self):
    self.worker.daemon = True
    self.worker.start()
于 2017-12-21T16:02:05.970 回答