目录

  • 概述
  • Supervisor是什么
  • Supervisor意图
  • Supervisor特性
  • Supervisor组件
  • 平台需求

概述

    项目运行需要后台运行,一般都是使用 nohup,但是nohup不能对后台进程监控和失败重启等高级功能,有木有更好的工具可以帮我们做这些事呢,通过谷哥的绑住找到了一个满意答案就是Supervisor

转帖请注明出处:https://my.oschina.net/u/2342969/blog/2963930

Supervisor是什么

    Supervisor是一个进程管理系统(其实是一个软件),它有一个可视化界面可以启动进程,查看进程状态,它允许用户监视和控制类unix操作系统上的许多进程。

    它与launchd、daemontools和runit等程序共享一些相同的目标。与某些程序不同,它不打算作为init的替代程序“process id 1”运行。相反,它被用于控制与项目或客户相关的过程,并且在引导时像其他程序一样启动。

Supervisor意图

  • 简便

        rc.d脚本是流程初始化/自动启动/管理的一种很好的、最基本的形式,但是编写和维护它们可能会很麻烦。此外,rc.d脚本不能自动重启崩溃的进程,许多程序在崩溃时不能正确重启自己。Supervisor将进程作为子进程启动,并且可以配置为在崩溃时自动重启它们。它还可以自动配置为在自己的调用上启动进程。

  • 精准

        通常很难在UNIX上准确地获得进程的运行/停止状态。Pidfiles表现是不准确的。Supervisor以子进程的形式启动进程,因此它总是知道其子进程的真正运行/停止状态,并且可以方便地查看这些数据。

  • 托管

        我们不希望或不需要完整的shell访问进程运行的机器。在底层TCP端口上侦听的进程通常需要作为根用户启动和重新启动(UNIX的一个错误特性)。通常情况下,允许普通用户停止或重启这样的进程是完全可以的,但是为他们提供shell访问通常是不切实际的,而为他们提供根访问或sudo访问通常是不可能的。向他们解释为什么会存在这个问题也是困难的。如果将Supervisor作为根用户启动,就有可能允许普通用户控制此类流程,而不需要向他们解释问题的复杂性。通过从一个简单的shell或web UI发出“stop”、“start”和“restart”命令,Supervisorctl允许对机器进行非常有限的访问,基本上允许用户查看进程状态并控制受监视控制的子进程。

  • 进程组

        Supervisor通过进程组管理进程,进程常常需要在组中启动和停止,甚至可以按“优先顺序”启动和停止。Supervisor允许您为进程分配优先级,并允许用户通过监控管理客户端发出“start all”和“restart all”等命令,这些命令按照预先分配的优先级顺序启动进程。此外,可以将流程分组为“流程组”,并且可以作为一个单元停止和启动一组逻辑相关的流程。

Supervisor特性

  • 简单

    Supervisor是通过一个简单的ini风格的配置文件来配置的,很容易学习。它提供了许多进程选项,使您的工作更容易,例如重新启动失败的进程和自动日志循环。

  • 一站式

    Supervisor提供了一个开始、停止和监视流程的控制台。进程可以单独控制,也可以分组控制。可以通过配置Supervisor提供本地或远程命令行和web界面。

  • 高效

    Supervisor通过fork/exec启动它的子进程,而不是守护。当进程终止时,操作系统立即向Supervisor发出信号,这与某些解决方案不同,这些解决方案依赖于容易出错的的PID文件和定期轮询来重启失败的进程。

  • 可扩展

    Supervisor有一个简单的事件通知协议,用任何语言编写的程序都可以使用它来监视它,还有一个XML-RPC接口用于控制。它也可以由Python开发人员利用扩展点构建。

  • 兼容性

    Supervisor除了windows系统,其他系统均可以使用。它在Linux、Mac OS X、Solaris和FreeBSD上均得到了测试和支持。它完全用Python编写,所以安装不需要C编译器。

  • 可靠

    虽然Supervisor在今天被非常积极的开发,但是它并不是一个新的软件。Supervisor已经存在多年,并且已经在许多服务器上使用。

Supervisor组件

supervisord

    Supervisor服务部分叫做Supervisord。它负责自己调用时启动子程序,响应来自客户机的命令,重新启动崩溃或退出的子进程,记录子进程挂掉和崩溃的输出,并生成和处理与子进程生命周期中的点对应的“事件”。

    它使用了一个配置文件。配置文件通常位于/etc/supervision.conf中。这个配置文件是一个“Windows-INI”风格的配置文件。通过适当的文件系统权限保持该文件的安全性非常重要,因为它可能包含未加密的用户名和密码。

    通俗点讲就是Supervisor的处理器

supervisorctl

    supervisorctl是Supervisor命令行客户端.它提供了一个类shell的接口,用于管理Supervisor提供的特性.用户可以连接到不同的监控器进程(一次一个),获取受控子进程的状态,停止和启动的子进程,以及监控器的运行进程列表。

    通俗点讲就是Supervisor的命令工具

Web Server

    如果配置中启动了这个模块,就可以通过浏览器访问具有与supervisorctl类似功能的web用户界面。在配置文件的[inet_http_server]部分开启,访问服务器URL(例如http://localhost:9001/),通过web接口查看和控制进程状态。

    通俗点讲就是一个可视化界面,可以在界面操作进程

XML-RPC Interface

    web UI基于XML-RPC接口服务,该接口可用于询问和控制Supervisor及其运行的程序

平台需求

    Supervisor经过测试,可以在Linux (Ubuntu 9.10)、Mac OS X(10.4/10.5/10.6)、Solaris (10 for Intel)和FreeBSD 6.1上运行。它在大多数UNIX系统上都可以很好地工作。但是他不能在windows平台下运行

    Supervisor可以使用Python 2.4或更高版本,但不能在Python 3的任何版本下工作。

11-30 21:56