Библиотека демонов 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)

Это того стоит

Другие вопросы по тегам