进程管理利器Supervisor--入门简介
发布日期:2021-09-11 05:52:51 浏览次数:9 分类:技术文章

本文共 3465 字,大约阅读时间需要 11 分钟。

  目录

  
  概述
  
  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的任何版本下工作。

转载地址:https://blog.csdn.net/weixin_34406061/article/details/86028306 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!

上一篇:mysql 比较函数和操作符
下一篇:工控随笔_15_西门子_WinCC的VBS脚本_05_变量类型之三_VBS数组

发表评论

最新留言

感谢大佬
[***.8.128.20]2024年04月03日 11时24分48秒