Библиотека демонов Python3
Я изучаю Python3, особенно библиотеку демонов. Я хочу, чтобы мой демон вызывался с двумя возможными аргументами: start & stop.
Пока у меня есть этот код:
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, например, вы управляете этим через upstart.
description "Some Description"
author "your@email-address.com"
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)
Это того стоит