supervisor监控php进程程序,详解Supervisor进程守护监控(转)

Supervisor的配置

2.0 创建目录,初始化配置文件

mkdir /usr/supervisor

echo_supervisord_conf > /usr/supervisor/supervisord.conf

1

2

mkdir/usr/supervisor

echo_supervisord_conf>/usr/supervisor/supervisord.conf

echo_supervisord_conf详解:

echo_supervisord_conf详解

[root@centos-011 ~ 07:50:00]#cat /etc/supervisord.conf.bak

; Sample supervisor config file.

[unix_http_server]

file=/var/run/supervisor/supervisor.sock ; socket 路径

;chmod=0700 ; socket 文件的权限

;chown=nobody:nogroup ; socket 所属用户及组

;username=user ; 用户名

;password=123 ; 密码

;[inet_http_server] ; 是否启用服务,默认是关闭的(启用的话可以看到supervisor 管理的服务状态)

;port=127.0.0.1:9001 ; 监听的IP及端口

;username=user ; 用户名

;password=123 ; 密码

[supervisord] ; supervisord 全局配置

logfile=/var/log/supervisor/supervisord.log ; supervisor 日志路径

logfile_maxbytes=50MB ; 单个日志文件最大数

logfile_backups=10 ; 保留多少个日志文件(默认10个)

loglevel=info ; (log level;default info; others: debug,warn,trace)

pidfile=/var/run/supervisord.pid ; pid 文件路径

nodaemon=false ; 启动是否丢到前台,设置为false ,表示以daemon 的方式启动

minfds=1024 ; 最小文件打开数,对应系统limit.conf 中的nofile ,默认最小为1024,最大为4096

minprocs=200 ; 最小的进程打开数,对应系统的limit.conf 中的nproc,默认为200

;umask=022 ; (process file creation umask;default 022)

;user=chrism ; 启动supervisord 服务的用户,默认为root

;identifier=supervisor ; (supervisord identifier, default is 'supervisor')

;directory=/tmp ; 这里的目录指的是服务的工作目录

