我必须用Python3开发一个在特定时间自动执行程序的程序。我必须使用一个守护进程,我不能使用外部库。
这就是为什么我创建一个配置守护进程的安装程序(我遵循了本教程https://openclassrooms.com/courses/faire-un-demon-sous-linux)。
文件是自动执行程序的程序。

#! /usr/bin/python3
# -*- coding: utf8 -*-

import os
import sys
import time
import shutil

# Check if script is start with root rights
if os.geteuid() != 0:
    exit('You need to have root privileges to run this script. Use \'sudo ./install.py\'.')

# Title
print('----- ProcessManager install ----- \n')

time.sleep(1)

# Get path of gobatch file
gobatchPath = input("Please enter the path (absolute) where the ProcessManager gobatch program is located: ")

# Check if file exists
try:
    with open(gobatchPath):
        pass
except IOError:
    exit('Error : file does not exists.')

# Copy gobatch file into /usr/bin/
shutil.copy(gobatchPath, '/usr/bin/gobatch')

# Create and fill the automatic launch program
description = 'Deamon that allows you to run cyclicaly at a date or a specific time a program'

fileContent = '#### BEGIN INIT INFO \n' \
              '# Provides:          chillispot et freeradius dans le chroot \n' \
              '# Required-Start:    $local_fs $network \n' \
              '# Required-Stop:     $local_fs $remote_fs _\n' \
              '# Default-Start:     2 3 4 5 \n' \
              '# Default-Stop:      0 1 6 \n' \
              '# Short-Description: Wireless & LAN Access Point Controller \n' \
              '# Description:       ChilliSpot is an open source captive portal \n' \
              '#                    or wireless LAN access point controller. \n' \
              '### END INIT INFO \n\n\n' \
              'DESC="' + description + '"\n' \
              'DEAMON=/usr/bin/gobatch'

file = open('/etc/init.d/gobatch', 'w')
file.write(fileContent)
file.close()

# Give the rights
os.chmod('/etc/init.d/gobatch', 0o755)

# Save gobatch file to be active
os.system('update-rc.d gobatch defaults')

但是,当我用gobatch启动服务并用/etc/init.d/gobatch start显示状态时,会得到
gobatch.service - SYSV: ChilliSpot is an open source captive portal
  Loaded: loaded (/etc/init.d/gobatch; bad; vendor preset: enabled)
  Active: inactive (dead)
     Docs: man:systemd-sysv-generator(8)

你能告诉我我的方法是正确的还是存在其他的解决方法?
你知道为什么我的守护进程会在启动后直接死亡吗?
谢谢你的帮助!
更新
目前,我的service gobatch status文件不是一个真正的程序,因为我更喜欢在前面创建deamon。
gobatch文件
#! /bin/bash

echo "it works !"

我的工作是创建守护进程的安装程序,而不是gobatch程序。是另一个人必须这么做。这就是为什么我要用最小的内容。
更新2:
我的新gobatch
#!/bin/sh
#### BEGIN INIT INFO
# Provides:          chillispot et freeradius dans le chroot
# Required-Start:    $local_fs $network
# Required-Stop:     $local_fs $remote_fs _
# Default-Start:     2 3 4 5
# Default-Stop:      0 1 6
# Short-Description: Wireless & LAN Access Point Controller
# Description:       ChilliSpot is an open source captive portal
#                    or wireless LAN access point controller.
### END INIT INFO


PATH=/bin:/usr/bin:/sbin:/usr/sbin
DESC="Deamon that allows you to run cyclicaly at a date or a specific time a program"
NAME=gobatch
DEAMON=/usr/sbin/gobatch
PIDFILE=/var/run/$NAME.pid
SCRIPTNAME=/etc/init.d/"$NAME"

. /lib/lsb/init-functions

case "$1" in
start) log_daemon_msg "Starting gobatch"
       start_daemon -p $PIDFILE $DAEMON
       log_end_msg $?
       ;;
stop) log_daemon_msg "Stopping gobatch"
      killproc -p $PIDFILE $DAEMON
      RETVAL=$?
      [ $RETVAL -eq 0 ] && [ -e "$PIDFILE" ] && rm -f $PIDFILE
      log_end_msg $RETVAL
      ;;
restart) log_daemon_msg "Restarting gobatch"
         $0 stop
         $0 start
         ;;
esac
exit 0

有了这段代码,我得到了这个错误:
gobatch.service:在步骤EXEC派生时失败/etc/init.d/gobatch:EXEC格式错误
更新3:
日志文件中的最后一个错误是:
珍妮08 15:33:07 ubuntu systemd[1]:无法启动SYSV:ChilliSpot是一个开源的捕获门户。
我希望在那之后,我的计划能奏效。

最佳答案

你的脚本立即回响并退出,所以它不是一个恶魔。调用后,守护进程需要继续运行。
为了测试它的安装,您需要有一个行为类似于deamon的程序。安装程序不会从常规程序中创建deamon。它只会为运行它准备环境。
问题How do you create a daemon in Python?将为您提供更多关于如何用Python编写正确守护进程的信息。

08-05 10:49