Deprecated: htmlspecialchars(): Passing null to parameter #1 ($string) of type string is deprecated in /webData/hua/www.ascwh.com/var/Typecho/Feed.php on line 221
ASCWH - supervisor https://ascwh.com/tag/supervisor/ CentOS7 安装 、配置 Supervisor 基础操作 https://ascwh.com/399.html 2022-05-21T00:50:00+08:00 Supervisor是什么Supervisor是比较常用的进程管理工具,支持 Linux/MacOS平台,可以用来控制一组Linux/Unix进程(启动、重启、kill)等,使用Supervisor管理的进程,可以做到以守护进程的方式运行,服务异常关闭后可以自动重启。Supervisor是一个 Client/Server模式的系统,允许用户在类unix操作系统上监视和控制多个进程,或者可以说是多个程序。Supervisor 有下面几个组件:supervisord: Supervisor的服务端程序,使用前,需要先启动该组件;supervisorctl: Supervisor的客户端程序,用来实际控制子进程(自定义的服务、程序);Supervisor 通过配置文件,还可以启动Web控制台,通过Web页面来管理子进程;Supervisor 与系统自带 init 进程管理比较方便:有些编译运行的程序,在安装完成后,需要为他们编写启动停止管理脚本,写入和维护可能很痛苦,而且进程在异常崩溃结束时,许多程序都不会正确重新启动的。Supervisord启动管理的程序进程是作为其子进程来运行的,并且可以配置为在进程崩溃停止时自动重新启动它们。准确:在Unix上的进程通常很难获得准确的up/down状态。Pidfiles经常说谎。Supervisord 将进程作为子进程启动,所以它总是知道其子进程的正确的up/down状态,可以方便的对这些数据进行查询。进程分组:进程支持分组启动和停止,也支持启动顺序,即‘优先级’,supervisor允许为进程分配优先级,并允许用户通过supervisorctl客户端发出命令,如“全部启动”和”重新启动所有“,它们以预先分配的优先级顺序启动。还可以将进程分为”进程组“,一组逻辑关联的进程可以作为一个单元停止或启动。Supervisor 特点简单:supervisor通过简单的INI风格的配置文件进行配置管理,易于学习,并提供了许多每个进程选项,如重新启动失败的进程和日志的自动切割。集中:supervisor提供一个start、stop和监控进程的地方,进程可以单独或分组进行控制。可以通过supervisor的本地或远程命令行管理和web管理(一般为了安全,web通常需要禁用)高效:supervisor通过fork/exec启动子进程,子进程需要前台运行,操作系统进程终止时去通知supervisor,而不像一些我们需要写脚本去定期轮询PID文件来重新启动失败的进程。可扩展:supervisor有一个简单的事件(event)通知协议,还有一个用于控制的XML-RPC接口,可以用Python开发人员来扩展构建。兼容:supervisor由Python编写,在除Windows操作系统以外基本都支持,如linux,Mac OS x,solaris,FreeBSD系统。Supervisor 组建构成supervisord:supervisor服务器的进程名是supervisord。它主要负责在自己的调用中启动子程序,响应客户端的命令,重新启动崩溃或退出的进程,记录其子进程stdout和stderr的输出,以及生成和处理对应于子进程生命周期中的”event“。服务器进程使用的配置文件,通常路径存放在 /etc/supervisord.conf 中。此配置文件是INI格式的配置文件。supervisorctl:supervisor命令行的客户端名称是supervisorctl。它为supervisord提供了一个类似于shell的交互界面。使用supervisorctl,用户可以查看不同的supervisord进程列表,获取控制子进程的状态,如停止和启动子进程。web服务器:一个可以通过Web界面来查看和控制进程的状态,默认监听在9001上。1、安装以及服务启动yum install epel-release # 安装企业版 Linux 附加软件包(EPEL) yum install -y supervisor # yum 安装 supervisor systemctl enable supervisord # 开机自启动 systemctl start supervisord # 启动supervisord服务(服务端) systemctl status supervisord # 查看supervisord服务状态(服务端) ps -ef|grep supervisord # 查看是否存在supervisord进程 生成配置文件用supervisor自带命令生成一个标准的配置文件/usr/bin/echo_supervisord_conf > /etc/supervisord.conf~]# cat /etc/supervisord.conf ; Sample supervisor config file. ; ; For more information on the config file, please see: ; http://supervisord.org/configuration.html ; ; Notes: ; - Shell expansion ("~" or "$HOME") is not supported. Environment ; variables can be expanded using this syntax: "%(ENV_HOME)s". ; - Comments must have a leading space: "a=b ;comment" not "a=b;comment". [unix_http_server] file=/tmp/supervisor.sock ; (socket 文件的路径) ;chmod=0700 ; socket 文件权限 (default 0700) ;chown=nobody:nogroup ; socket 文件属主:属组 ;username=user ; (启动http的用户 (open server)) ;password=123 ; (默认的密码 (open server)) ;[inet_http_server] ; 默认禁用tcp监听的http 服务 ;port=127.0.0.1:9001 ; (指定监听在本机ip地址和端口) ;username=user ; (默认启动http服务的用户) ;password=123 ; (默认的密码) [supervisord] logfile=/tmp/supervisord.log ; (主日志文件的存放位置,默认在程序的工作启动目录) logfile_maxbytes=50MB ; (主日志文件的最大值,之后进行切割;默认 50MB) logfile_backups=10 ; (主日志文件备份的数目;默认 10) loglevel=info ; (日志级别;默认是info; 其它: debug,warn,trace) pidfile=/tmp/supervisord.pid ; (supervisord 运行时的pidfile路径;默认 supervisord.pid) nodaemon=false ; (如果为true,程序就以前台运行;默认是 false) minfds=1024 ; (min. 启动有效的文件描述符数目;默认 1024) minprocs=200 ; (min. 有效进程描述符;默认 200) ;umask=022 ; (进程文件创建的默认权限;默认 022) ;user=chrism ; (默认是当前启动的用户) ;identifier=supervisor ; (supervisord 标识符, 默认是'supervisor') ;directory=/tmp ; (默认启动时间不会切换) ;nocleanup=true ; (在启动时不清理临时文件;默认值为false) ;childlogdir=/tmp ; ('AUTO' 子进程日志目录, 默认 $TEMP) ;environment=KEY="value" ; (增加一个环境变量键值对:key=”value“) ;strip_ansi=false ; (在log日志里去掉ansi转义编码; 默认是 false) ; 下面的部分选项必须保留在RPC的配置文件中 ; (supervisorctl/web 接口) 使用以下配置来管理 ; added by defining them in separate rpcinterface: sections [rpcinterface:supervisor] supervisor.rpcinterface_factory = supervisor.rpcinterface:make_main_rpcinterface [supervisorctl] serverurl=unix:///tmp/supervisor.sock ; use a unix:// URL for a unix socket ;serverurl=http://127.0.0.1:9001 ; use an http:// url to specify an inet socket ;username=chris ; should be same as http_username if set ;password=123 ; should be same as http_password if set ;prompt=mysupervisor ; cmd line prompt (default "supervisor") ;history_file=~/.sc_history ; use readline history if available ; 以下是被管理的示例程序显示所有可能用到的配置。 ; 创建一个或“多个”程序: 要遵循以下的键值对规则。 ; supervisor. ;[program:theprogramname] ;command=/bin/cat ; 程序的启动命令 (使用绝对路径) ;process_name=%(program_name)s ; process_name 表示 (默认是 %(program_name)s) ;numprocs=1 ; 启动时的进程数 (默认 1) ;directory=/tmp ; 执行时切换到的目录 (def no cwd) ;umask=022 ; umask for process (default None) ;priority=999 ; 相对启动优先级(default 999) ;autostart=true ; 是否跟随supervisord程序启动该监控程序 (default: true) ;startsecs=1 ; # 在设定时间内,程序必须保持运行 (def. 1) ;startretries=3 ; 当启动失败时尝试的最大次数(default 3) ;autorestart=unexpected ; 如果退出后,什么状态退出的去重启,默认非意外的(def: unexpected) ;exitcodes=0,2 ; 'expected' 符合退出代码之后去重启 (default 0,2) ;stopsignal=QUIT ; 用于杀死进程的信号 (default TERM) ;stopwaitsecs=10 ; 最大等待秒数 SIGKILL (default 10) ;stopasgroup=false ; 发送停止信号到Unix进程组 (default false) ;killasgroup=false ; SIGKILL UNIX进程组 (def false) ;user=chrism ; setuid to this UNIX account to run the program ;redirect_stderr=true ; 是否开启程序标准错误输出的重定向 (default false) ;stdout_logfile=/a/path ; 标准输出路径; default AUTO ;stdout_logfile_maxbytes=1MB ; 文件最大大小 # 日志文件进行切割 (default 50MB) ;stdout_logfile_backups=10 ; # 日志文件备份数目 (default 10) ;stdout_capture_maxbytes=1MB ; ‘捕获模式’中的字节数 (default 0) ;stdout_events_enabled=false ; 在标准输出写入文件时发出事件 (default false) ;stderr_logfile=/a/path ; 标准错误输出, NONE for none; default AUTO ;stderr_logfile_maxbytes=1MB ; 文件最大大小 # logfile bytes b4 rotation (default 50MB) ;stderr_logfile_backups=10 ; # of stderr logfile backups (default 10) ;stderr_capture_maxbytes=1MB ; number of bytes in 'capturemode' (default 0) ;stderr_events_enabled=false ; emit events on stderr writes (default false) ;environment=A="1",B="2" ; 添加进程环境变量 (def no adds) ;serverurl=AUTO ; 覆盖serverurl计算 (childutils) ;下面是event事件部分所有可能设置的值,大部分同上面一样。 ; eventlistener subsection values, create one or more 'real' ; eventlistener: sections to be able to handle event notifications ; sent by supervisor. ;[eventlistener:theeventlistenername] ;command=/bin/eventlistener ; the program (relative uses PATH, can take args) ;process_name=%(program_name)s ; process_name expr (default %(program_name)s) ;numprocs=1 ; number of processes copies to start (def 1) ;events=EVENT ; event notif. types to subscribe to (req'd) ;buffer_size=10 ; event buffer queue size (default 10) ;directory=/tmp ; directory to cwd to before exec (def no cwd) ;umask=022 ; umask for process (default None) ;priority=-1 ; the relative start priority (default -1) ;autostart=true ; start at supervisord start (default: true) ;startsecs=1 ; # of secs prog must stay up to be running (def. 1) ;startretries=3 ; max # of serial start failures when starting (default 3) ;autorestart=unexpected ; autorestart if exited after running (def: unexpected) ;exitcodes=0,2 ; 'expected' exit codes used with autorestart (default 0,2) ;stopsignal=QUIT ; signal used to kill process (default TERM) ;stopwaitsecs=10 ; max num secs to wait b4 SIGKILL (default 10) ;stopasgroup=false ; send stop signal to the UNIX process group (default false) ;killasgroup=false ; SIGKILL the UNIX process group (def false) ;user=chrism ; setuid to this UNIX account to run the program ;redirect_stderr=false ; redirect_stderr=true is not allowed for eventlisteners ;stdout_logfile=/a/path ; stdout log path, NONE for none; default AUTO ;stdout_logfile_maxbytes=1MB ; max # logfile bytes b4 rotation (default 50MB) ;stdout_logfile_backups=10 ; # of stdout logfile backups (default 10) ;stdout_events_enabled=false ; emit events on stdout writes (default false) ;stderr_logfile=/a/path ; stderr log path, NONE for none; default AUTO ;stderr_logfile_maxbytes=1MB ; max # logfile bytes b4 rotation (default 50MB) ;stderr_logfile_backups=10 ; # of stderr logfile backups (default 10) ;stderr_events_enabled=false ; emit events on stderr writes (default false) ;environment=A="1",B="2" ; process environment additions ;serverurl=AUTO ; override serverurl computation (childutils) ; The below sample group section shows all possible group values, ; create one or more 'real' group: sections to create "heterogeneous" ; process groups. ;[group:thegroupname] ;programs=progname1,progname2 ; 这里的progname1,progname2就是定义的监控管理程序的名字,如[program:x]这里就是x ;priority=999 ; the relative start priority (default 999) ; 下面的 [include] 选项只能包含一个files 设置,功能是定义supervisor管理程序的配置文件,可以单独的移除去,和主配置文件分开,方便。; setting can list multiple files (separated by whitespace or ; newlines). It can also contain wildcards. The filenames are ; interpreted as relative to this file. Included files *cannot* ; include files themselves. ;[include] ;files = relative/directory/*.ini ;定义管理监控程序的配置文件的路径管理命令supervisorctl status # 查看所有进程的状态 supervisorctl stop program_name # 停止 supervisorctl start program_name # 启动 supervisorctl restart program_name # 重启某个程序 supervisorctl stop all # 停止所有 supervisorctl reload # 重新启动配置中的所有程序 supervisorctl update # 更新新的配置到supervisord supervisord -c /etc/supervisord.conf # yum 安装后,启动默认方式 supervisorctl start/stop/restart/status group # 管理所有属于名为 group 这个分组的进程 supervisorctl start/stop/restart/status group:name1 # 管理分组里指定的进程添加配置实例; 设置进程的名称,使用 supervisorctl 来管理进程时需要使用该进程名 我这里就叫做nginx了! [program:nginx] ; 需要执行的命令 command=/usr/sbin/nginx -g 'daemon off;' ; 命令执行的目录或者说执行 command 之前,先切换到工作目录 可以理解为在执行命令前会切换到这个目录 在我这基本没啥用 directory=/etc/nginx ; 是否自动启动 autostart=true ; 程序意外退出是否自动重启 autorestart=true ; 如果为true,则stderr的日志会被写入stdout日志文件中, 理解为重定向输出的日志 redirect_stderr=true ; 启动优先级 越大优先级越高 priority=10 ; 子进程的stdout的日志路径 输出日志文件,如果日志路径不存在,会导致无法启动错误 stdout_logfile=/data/logs/supervisord/nginx.log ; 错误日志文件 当 redirect_stderr=true 时,stderr_logfile就不用 stderr_logfile=/data/logs/supervisord/nginx.err.log 修改后,更新 supervisor supervisorctl reread # 重新读取配置 supervisorctl update # 更新配置 supervisorctl restart nginx # 重启 nginx killall nginx # 杀掉所有的 nginx 进程. 已经杀不死了 说明守护进程配置成功宝塔Supervisor管理器生成实例[program:test-call-serve-excel] command=redis xxxxxxx directory=/www/wwwroot/test-call autorestart=true startsecs=3 startretries=3 stdout_logfile=/www/server/panel/plugin/supervisor/log/test-serve.out.log stderr_logfile=/www/server/panel/plugin/supervisor/log/test-serve.err.log stdout_logfile_maxbytes=2MB stderr_logfile_maxbytes=2MB user=www priority=999 numprocs=4 process_name=%(program_name)s_%(process_num)02d think-queue (消息队列结合supervisor进程管理实现队列常驻进程 https://ascwh.com/385.html 2021-01-26T22:41:44+08:00 具体操作think-queue+supervisor 详细配置 https://www.jianshu.com/p/d5e95c7ae526supervisor配置信息 https://www.jianshu.com/p/0b9054b33db3