2015-09-12 69 views
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 

或锁定文件?

回答

1

我认为你在混合守护进程脚本和负责管理它的代码。

通常在说Ubuntu的,例如,你将通过新贵

description "Some Description" 
author "[email protected]" 

start on runlevel [2345] 
stop on runlevel [!2345] 

exec /path/to/script 

实际运行Python应用程序将永远需要保存它的PID,因为它总是访问它的控制这一点。

那么写什么是一个本质上管理守护进程的脚本,这真的是你想要的吗? PS:为自己做个忙,结识argparse库。

import argparse 
parser = argparse.ArgumentParser(description='Some Description') 
parser.add_argument('command', help='Either stop or start', choices=['start', 'stop']) 

args = parser.parse_args() 
print(args.command) 

这是非常值得的

+0

感谢你的答案Anarci。是的,这真的是我想要的。之所以我不想在Upstart上转播,或者我们说systemd,是因为我希望脚本能够成为平台不可知论者......我只是在原型阶段,当然我会尝试将守护进程管理从在我最终的程序中的实际处理...我会看看argparse库。 我对我在这里得到的快速反应感到惊讶(这是我的第一篇文章),确实是这样! 祝您有愉快的一天。 –

+0

我明白了,在这种情况下,您肯定需要某种方法将进程中的pid传递给管理脚本。我将定义一个目录,其中所有正在运行的脚本都会写入一个以其pid命名的文件,然后在关闭时删除该文件。这与守护进程无关。 –