文档章节

Supervisor

lionets
 lionets
发布于 2016/12/12 21:25
字数 492
阅读 29
收藏 0
点赞 0
评论 0

配置文件


创建的默认配置文件本身包含好几个项目,他们的功能分别是:

unix_http_server 提供一个 Unix socket 的接口,这是 supervisorctl 默认使用的接口,用于和 supervisord 通信。

如果想让一个虚拟环境只负责一组进程,而不是创建一个全局的 supervisord 的话,这里面的 file 项就应该改成一个特有的文件名,而不是默认的 /tmp/supervisord.sock

inet_http_server 提供网络 socket 接口,可以支持 xmlrpc 通信。可以替代 Unix socket,也可以一起开。当然用不上的话也可以不开。

supervisord 主进程,有需要的话配一下他的日志 和 pid 文件路径。

supervisorctl,控制进程,serverurl 要和上面的保持一致。即你开的是哪一种 server,然后配的分别是什么地址。

最后就是你的真正进程的配置了。注意 directory 项记得配,不然容易出现路径问题。

进程监控

如果要通过脚本定时监控进程状态,可以有两种方法。背后其实就是你开的两种不同 server。

一是通过 supervisorctl 访问 Unix socket,二是通过 xmlrpc 访问 inet。

第一种,直接从 supervisor 包引入组件,缺点是有虚拟环境依赖。


from supervisor.supervisorctl import Controller
from supervisor.options import ClientOptions
from cStringIO import StringIO

ST_OK = ''

def check_process_status(process_name):
    std_cap = StringIO()
    args = ['-c', '/etc/supervisord.conf', 'status']
    options = ClientOptions()
    options.realize(args, doc=__doc__)
    controller = Controller(options)
    controller.stdout = std_cap
    try:
        controller.onecmd(" ".join(options.args))
    except Exception as e:
        return str(e)
    else:
        std_cap.seek(0, 0)
        for line in std_cap:
            output = filter(bool, line.split(' '))
            if output and output[0] == process_name:
                if output[1] in ['STOPPED', 'BACKOFF', 'EXITED', 'FATAL', 'UNKNOWN']:
                    return ' '.join(output)
                else:
                    return ST_OK
    return 'process: %s not found in supervisorctl.' % process_name

另一种是通过内建的 xmlrpc 包访问 supervisord 的 inet 接口。这需要在启动 supervisord 的时候打开 inet 选项。

import xmlrpclib

ST_OK = ''
SUPERVISOR_RPC = 'http://localhost:9002/RPC2'

def check_process_state(process='linking_api'):
    server = xmlrpclib.Server(SUPERVISOR_RPC)
    try:
        process_info = server.supervisor.getProcessInfo(process)
        assert isinstance(process_info, dict), 'Invalid supervisor rpc return.'
    except Exception as e:
        return str(e)
    else:
        state = process_info.get('statename')
        if state in ['STARTING', 'RUNNING', 'STOPPING']:
            return ST_OK
        else:
            return '%s: %s' % (process_info.get('name'), state)

© 著作权归作者所有

共有 人打赏支持
lionets
粉丝 90
博文 96
码字总数 131014
作品 0
朝阳
程序员
python 部署:virtuale + gunicorn + supervisor + flask

主要参考 Flask + Gunicorn + Nginx 部署 http://www.cnblogs.com/Ray-liang/p/4837850.html python web 部署:nginx + gunicorn + supervisor + flask 部署笔记 http://www.jianshu.com/p/b......

曹梦龙 ⋅ 2016/07/19 ⋅ 2

(整理)用Elixir做一个多人扑克游戏 3

今天我们将为德州扑克游戏添加故障恢复能力。 OTP为我们准备好了构建容错程序所需要的工具。我们只需要定义正确的behavior 行为。 Supervisor 有了Supervisor,我们就只需要关心当进程崩溃时...

ljzn ⋅ 2016/10/05 ⋅ 0

Akka 容错和监控策略

Akka fault tolerance and supervisor strategies akka的容错和监控策略 In an actor system, each actor is the supervisor of its children. If an actor fails to handle a message, it ......

秋风醉了 ⋅ 2015/01/14 ⋅ 0

virtualenv 环境下 Flask + Nginx + Gunicorn+ Supervis

在这篇文章里,我们将搭建一个简单的 Web 应用,在虚拟环境中基于 Flask 框架,用 Gunicorn 做 wsgi 容器,用 Supervisor 管理进程,然后使用 OneAPM Python 探针来监测应用性能,形成一个「...

OneAPM蓝海讯通 ⋅ 2015/07/15 ⋅ 0

supervisor运行golang守护进程

Supervisor是一个C/S系统,它可以在类UNIX系统上控制系统进程,由python编写,它提供了大量的功能来实现对进程的管理。 程序的多进程启动,可以配置同时启动的进程数,而不需要一个个启动 程序...

Minho ⋅ 2016/07/09 ⋅ 1

Supervisor全攻略(1)

