【Python】使用Supervisor来管理Python的进程

1.问题描述

需要一个python的服务程序在后台一直运行,不能让该进程被杀死,即使被杀死也要能及时自动重启。如:有一个python的程序:test.py ,通过命令:python test.py来运行程序,但是它会受命令行的中断而中断。所以我们需要一个方法来保证该程序一直在后台运行。

2.解决方法

以前经常用命令:nohup python test.py & 来保证其在后台运行不中断,但是这也不能保证一直运行。

下面介绍用supervisor来管理python的进程,保证其在后台一直运行不中断。

(1)安装supervisor

在命令行输入:sudo apt-get install supervisor  来安装supervisor

测试安装是否成功,在命令行输入:supervis 再按tab键,看其是否能补全命令:supervisor,如果能则表示安装成功

(2)配置supervisord.conf文件

找到supervisord.conf配置文件,一般在/etc/ 目录下,或者在/etc/supervisor/ 目录下,用root权限打开该文件:sudo vim supervisord.conf,否则不能进行修改。

在文件末尾添加如下几行:

[program:myProgram]

command=python /home/myname/test.py

autostart=true

autorestart=ture

stdout_logfile=/home/myname/test.log

注释:第一行的myProgram自己取个名字,表示你的项目就行

第二行的python /home/myname/test.py表示你运行程序的命令

第三行表示自动启动,如果值为false则表示不自动启动

第四行表示自动重启,如果值为false则表示不自动重启

最后一样表示程序打印出的信息都记录在该test.log文件内,是log文件

(3)使用supervisor

配置完之后,命令行输入:sudo supervisord  就可以了。

你可以kill掉你程序的进程,然后再看,发现它自动重启了,不用担心会被kill掉。

好了,希望对大家有帮助。

-----------------------------------------------------------------------------------------------------------------------------------------

时间: 2024-10-25 01:00:28

【Python】使用Supervisor来管理Python的进程的相关文章

python实现主机批量管理

在日常的运维工作中批量对主机的是很常见的,市面上也有许多主机批量管理的软件,但有时候这些软件并不能完全的满足我们的需求.python中刚好提供了关于主机批量管理的模块,今天就让我们来看看如何利用python实现主机批量管理 python提供主机批量管理的模块主要有三个paramiko.fabric与pexpect,今天我们主要说的是paramiko模块,paramiko模块是第三方模块 安装:pip install paramiko或者yum install python-paramiko如果都

用Supervisord管理Python进程

http://feilong.me/2011/03/monitor-processes-with-supervisord Supervisord是用Python实现的一款非常实用的进程管理工具,类似于monit(关于monit见我的博客:用monit监控系统关键进程),monit和supervisord的一个比较大的差异是supervisord管理的进程必须由supervisord来启动,monit可以管理已经在运行的程序:supervisord还要求管理的程序是非daemon程序,superv

ubuntu下python+tornado+supervisor+nginx部署

由于之前在医院采集的数据都是拍照得到的处方图片,而需要用到的是处方的文本形式.因此这两个星期写了个小程序把服务器的图片显示给用户(到时候雇一些人),让用户根据图片录入文字信息. 之前都是用java写web,想到自己最近学机器学习要用python,所以用python来写一下,此外,因为想用点新东西,也介于程序比较小,所以考虑用mongodb来存储(虽然确实没有必要). 基本架构是这样:(后台语言)python +(web框架和web服务器)tornado + (数据库)mongodb  +(进程管

docker之使用supervisor管理多个进程

docker题外话: centos7安装supervisor: 源码编译安装: 下载源码文件:supervisor-3.3.1.tar.gz 下载地址:https://pypi.python.org/pypi/supervisor 安装: [[email protected] src]# tar -zxf supervisor-3.3.1.tar.gz [[email protected] src]# cd supervisor-3.3.1/ [[email protected] supervi

python学习笔记-(十四)进程&协程

一. 进程 1. 多进程multiprocessing multiprocessing包是Python中的多进程管理包,是一个跨平台版本的多进程模块.与threading.Thread类似,它可以利用multiprocessing.Process对象来创建一个进程.该进程可以运行在Python程序内部编写的函数.该Process对象与Thread对象的用法类似. 创建一个Process实例,可用start()方法启动. join()方法可以等待子进程结束后再继续往下运行,通常用于进程间的同步.

Python黑帽编程1.3 Python运行时与包管理工具

Python黑帽编程1.3  Python运行时与包管理工具 0.1  本系列教程说明 本系列教程,采用的大纲母本为<Understanding Network Hacks Attack and Defense with Python>一书,为了解决很多同学对英文书的恐惧,解决看书之后实战过程中遇到的问题而作.由于原书很多地方过于简略,笔者根据实际测试情况和最新的技术发展对内容做了大量的变更,当然最重要的是个人偏好.教程同时提供图文和视频教程两种方式,供不同喜好的同学选择. 0.2 前言 前两

在python中使用zookeeper管理你的应用集群

http://www.zlovezl.cn/articles/40/ 简介: Zookeeper 分布式服务框架是 Apache Hadoop 的一个子项目,它主要是用来解决分布式应用中经常遇到的一些数据管理问题,如:统一命名服务.状态同步服务.集群管理.分布式应用配置项的管理等. 具体简介可以参照这篇文章. zkpython的安装: python中有一个zkpython的包,是基于zookeeper的c-client开发的,所以安装的时候需要先安装zookeeper的c客户端.安装步骤如下:

Docker使用 Supervisor 来管理进程

Docker 容器在启动的时候开启单个进程,比如,一个 ssh 或者 apache 的 daemon 服务.但我们经常需要在一个机器上开启多个服务,这可以有很多方法,最简单的就是把多个启动命令放到一个启动脚本里面,启动的时候直接启动这个脚本,另外就是安装进程管理工具. 本小节将使用进程管理工具 supervisor 来管理容器中的多个进程.使用 Supervisor 可以更好的控制.管理.重启我们希望运行的进程.在这里我们演示一下如何同时使用 ssh 和 apache 服务. 配置 首先创建一个

Python多环境扩展管理-Virtualenv

Python多环境管理工具,这两款可能都不错: Pyenv 和 Virtualenv .Pyenv ,是对Python的版本进行管理,实现版本的切换.Virtualenv ,是通过创建虚拟环境,实现Python环境间的隔离,避免相互干扰. Virtualenv 部署 首先得先准备好Python和pip.Windows系统去官网下载安装后就都有了.CentOS7安装python3可以看这篇:http://blog.51cto.com/steed/2288045用pip安装Virtualenv pi