;nocleanup=true ; (don't clean up tempfiles at start;default false)

;childlogdir=/tmp ; ('AUTO' child log dir, default $TEMP)

;environment=KEY=value ; (key value pairs to add to environment)

;strip_ansi=false ; (strip ansi escape codes in logs; def. false)

; the below section must remain in the config file for RPC

; (supervisorctl/web interface) to work, additional interfaces may be

; added by defining them in separate rpcinterface: sections

[rpcinterface:supervisor]

supervisor.rpcinterface_factory = supervisor.rpcinterface:make_main_rpcinterface

[supervisorctl]

serverurl=unix:///var/run/supervisor/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

; The below sample program section shows all possible program subsection values,

; create one or more 'real' program: sections to be able to control them under

; supervisor.

;[program:theprogramname] ; 定义一个守护进程 ,比如下面的elasticsearch

;command=/bin/cat ; 启动程序使用的命令,可以是绝对路径或者相对路径

;process_name=%(program_name)s ; 一个python字符串表达式,用来表示supervisor进程启动的这个的名称,默认值是%(program_name)s

;numprocs=1 ; Supervisor启动这个程序的多个实例,如果numprocs>1,则process_name的表达式必须包含%(process_num)s,默认是1

;directory=/tmp ; supervisord在生成子进程的时候会切换到该目录

;umask=022 ; umask for process (default None)

;priority=999 ; 权重,可以控制程序启动和关闭时的顺序,权重越低:越早启动,越晚关闭。默认值是999

;autostart=true ; 如果设置为true,当supervisord启动的时候,进程会自动启动

;autorestart=true ; 设置为随 supervisord 重启而重启,值可以是false、true、unexpected。false:进程不会自动重启

;startsecs=10 ; 程序启动后等待多长时间后才认为程序启动成功,默认是10秒

;startretries=3 ; supervisord尝试启动一个程序时尝试的次数。默认是3

;exitcodes=0,2 ; 一个预期的退出返回码,默认是0,2。

;stopsignal=QUIT ; 当收到stop请求的时候,发送信号给程序,默认是TERM信号,也可以是 HUP, INT, QUIT, KILL, USR1, or USR2

;stopwaitsecs=10 ; 在操作系统给supervisord发送SIGCHILD信号时等待的时间

;user=chrism ; 如果supervisord以root运行,则会使用这个设置用户启动子程序

;redirect_stderr=true ; 如果设置为true,进程则会把标准错误输出到supervisord后台的标准输出文件描述符

;stdout_logfile=/a/path ; 把进程的标准输出写入文件中,如果stdout_logfile没有设置或者设置为AUTO,则supervisor会自动选择一个文件位置

;stdout_logfile_maxbytes=1MB ; 标准输出log文件达到多少后自动进行轮转,单位是KB、MB、GB。如果设置为0则表示不限制日志文件大小

;stdout_logfile_backups=10 ; 标准输出日志轮转备份的数量,默认是10,如果设置为0,则不备份

;stdout_capture_maxbytes=1MB ; 当进程处于stderr capture mode模式的时候,写入FIFO队列的最大bytes值,单位可以是KB、MB、GB

;stdout_events_enabled=false ; 如果设置为true,当进程在写它的stderr

;stderr_logfile=/a/path ; 把进程的错误日志输出一个文件中,除非redirect_stderr参数被设置为true

;stderr_logfile_maxbytes=1MB ; 错误log文件达到多少后自动进行轮转,单位是KB、MB、GB。如果设置为0则表示不限制日志文件大小

;stderr_logfile_backups=10 ; 错误日志轮转备份的数量,默认是10,如果设置为0,则不备份

;stderr_capture_maxbytes=1MB ; 当进程处于stderr capture mode模式的时候,写入FIFO队列的最大bytes值,单位可以是KB、MB、GB

;stderr_events_enabled=false ; 如果设置为true,当进程在写它的stderr到文件描述符的时候,PROCESS_LOG_STDERR事件会被触发

;environment=A=1,B=2 ; 一个k/v对的list列表

;serverurl=AUTO ; 是否允许子进程和内部的HTTP服务通讯,如果设置为AUTO,supervisor会自动的构造一个url

; The below sample eventlistener section shows all possible

; eventlistener subsection values, create one or more 'real'

; eventlistener: sections to be able to handle event notifications

; sent by supervisor.

#这个地方是自定义一个守护进程

[program:elasticsearch] ; 定义一个守护进程 elasticsearch

environment=ES_HOME=/usr/local/elasticsearch ; 设置ES_HOME 环境变量

user=elk ; 启动elasticsearch 的用户

directory=/usr/local/elasticsearch ; 进入到这个目录中

command=/usr/local/elasticsearch/bin/elasticsearch ; 执行启动命令

numprocs=1 ; Supervisor启动这个程序的多个实例,如果numprocs>1,则process_name的表达式必须包含%(process_num)s,默认是1

autostart=true ; 设置为随 supervisord 启动而启动

autorestart=true ; 设置为随 supervisord 重启而重启

startretries=3 ; 设置elasticsearch 重启的重试次数

priority=1 ; 权重,可以控制程序启动和关闭时的顺序,权重越低:越早启动,越晚关闭。默认值是999

;[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)

;autorestart=unexpected ; restart at unexpected quit (default: unexpected)

;startsecs=10 ; number of secs prog must stay running (def. 1)

;startretries=3 ; max # of serial start failures (default 3)

;exitcodes=0,2 ; 'expected' exit codes for process (default 0,2)

;stopsignal=QUIT ; signal used to kill process (default TERM)

;stopwaitsecs=10 ; max num secs to wait b4 SIGKILL (default 10)

;user=chrism ; setuid to this UNIX account to run the program

;redirect_stderr=true ; redirect proc stderr to stdout (default false)

;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 ; # 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 ; 上面配置好的服务名,比如elasticsearch,kibana,logstash

;priority=999 ; the relative start priority (default 999)

; The [include] section can just contain the "files" setting. This

; 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 = supervisord.d/*.ini

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84

85

86

87

88

89

90

91

92

93

94

95

96

97

98

99

100

101

102

103

104

105

106

107

108

109

110

111

112

113

114

115

116

117

118

119

120

121

122

123

124

125

126

127

128

129

130

131

132

133

134

135

136

137

138

139

140

141

142

[root@centos-011~07:50:00]#cat /etc/supervisord.conf.bak

;Samplesupervisorconfigfile.

[unix_http_server]

file=/var/run/supervisor/supervisor.sock;socket路径

;chmod=0700;socket文件的权限

;chown=nobody:nogroup;socket所属用户及组

;username=user;用户名

;password=123;密码

;[inet_http_server];是否启用服务,默认是关闭的(启用的话可以看到supervisor管理的服务状态)

;port=127.0.0.1:9001;监听的IP及端口

;username=user;用户名

;password=123;密码

[supervisord];supervisord全局配置

logfile=/var/log/supervisor/supervisord.log;supervisor日志路径

logfile_maxbytes=50MB;单个日志文件最大数

logfile_backups=10;保留多少个日志文件(默认10个)

loglevel=info;(loglevel;defaultinfo;others:debug,warn,trace)

pidfile=/var/run/supervisord.pid;pid文件路径

nodaemon=false;启动是否丢到前台,设置为false,表示以daemon的方式启动

minfds=1024;最小文件打开数,对应系统limit.conf中的nofile,默认最小为1024,最大为4096

minprocs=200;最小的进程打开数,对应系统的limit.conf中的nproc,默认为200

;umask=022;(processfilecreationumask;default022)

;user=chrism;启动supervisord服务的用户,默认为root

;identifier=supervisor;(supervisordidentifier,defaultis'supervisor')

;directory=/tmp;这里的目录指的是服务的工作目录

;nocleanup=true;(don't clean up tempfiles at start;default false)

;childlogdir=/tmp            ; ('AUTO' child log dir, default $TEMP)

;environment=KEY=value       ; (key value pairs to add to environment)

;strip_ansi=false            ; (strip ansi escape codes in logs; def. false)

; the below section must remain in the config file for RPC

; (supervisorctl/web interface) to work, additional interfaces may be

; added by defining them in separate rpcinterface: sections

[rpcinterface:supervisor]

supervisor.rpcinterface_factory = supervisor.rpcinterface:make_main_rpcinterface

[supervisorctl]

serverurl=unix:///var/run/supervisor/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

; The below sample program section shows all possible program subsection values,

; create one or more 'real' program: sections to be able to control them under

; supervisor.

;[program:theprogramname]      ; 定义一个守护进程 ,比如下面的elasticsearch

;command=/bin/cat              ; 启动程序使用的命令,可以是绝对路径或者相对路径

;process_name=%(program_name)s ; 一个python字符串表达式,用来表示supervisor进程启动的这个的名称,默认值是%(program_name)s

;numprocs=1                    ; Supervisor启动这个程序的多个实例,如果numprocs>1,则process_name的表达式必须包含%(process_num)s,默认是1

;directory=/tmp                ; supervisord在生成子进程的时候会切换到该目录

;umask=022                     ; umask for process (default None)

;priority=999                  ; 权重,可以控制程序启动和关闭时的顺序,权重越低:越早启动,越晚关闭。默认值是999

;autostart=true                ; 如果设置为true,当supervisord启动的时候,进程会自动启动

;autorestart=true              ; 设置为随 supervisord 重启而重启,值可以是false、true、unexpected。false:进程不会自动重启

;startsecs=10                  ; 程序启动后等待多长时间后才认为程序启动成功,默认是10秒

;startretries=3                ; supervisord尝试启动一个程序时尝试的次数。默认是3

;exitcodes=0,2                 ; 一个预期的退出返回码,默认是0,2。

;stopsignal=QUIT               ; 当收到stop请求的时候,发送信号给程序,默认是TERM信号,也可以是 HUP, INT, QUIT, KILL, USR1, or USR2

;stopwaitsecs=10               ; 在操作系统给supervisord发送SIGCHILD信号时等待的时间

;user=chrism                   ; 如果supervisord以root运行,则会使用这个设置用户启动子程序

;redirect_stderr=true          ; 如果设置为true,进程则会把标准错误输出到supervisord后台的标准输出文件描述符

;stdout_logfile=/a/path        ; 把进程的标准输出写入文件中,如果stdout_logfile没有设置或者设置为AUTO,则supervisor会自动选择一个文件位置

;stdout_logfile_maxbytes=1MB   ; 标准输出log文件达到多少后自动进行轮转,单位是KB、MB、GB。如果设置为0则表示不限制日志文件大小

;stdout_logfile_backups=10     ; 标准输出日志轮转备份的数量,默认是10,如果设置为0,则不备份

;stdout_capture_maxbytes=1MB   ; 当进程处于stderr capture mode模式的时候,写入FIFO队列的最大bytes值,单位可以是KB、MB、GB

;stdout_events_enabled=false   ; 如果设置为true,当进程在写它的stderr

;stderr_logfile=/a/path        ; 把进程的错误日志输出一个文件中,除非redirect_stderr参数被设置为true

;stderr_logfile_maxbytes=1MB   ; 错误log文件达到多少后自动进行轮转,单位是KB、MB、GB。如果设置为0则表示不限制日志文件大小

;stderr_logfile_backups=10     ; 错误日志轮转备份的数量,默认是10,如果设置为0,则不备份

;stderr_capture_maxbytes=1MB   ; 当进程处于stderr capture mode模式的时候,写入FIFO队列的最大bytes值,单位可以是KB、MB、GB

;stderr_events_enabled=false   ; 如果设置为true,当进程在写它的stderr到文件描述符的时候,PROCESS_LOG_STDERR事件会被触发

;environment=A=1,B=2           ; 一个k/v对的list列表

;serverurl=AUTO                ; 是否允许子进程和内部的HTTP服务通讯,如果设置为AUTO,supervisor会自动的构造一个url

; The below sample eventlistener section shows all possible

; eventlistener subsection values, create one or more 'real'

; eventlistener: sections to be able to handle event notifications

; sent by supervisor.

#这个地方是自定义一个守护进程

[program:elasticsearch]                       ; 定义一个守护进程 elasticsearch

environment=ES_HOME=/usr/local/elasticsearch  ; 设置ES_HOME 环境变量

user=elk                                      ; 启动elasticsearch 的用户

directory=/usr/local/elasticsearch            ; 进入到这个目录中

command=/usr/local/elasticsearch/bin/elasticsearch ; 执行启动命令

numprocs=1                                    ; Supervisor启动这个程序的多个实例,如果numprocs>1,则process_name的表达式必须包含%(process_num)s,默认是1

autostart=true                                ; 设置为随 supervisord 启动而启动

autorestart=true                              ; 设置为随 supervisord 重启而重启

startretries=3                                ; 设置elasticsearch 重启的重试次数

priority=1                                    ; 权重,可以控制程序启动和关闭时的顺序,权重越低:越早启动,越晚关闭。默认值是999

;[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;eventbufferqueuesize(default10)

;directory=/tmp;directorytocwdtobeforeexec(defnocwd)

;umask=022;umaskforprocess(defaultNone)

;priority=-1;therelativestartpriority(default-1)

;autostart=true;startatsupervisordstart(default:true)

;autorestart=unexpected;restartatunexpectedquit(default:unexpected)

;startsecs=10;numberofsecsprogmuststayrunning(def.1)

;startretries=3;max# of serial start failures (default 3)

;exitcodes=0,2;'expected'exitcodesforprocess(default0,2)

;stopsignal=QUIT;signalusedtokillprocess(defaultTERM)

;stopwaitsecs=10;maxnumsecstowaitb4SIGKILL(default10)

;user=chrism;setuidtothisUNIXaccounttoruntheprogram

;redirect_stderr=true;redirectprocstderrtostdout(defaultfalse)

;stdout_logfile=/a/path;stdoutlogpath,NONEfornone;defaultAUTO

;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;emiteventsonstdoutwrites(defaultfalse)

;stderr_logfile=/a/path;stderrlogpath,NONEfornone;defaultAUTO

;stderr_logfile_maxbytes=1MB;max# logfile bytes b4 rotation (default 50MB)

;stderr_logfile_backups;# of stderr logfile backups (default 10)

;stderr_events_enabled=false;emiteventsonstderrwrites(defaultfalse)

;environment=A=1,B=2;processenvironmentadditions

;serverurl=AUTO;overrideserverurlcomputation(childutils)

;Thebelowsamplegroupsectionshowsallpossiblegroupvalues,

;createoneormore'real'group:sectionstocreate"heterogeneous"

;processgroups.

;[group:thegroupname];服务组管理,可以将多个服务名写到这里管理(组名自定义)

;programs=progname1,progname2;上面配置好的服务名,比如elasticsearch,kibana,logstash

;priority=999;therelativestartpriority(default999)

;The[include]sectioncanjustcontainthe"files"setting.This

;settingcanlistmultiplefiles(separatedbywhitespaceor

;newlines).Itcanalsocontainwildcards.Thefilenamesare

;interpretedasrelativetothisfile.Includedfiles *cannot*

;includefilesthemselves.

[include]

files=supervisord.d/*.ini

2.1 为了不将所有新增配置信息全写在一个配置文件里,这里新建一个文件夹

mkdir /usr/supervisor/supervisord.d/

2.2 修改系统配置文件

vim /usr/supervisor/supervisord.conf

2.3 include 2.1中新建的supervisord.d文件夹下所有的conf

[include]

files = /usr/supervisor/supervisord.d/*.conf

1

2

[include]

files=/usr/supervisor/supervisord.d/*.conf

2.4 若需要web查看进程,则去掉[inet_http_server]的注释

[inet_http_server]

port=127.0.0.1:9001 ;IP按需配置

username=user

password=123

1

2

3

4

[inet_http_server]

port=127.0.0.1:9001;IP按需配置

username=user

password=123

运行Supervisor

3.0 启动supervisord

supervisord -c /usr/supervisor/supervisord.conf

1

supervisord-c/usr/supervisor/supervisord.conf

3.1 查看监听

lsof -i:9001

1

lsof-i:9001

a6fff28e2f167c5820fd2784859e15e1.png

到这一步,就可以通过 http://ip:9001/ 查看supervisor的web界面了,只不过目前还没有加入任何监控程序。

5a928905738a3466ba5a66cf91563587.png

3.2 增加一个配置文件,以便supervisor用来监控程序

cat > /usr/supervisor/supervisord.d/supervisor_test_one.conf

在新建的supervisor_test_one.conf文件中添加以下配置

[program:test_one]

command=java -jar /data/smallvideo/supervisor/taskApp-exec.jar TaskTestOne ; 被监控的进程路径

priority=1 ; 数字越高,优先级越高

numprocs=1 ; 启动几个进程

autostart=true ; 随着supervisord的启动而启动

autorestart=true ; 自动重启

startretries=10 ; 启动失败时的最多重试次数

exitcodes=0 ; 正常退出代码

stopsignal=KILL ; 用来杀死进程的信号

stopwaitsecs=10 ; 发送SIGKILL前的等待时间

redirect_stderr=true ; 重定向stderr到stdout

[program:test_two]

command=java -jar /data/smallvideo/supervisor/taskApp-exec.jar TaskTestTwo ; 被监控的进程路径

priority=1 ; 数字越高,优先级越高

numprocs=1 ; 启动几个进程

autostart=true ; 随着supervisord的启动而启动

autorestart=true ; 自动重启

startretries=10 ; 启动失败时的最多重试次数

exitcodes=0 ; 正常退出代码

stopsignal=KILL ; 用来杀死进程的信号

stopwaitsecs=10 ; 发送SIGKILL前的等待时间

redirect_stderr=true ; 重定向stderr到stdout

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

[program:test_one]

command=java-jar/data/smallvideo/supervisor/taskApp-exec.jarTaskTestOne;被监控的进程路径

priority=1;数字越高,优先级越高

numprocs=1;启动几个进程

autostart=true;随着supervisord的启动而启动

autorestart=true;自动重启

startretries=10;启动失败时的最多重试次数

exitcodes=0;正常退出代码

stopsignal=KILL;用来杀死进程的信号

stopwaitsecs=10;发送SIGKILL前的等待时间

redirect_stderr=true;重定向stderr到stdout

[program:test_two]

command=java-jar/data/smallvideo/supervisor/taskApp-exec.jarTaskTestTwo;被监控的进程路径

priority=1;数字越高,优先级越高

numprocs=1;启动几个进程

autostart=true;随着supervisord的启动而启动

autorestart=true;自动重启

startretries=10;启动失败时的最多重试次数

exitcodes=0;正常退出代码

stopsignal=KILL;用来杀死进程的信号

stopwaitsecs=10;发送SIGKILL前的等待时间

redirect_stderr=true;重定向stderr到stdout

3.3 supervisor配置文件详解

- command:启动程序使用的命令,可以是绝对路径或者相对路径

- process_name:一个python字符串表达式,用来表示supervisor进程启动的这个的名称,默认值是%(program_name)s

- numprocs:Supervisor启动这个程序的多个实例,如果numprocs>1,则process_name的表达式必须包含%(process_num)s,默认是1

- numprocs_start:一个int偏移值,当启动实例的时候用来计算numprocs的值

- priority:权重,可以控制程序启动和关闭时的顺序,权重越低:越早启动,越晚关闭。默认值是999

- autostart:如果设置为true,当supervisord启动的时候,进程会自动重启。

- autorestart:值可以是false、true、unexpected。false:进程不会自动重启,unexpected:当程序退出时的退出码不是exitcodes中定义的时,进程会重启,true:进程会无条件重启当退出的时候。

- startsecs:程序启动后等待多长时间后才认为程序启动成功

- startretries:supervisord尝试启动一个程序时尝试的次数。默认是3

- exitcodes:一个预期的退出返回码,默认是0,2。

- stopsignal:当收到stop请求的时候,发送信号给程序,默认是TERM信号,也可以是 HUP, INT, QUIT, KILL, USR1, or USR2。

- stopwaitsecs:在操作系统给supervisord发送SIGCHILD信号时等待的时间

- stopasgroup:如果设置为true,则会使supervisor发送停止信号到整个进程组

- killasgroup:如果设置为true,则在给程序发送SIGKILL信号的时候,会发送到整个进程组,它的子进程也会受到影响。

- user:如果supervisord以root运行,则会使用这个设置用户启动子程序

- redirect_stderr:如果设置为true,进程则会把标准错误输出到supervisord后台的标准输出文件描述符。

- stdout_logfile:把进程的标准输出写入文件中,如果stdout_logfile没有设置或者设置为AUTO,则supervisor会自动选择一个文件位置。

- stdout_logfile_maxbytes:标准输出log文件达到多少后自动进行轮转,单位是KB、MB、GB。如果设置为0则表示不限制日志文件大小

- stdout_logfile_backups:标准输出日志轮转备份的数量,默认是10,如果设置为0,则不备份

- stdout_capture_maxbytes:当进程处于stderr capture mode模式的时候,写入FIFO队列的最大bytes值,单位可以是KB、MB、GB

- stdout_events_enabled:如果设置为true,当进程在写它的stderr到文件描述符的时候,PROCESS_LOG_STDERR事件会被触发

- stderr_logfile:把进程的错误日志输出一个文件中,除非redirect_stderr参数被设置为true

- stderr_logfile_maxbytes:错误log文件达到多少后自动进行轮转,单位是KB、MB、GB。如果设置为0则表示不限制日志文件大小

- stderr_logfile_backups:错误日志轮转备份的数量,默认是10,如果设置为0,则不备份

- stderr_capture_maxbytes:当进程处于stderr capture mode模式的时候,写入FIFO队列的最大bytes值,单位可以是KB、MB、GB

- stderr_events_enabled:如果设置为true,当进程在写它的stderr到文件描述符的时候,PROCESS_LOG_STDERR事件会被触发

- environment:一个k/v对的list列表

- directory:supervisord在生成子进程的时候会切换到该目录

- umask:设置进程的umask

- serverurl:是否允许子进程和内部的HTTP服务通讯,如果设置为AUTO,supervisor会自动的构造一个url

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

-command:启动程序使用的命令,可以是绝对路径或者相对路径

-process_name:一个python字符串表达式,用来表示supervisor进程启动的这个的名称,默认值是%(program_name)s

-numprocs:Supervisor启动这个程序的多个实例,如果numprocs>1,则process_name的表达式必须包含%(process_num)s,默认是1

-numprocs_start:一个int偏移值,当启动实例的时候用来计算numprocs的值

-priority:权重,可以控制程序启动和关闭时的顺序,权重越低:越早启动,越晚关闭。默认值是999

-autostart:如果设置为true,当supervisord启动的时候,进程会自动重启。

-autorestart:值可以是false、true、unexpected。false:进程不会自动重启,unexpected:当程序退出时的退出码不是exitcodes中定义的时,进程会重启,true:进程会无条件重启当退出的时候。

-startsecs:程序启动后等待多长时间后才认为程序启动成功

-startretries:supervisord尝试启动一个程序时尝试的次数。默认是3

-exitcodes:一个预期的退出返回码,默认是0,2。

-stopsignal:当收到stop请求的时候,发送信号给程序,默认是TERM信号,也可以是HUP,INT,QUIT,KILL,USR1,orUSR2。

-stopwaitsecs:在操作系统给supervisord发送SIGCHILD信号时等待的时间

-stopasgroup:如果设置为true,则会使supervisor发送停止信号到整个进程组

-killasgroup:如果设置为true,则在给程序发送SIGKILL信号的时候,会发送到整个进程组,它的子进程也会受到影响。

-user:如果supervisord以root运行,则会使用这个设置用户启动子程序

-redirect_stderr:如果设置为true,进程则会把标准错误输出到supervisord后台的标准输出文件描述符。

-stdout_logfile:把进程的标准输出写入文件中,如果stdout_logfile没有设置或者设置为AUTO,则supervisor会自动选择一个文件位置。

-stdout_logfile_maxbytes:标准输出log文件达到多少后自动进行轮转,单位是KB、MB、GB。如果设置为0则表示不限制日志文件大小

-stdout_logfile_backups:标准输出日志轮转备份的数量,默认是10,如果设置为0,则不备份

-stdout_capture_maxbytes:当进程处于stderrcapturemode模式的时候,写入FIFO队列的最大bytes值,单位可以是KB、MB、GB

-stdout_events_enabled:如果设置为true,当进程在写它的stderr到文件描述符的时候,PROCESS_LOG_STDERR事件会被触发

-stderr_logfile:把进程的错误日志输出一个文件中,除非redirect_stderr参数被设置为true

-stderr_logfile_maxbytes:错误log文件达到多少后自动进行轮转,单位是KB、MB、GB。如果设置为0则表示不限制日志文件大小

-stderr_logfile_backups:错误日志轮转备份的数量,默认是10,如果设置为0,则不备份

-stderr_capture_maxbytes:当进程处于stderrcapturemode模式的时候,写入FIFO队列的最大bytes值,单位可以是KB、MB、GB

-stderr_events_enabled:如果设置为true,当进程在写它的stderr到文件描述符的时候,PROCESS_LOG_STDERR事件会被触发

-environment:一个k/v对的list列表

-directory:supervisord在生成子进程的时候会切换到该目录

-umask:设置进程的umask

-serverurl:是否允许子进程和内部的HTTP服务通讯,如果设置为AUTO,supervisor会自动的构造一个url

监控demotest程序示例:

[program:demotest]

command=python demotest.py 10000 ; 被监控的进程启动命令

directory=/root/ ; 执行前要不要先cd到目录去,一般不用

priority=1 ;数字越高,优先级越高

numprocs=1 ; 启动几个进程

autostart=true ; 随着supervisord的启动而启动

autorestart=true ; 自动重启。。当然要选上了

startretries=10 ; 启动失败时的最多重试次数

exitcodes=0 ; 正常退出代码(是说退出代码是这个时就不再重启了吗?待确定)

stopsignal=KILL ; 用来杀死进程的信号

stopwaitsecs=10 ; 发送SIGKILL前的等待时间

redirect_stderr=true ; 重定向stderr到stdout

1

2

3

4

5

6

7

8

9

10

11

12

[program:demotest]

command=pythondemotest.py10000;被监控的进程启动命令

directory=/root/;执行前要不要先cd到目录去,一般不用

priority=1;数字越高,优先级越高

numprocs=1;启动几个进程

autostart=true;随着supervisord的启动而启动

autorestart=true;自动重启。。当然要选上了

startretries=10;启动失败时的最多重试次数

exitcodes=0;正常退出代码(是说退出代码是这个时就不再重启了吗?待确定)

stopsignal=KILL;用来杀死进程的信号

stopwaitsecs=10;发送SIGKILL前的等待时间

redirect_stderr=true;重定向stderr到stdout

3.4 重启supervisor

supervisorctl -c /usr/supervisor/supervisord.conf

1

supervisorctl-c/usr/supervisor/supervisord.conf

9bf421ccb6eef0f25e0e252529965e66.png

现在就可以在http://ip:9001/中访问test_one的程序了。

0360926243f4d495358a438eaa8612d0.png

3.5 supervisor开机自动启动

3.5.1 在目录/usr/lib/systemd/system/ 新建文件supervisord.service,并添加配置内容

[Unit]

Description=Process Monitoring and Control Daemon

After=rc-local.service nss-user-lookup.target

[Service]

Type=forking

ExecStart=/usr/bin/supervisord -c /usr/supervisor/supervisord.conf ;开机启动时执行

ExecStop=/usr/bin/supervisord shutdown

ExecReload=/usr/bin/supervisord reload

killMode=process

Restart=on-failure

RestartSec=42s

[Install]

WantedBy=multi-user.target

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

[Unit]

Description=ProcessMonitoringandControlDaemon

After=rc-local.servicenss-user-lookup.target

[Service]

Type=forking

ExecStart=/usr/bin/supervisord-c/usr/supervisor/supervisord.conf;开机启动时执行

ExecStop=/usr/bin/supervisordshutdown

ExecReload=/usr/bin/supervisordreload

killMode=process

Restart=on-failure

RestartSec=42s

[Install]

WantedBy=multi-user.target

3.5.2 启动服务

systemctl enable supervisord

3.5.3 验证一下是否为开机启动

systemctl is-enabled supervisord

Supervisor周边

4.1 supervisor常用命令

### 查看supervisorctl支持的命令

# supervisorctl help

default commands (type help ):

=====================================

add exit open reload restart start tail

avail fg pid remove shutdown status update

clear maintail quit reread signal stop version

### 查看当前运行的进程列表

# supervisorctl status

1

2

3

4

5

6

7

8

9

10

### 查看supervisorctl支持的命令

# supervisorctl help

defaultcommands(typehelp):

=====================================

addexitopenreloadrestartstarttail

availfgpidremoveshutdownstatusupdate

clearmaintailquitrereadsignalstopversion

### 查看当前运行的进程列表

# supervisorctl status

update 更新新的配置到supervisord(不会重启原来已运行的程序)

reload,载入所有配置文件,并按新的配置启动、管理所有进程(会重启原来已运行的程序)

start xxx: 启动某个进程

restart xxx: 重启某个进程

stop xxx: 停止某一个进程(xxx),xxx为[program:theprogramname]里配置的值

stop groupworker: 重启所有属于名为groupworker这个分组的进程(start,restart同理)

stop all,停止全部进程,注:start、restart、stop都不会载入最新的配置文

reread,当一个服务由自动启动修改为手动启动时执行一下就ok

ps:有些版本并不支持supervisorctl ,可以通过supervisorctl -c /usr/supervisor/supervisord.conf唤起命令,格式如上,实际效果如下。

3a59e26d0b36448ccb3b02eef7296140.png

4.2 如果supervisorCPU和内存占用率特别高,导致机器卡死。

尝试注释掉2.4中的web。

4.3 Unlinking stale socket /tmp/supervisor.sock

解决方案,执行unlink /tmp/supervisor.sock

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/525588.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

H264/ACC数据使用librtmp推流到服务器

这是本人第一次发表这个,首先声明本人也是个菜鸟!都说使用librtmp很简单,但是在网上找了很久,还是被各种大神坑了。 其实我也还是有很多东西不懂,如果下面有什么问题的地方,还请各位大神指点纠正。 1.视频数…

从容器到微服务,技术架构、网络和生态详解

图片来源:Unsplash作者晗狄文章来源架构师技术联盟如需转载,请联系原作者授权谈起容器技术,不得不提Docker技术。Docker 是 PaaS 提供商 DotCloud 开源的一个高级容器引擎,源代码托管在 Github 上,基于Go语言并遵从Apa…

彻底搞懂 python 中文乱码问题

前言 曾几何时 Python 中文乱码的问题困扰了我很多很多年,每次出现中文乱码都要去网上搜索答案,虽然解决了当时遇到的问题但下次出现乱码的时候又会懵逼,究其原因还是知其然不知其所以然。现在有的小伙伴为了躲避中文乱码的问题甚至代码中不使…

如何让Kubernetes集群生产可用?

图片来源:veer本文作者Steven Wong (VMware)Michael Gasch (VMware)文章翻译Karen Lee文章来源K8S技术社区原文链接https://kubernetes.io/blog/2018/08/03/out-of-the-clouds-onto-the-ground-how-to-make-kubernetes-production-grade-anywhere如需转载&#xff0…

北京房租到底有多高? | 爬取北京海淀区一居室租房信息

图片来源:花瓣网文章来源人工智能与大数据生活如需转载,请联系原作者授权最近北京房租成了热门话题,到底北京的房租有多高?本次实战是爬取北京海淀区一居室的租房信息,共爬取了300套房源信息,看一下北京的房…

租房有深坑?手把手教你如何用R速读评论+科学选房

图片来源:网络编译Hope、臻臻、CoolBoy文章来源大数据文摘出品如有转载,请联系原作者。最近,租房这事儿成了北漂族的一大bug,要想租到称心如意的房子,不仅要眼明手快,还得看清各类“前辈”的评价避开大坑。…

快速搭建Python+Selenium+Sublime 自动化测试环境方法

随着业内越来越多的公司对自动化测试的大力推行,对测试人员能够使用自动化工具的要求也随之增多。为了能让更多的同事在学习selenium的初期,能够顺利的迈出第一步,即可以通过代码操作selenium driver 调用浏览器打开目标网址,笔者…

刚刚,百度总裁张亚勤说……

作者奋笔疾书的小编原创文章,如有转载,请联系本公众号。9月4日, ABC SUMMIT百度云智峰会在上海举行。百度总裁张亚勤首先发表《云计算的新浪潮》主题演讲,他表示,我们已经全面进入物理世界数字化、AI as a Service、新…

pycharm 提示:this license **** has been cancelled(2)

目录 一.找到hosts文件 二.修改hosts文件 三.检查hosts文件是否修改成功 pycharm安装激活过程中,提示 this license **** has been cancelled 。这个问题并不是你的激活码不对,而是需要修改系统的hosts文件,下面详细讲解下如何修改hosts文…

嘿,运维!你与VXLAN有场约会……

图片来源:网络作者Bert如有转载,请联系本公众号。VXLAN概述 ▍顾名思义,VXLAN(Virtual eXtensible Local Area Network)提供了类似VLAN的二层网络服务,并且比VLAN更具备扩展性和灵活性,该技术将…

如何判断一个点在任意四边形内

通过面积法,判断点P是否在四边形(A,B,C,D)内。如果在四边形内,则四边形的面积面积(P,A,B)面积(P,B,C)面积(P,C,D)面积(P,D,A),反之不在四边形内。 此处我将判断方法定义成了静态方法,方便其他类访问,代码如下: public class IsInQuadrangle {public IsInQuadrangle…

网格变形动画MeshTransform

原文:Mesh Transforms 作者:Bartosz Ciechanowski 译者:kmyhy 我是 transform 属性的超级粉丝。让 UIView 或者 CALayer 的形体发生改变的最简单方法就是联合使用旋转、平移和缩放。在易于适用的同时,常规变换所能实现的效果也同…

cloud一分钟 | 腾讯云联手斗鱼、虎牙两大头部游戏直播平台开启 定制道具的创新互动...

Hello,everyone:9月7日早,星期五,祝大家工作愉快!一分钟新闻时间:完01微 信 群 添加小编微信:tangguoyemeng,备注“进群”即可,加入【云计算学习交流群】,和…

Linux服务器硬盘更换,[ Linux ] 服务器更换硬盘

服务器型号:ThinkServer RD650操作系统:Red Hat 6.7业务用途:生产环境监控机接到机房邮件通知,告知某台服务器硬盘告警,并提供了设备SN号和机柜位置。根据提供想相关信息找到对应的设备IP并确定该设备的业务用途。登录…

【BAT面试现场】如何判断一个数是否在40亿个整数中?

作者channingbreeze如需转载,请联系原作者授权。小史是一个应届生,虽然学的是电子专业,但是自己业余时间看了很多互联网与编程方面的书,一心想进BAT。今天他就去BAT中的一家面试了。简单的自我介绍后,面试官给了小史一…

彩色BMP转换成灰度图的原理

图像处理中,大部分的处理方法都需要事先把彩色图转换成灰度图才能进行相关的计算、识别。 彩色图转换灰度图的原理如下: 我们知道彩色位图是由R/G/B三个分量组成,其文件存储格式为 BITMAPFILEHEADERBITMAPINFOHEADER,紧跟后面的可…

Linux java 生效不了,linux jdk 不生效怎么办

【摘要】操作系统(Operating System,简称OS)是管理计算机硬件与软件资源的计算机程序。操作系统需要处理如管理与配置内存、决定系统资源供需的优先次序、控制输入设备与输出设备、操作网络与管理文件系统等基本事务。下面是linux jdk 不生效怎么办,让我…

程序猿 - 超实用的工具、素材、学习网站分享

文章目录------------------------------学习教程篇-------------------------------bilibili哔哩哔哩网易云课堂siki学院:泰课在线:可汗学院:线性代数的本质 - bilibili计算机科学速成课 - bilibiliLearnOpenGL:The Book of Shad…

面趣 | 马云在面试中出的一道题,据说只有一个人答对……

大神,求解!据说,马云给新员工出了一道题然鹅,只有一个人答对了!!!!智商不足的小编居然打开了这道题求解!!!我手里有50元钱花去剩余买衣服 20元30…

云漫圈 | 敢怼我们程序员?哼,有你好看的。。。

作者设计师静静来源非著名程序员原创作品,如有转载,请联系公众号授权。原创漫画,禁止转载,侵权必究前几天在网络上看到一个关于产品经理和设计的对话,非常的搞笑,有意思。对话如下:产品经理&…