Supervisor是一个C/S系统,它允许用户在类UNIX系统上控制一些进程。它具有以下特性: 1 简单 Supervisor通过INI格式配置文件进行配置,很容易掌握,它为每个进程提供了很多配置选项,可以使你...

China_OS ⋅ 2015/09/18 ⋅ 0

supervisor安装和配置指南

supervisor:是用python写的一个进程管理工具,用来启动,重启,关闭进程。 注意:Supervisor只能管理非daemon的进程,也就是说Supervisor不能管理守护进程。否则提示Exited too quickly (p...

高运维之路 ⋅ 05/03 ⋅ 0

supervisord的使用用法

Linux系统下的进程监控工具Supervisor的基本使用方法 Supervisor是一个C/S系统,它允许用户在类UNIX系统上控制一些进程。它具有以下特性: 1 简单 Supervisor通过INI格式配置文件进行配置,很...

caijyi1 ⋅ 2017/03/14 ⋅ 0

shadowsocks 安装及使用

安装 shadowsocks 1. 安装shadowsocks pip install shadowsocks 2. 编写shadowsocks配置文件测试,配置文件如下: cat >> /etc/shadowsocks.json <...

lvnian2009 ⋅ 2017/10/13 ⋅ 0

supervisor配置使用

环境:ubutu 15.10 搭建步骤: sudo apt-get install python-setuptools easyinstall supervisor echosupervisord_conf > /etc/supervisord.conf #根据配置文件模板生成supervisor配置文件 ......

jeff_han ⋅ 2016/03/11 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

用ZBLOG2.3博客写读书笔记网站能创造今日头条的辉煌吗?

最近两年,著名的自媒体网站今日头条可以说是火得一塌糊涂,虽然从目前来看也遇到了一点瓶颈,毕竟发展到了一定的规模,继续增长就更加难了,但如今的今日头条规模和流量已经非常大了。 我们...

原创小博客 ⋅ 43分钟前 ⋅ 0

MyBatis四大核心概念

本文讲解 MyBatis 四大核心概念(SqlSessionFactoryBuilder、SqlSessionFactory、SqlSession、Mapper)。 MyBatis 作为互联网数据库映射工具界的“上古神器”,训有四大“神兽”,谓之:Sql...

waylau ⋅ 今天 ⋅ 0

以太坊java开发包web3j简介

web3j(org.web3j)是Java版本的以太坊JSON RPC接口协议封装实现,如果需要将你的Java应用或安卓应用接入以太坊,或者希望用java开发一个钱包应用,那么用web3j就对了。 web3j的功能相当完整...

汇智网教程 ⋅ 今天 ⋅ 0

2个线程交替打印100以内的数字

重点提示: 线程的本质上只是一个壳子,真正的逻辑其实在“竞态条件”中。 举个例子,比如本题中的打印,那么在竞态条件中,我只需要一个方法即可; 假如我的需求是2个线程,一个+1,一个-1,...

Germmy ⋅ 今天 ⋅ 0

Springboot2 之 Spring Data Redis 实现消息队列——发布/订阅模式

一般来说,消息队列有两种场景,一种是发布者订阅者模式,一种是生产者消费者模式,这里利用redis消息“发布/订阅”来简单实现订阅者模式。 实现之前先过过 redis 发布订阅的一些基础概念和操...

Simonton ⋅ 今天 ⋅ 0

error:Could not find gradle

一.更新Android Studio后打开Project,报如下错误: Error: Could not find com.android.tools.build:gradle:2.2.1. Searched in the following locations: file:/D:/software/android/andro......

Yao--靠自己 ⋅ 昨天 ⋅ 0

Spring boot 项目打包及引入本地jar包

Spring Boot 项目打包以及引入本地Jar包 [TOC] 上篇文章提到 Maven 项目添加本地jar包的三种方式 ,本篇文章记录下在实际项目中的应用。 spring boot 打包方式 我们知道,传统应用可以将程序...

Os_yxguang ⋅ 昨天 ⋅ 0

常见数据结构(二)-树(二叉树,红黑树,B树)

本文介绍数据结构中几种常见的树:二分查找树,2-3树,红黑树,B树 写在前面 本文所有图片均截图自coursera上普林斯顿的课程《Algorithms, Part I》中的Slides 相关命题的证明可参考《算法(第...

浮躁的码农 ⋅ 昨天 ⋅ 0

android -------- 混淆打包报错 (warning - InnerClass ...)

最近做Android混淆打包遇到一些问题,Android Sdutio 3.1 版本打包的 错误如下: Android studio warning - InnerClass annotations are missing corresponding EnclosingMember annotation......

切切歆语 ⋅ 昨天 ⋅ 0

eclipse酷炫大法之设置主题、皮肤

eclipse酷炫大法 目前两款不错的eclipse 1.系统设置 Window->Preferences->General->Appearance 2.Eclipse Marketplace下载【推荐】 Help->Eclipse Marketplace->搜索‘theme’进行安装 比如......

anlve ⋅ 昨天 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部