0
我在学习Python3,尤其是守护进程库。我想用两个可能的参数调用我的守护进程:start & stop。Python3守护进程库
到目前为止,我有这样的代码:
def start():
with context:
pidfile = open(Config.WDIR+scriptname+".pid",'w')
pidfile.write(str(getpid()))
pidfile.close()
feed_the_db()
def stop(pid):
try:
kill(int(pid),15)
except ProcessLookupError:
print("Nothing to kill… (No process with PID "+pid+")")
if __name__ == "__main__":
scriptname = sys.argv[0]
context = daemon.DaemonContext(
working_directory=Config.WDIR,
pidfile=lockfile.FileLock(Config.WDIR+scriptname),
stdout=sys.stdout,
stderr=sys.stderr)
try:
if sys.argv[1] == 'start':
start()
elif sys.argv[1] == 'stop':
try:
pidfile = open(Config.WDIR+scriptname+".pid",'r')
pid = pidfile.read()
pidfile.close()
remove(name+".pid")
print(name+" (PID "+pid+")")
stop(pid)
except FileNotFoundError:
print("Nothing to kill… ("+scriptname+".pid not found)")
else:
print("\nUnknown option : "+sys.argv[1]+"\n\nUsage "+sys.argv[0]+" <start|stop>\n")
except IndexError:
print("\nUsage "+sys.argv[0]+" <start|stop>\n")
它的工作,但我不知道如果我做正确的方式。
特别是,为什么我必须手动存储PID。为什么它不包含在自动创建的文件中:
myhostname-a6982700.3392-7990643415029806679
或锁定文件?
感谢你的答案Anarci。是的,这真的是我想要的。之所以我不想在Upstart上转播,或者我们说systemd,是因为我希望脚本能够成为平台不可知论者......我只是在原型阶段,当然我会尝试将守护进程管理从在我最终的程序中的实际处理...我会看看argparse库。 我对我在这里得到的快速反应感到惊讶(这是我的第一篇文章),确实是这样! 祝您有愉快的一天。 –
我明白了,在这种情况下,您肯定需要某种方法将进程中的pid传递给管理脚本。我将定义一个目录,其中所有正在运行的脚本都会写入一个以其pid命名的文件,然后在关闭时删除该文件。这与守护进程无关。 –