目录
概述 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特性 简单public static IServiceCollection AddIds4(this IServiceCollection @this)
2 { 3 @this 4 .AddAuthentication() 5 .AddQQConnect(www.dfgjpt.com"qq", "QQ Connect", SetQQConnectOptions) 6 .AddGithub("github", www.michenggw.com/"Github"www.mhylpt.com, SetGithubOptions); 7 8 @this 9 .AddIdentityServer(SetIdentityServerOptions)10 .AddDeveloperSigningCredential(www.gcyL157.com)11 .AddInMemoryIdentityResources(Resources.AllIdentityResources)12 .AddInMemoryApiResources(Resources.AllApiResources)13 .AddInMemoryClients(Clients.All)14 .AddTestUsers(Users.All);15 16 return @this; 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的任何版本下工作。