相关疑难解决方法(0)

Python脚本作为linux服务/守护进程

你好,

我想让一个python脚本在(ubuntu)linux上作为服务(守护进程)运行.

在网上有几个解决方案,如:

http://pypi.python.org/pypi/python-daemon/

一个表现良好的Unix守护进程很难做到,但每个守护进程程序所需的步骤大致相同.DaemonContext实例保存程序的行为和配置的进程环境; 使用实例作为上下文管理器来进入守护程序状态.

http://www.jejik.com/articles/2007/02/a_simple_unix_linux_daemon_in_python/

但是,由于我想将我的python脚本专门与ubuntu linux集成,我的解决方案是与init.d脚本的组合

#!/bin/bash

WORK_DIR="/var/lib/foo"
DAEMON="/usr/bin/python"
ARGS="/opt/foo/linux_service.py"
PIDFILE="/var/run/foo.pid"
USER="foo"

case "$1" in
  start)
    echo "Starting server"
    mkdir -p "$WORK_DIR"
    /sbin/start-stop-daemon --start --pidfile $PIDFILE \
        --user $USER --group $USER \
        -b --make-pidfile \
        --chuid $USER \
        --exec $DAEMON $ARGS
    ;;
  stop)
    echo "Stopping server"
    /sbin/start-stop-daemon --stop --pidfile $PIDFILE --verbose
    ;;
  *)
    echo "Usage: /etc/init.d/$USER {start|stop}"
    exit 1
    ;;
esac

exit 0
Run Code Online (Sandbox Code Playgroud)

并在python中:

import signal
import time
import multiprocessing

stop_event = multiprocessing.Event()

def stop(signum, frame):
    stop_event.set() …
Run Code Online (Sandbox Code Playgroud)

python linux service daemon

67
推荐指数
2
解决办法
7万
查看次数

在'git pull'ing我的Django项目之后,重新启动/重新加载Gunicorn(通过Upstart)的更好方法

我正在寻找比sudo restart projectname每次发布更好的东西git pull origin master,这将我的最新更改下拉到Django项目.restart我相信这个命令与Upstart有关,我用它来启动/支持我的Gunicorn服务器进程.

此重新启动会导致短暂停机.击中Web服务器(nginx)的用户将获得500,因为Gunicorn仍在重启.事实上,它似乎立即重启,但页面加载需要几秒钟.

关于如何使这个无缝的任何想法?理想情况下,我想git pull自动发出我的和Gunicorn重新加载.

django nginx upstart reload gunicorn

54
推荐指数
6
解决办法
5万
查看次数

如何使Python脚本作为服务运行?

我想在CENTOS服务器中运行python脚本:

#!/usr/bin/env python
import socket
try:    
    import thread 
except ImportError:
    import _thread as thread #Py3K changed it.
class Polserv(object):
    def __init__(self):
        self.numthreads = 0
        self.tidcount   = 0
        self.port       = 843
        self.sock       = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
        self.sock.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
        self.sock.bind(('100.100.100.100', self.port))
        self.sock.listen(5)
    def run(self):
        while True:
            thread.start_new_thread(self.handle, self.sock.accept()) 
    def handle(self,conn,addr):
        self.numthreads += 1
        self.tidcount   += 1
        tid=self.tidcount
        while True:
            data=conn.recv(2048)
            if not data:
                conn.close()
                self.numthreads-=1
                break
            #if "<policy-file-request/>\0" in data:
            conn.sendall(b"<?xml version='1.0'?><cross-domain-policy><allow-access-from domain='*' to-ports='*'/></cross-domain-policy>")
            conn.close()
            self.numthreads-=1
            break
        #conn.sendall(b"[#%d (%d running)] %s" % …
Run Code Online (Sandbox Code Playgroud)

python linux centos

47
推荐指数
4
解决办法
11万
查看次数

Unix:Python脚本是否经常运行最佳实践?

我有一个处理HTTP数据流数据的Python脚本,理论上我需要这个脚本在任何时候都是永久运行的,除非我手动将其删除以更新它并再次运行它.

我想知道这样做的最佳做法是在Unix(特别是Ubuntu)上,这样即使终端关闭等,除非进程或服务器关闭,否则脚本会继续在后台运行?

谢谢

python unix ubuntu

10
推荐指数
3
解决办法
3万
查看次数

标签 统计

python ×3

linux ×2

centos ×1

daemon ×1

django ×1

gunicorn ×1

nginx ×1

reload ×1

service ×1

ubuntu ×1

unix ×1

upstart ×1