supervisor 永不挂掉的进程 安装以及使用

2020-01-10 21:59:08

参考地址 supervisor安装教程


在使用Tp的消息队列 think-queue的时候进程意外结束了!导致项目没法运行;

所以用到了supervisor ; 接下来跟大家分享一下自己的使用心得以及安装到使用的方法;

官网:http://supervisord.org/introduction.html
首先安装 有很多办法;
01:wget 下载压缩包:

  1. cd /usr/local/lee   #这个lee是我自己建立的一个目录

  2. wget https://pypi.python.org/packages/7b/17/88adf8cb25f80e2bc0d18e094fcd7ab300632ea00b601cbbbb84c2419eae/supervisor-3.3.2.tar.gz

  3. tar -zxvf supervisor-3.3.2.tar.gz

  4. cd supervisor-3.3.2

  5. python setup.py install

复制代码

02: yum安装
  1. yum install python-setuptools

  2. easy_install supervisor

复制代码

我们安装的时候使用wget的;




之后生成配置文件:
  1. mkdir /etc/supervisor

  2. echo_supervisord_conf > /etc/supervisord.conf

复制代码

打开配置文件修改一点东西;
  1. vim /etc/supervisord.conf

复制代码

要将底部的
  1. ;[include]

  2. ;files = relative/directory/*.ini

  3. 修改为:

  4. [include]

  5. files=/etc/supervisor/*.conf (注意去掉分号,第一次安装的时候就因为没去掉分号出现了问题!);

复制代码

之后创建一个文件 文件名随意 后缀为.conf的,我这里就创建一个test.conf的文件;



我的项目在/www/wwwroot/admin/目录下:
  1. vim test.conf

  2. #写入一些配置:

  3. [program:test]   # 设置进程的名称,使用 supervisorctl 来管理进程时需要使用该进程名 我这里就叫做test了!

  4. command=php think queue:work --queue saveLoginLog --daemon --tries 10;  #这个就是队列执行的命令

  5. directory= /www/wwwroot/admin;  #命令执行的目录或者说执行 command 之前,先切换到工作目录 可以理解为在执行命令前会切换到这个目录

  6. process_name=%(process_num)02d; #默认为 %(program_name)s,即 [program:x] 中的 x 这个是进程名,如果我们下面的numprocs参数为1的话,就不用管这个参数

  7.                                  了,它默认值%(program_name)s也就是上面的那个program冒号后面的

  8. numprocs=5; #进程数量当不为1时的时候,就是进程池的概念,注意process_name的设置

  9. autostart=true; #是否自动启动

  10. autorestart=true; #程序意外退出是否自动重启

  11. startsecs=1;  自动重启间隔 

  12. startretries=20;  当进程启动失败后,最大尝试启动的次数。。当超过3次后,supervisor将把此进程的状态置为FAIL 默认值为3 。。

  13. redirect_stderr=true;  如果为true,则stderr的日志会被写入stdout日志文件中  理解为重定向输出的日志

  14. user=root;  这个参数可以设置一个非root用户,当我们以root用户启动supervisord之后。我这里面设置的这个用户,也可以对supervisord进行管理

  15. stdout_logfile= /www/wwwroot/admin/test.out.log; 子进程的stdout的日志路径 输出日志文件

  16. stderr_logfile=/www/wwwroot/admin/test.err.log ; 错误日志文件 redirect_stderr=true。这个就不用

复制代码

上面有注释说明的看起来有点混乱,我们来写一个没有注释的:
  1. [program:test] 

  2. command=php think queue:work --queue saveLoginLog --daemon --tries 10

  3. directory= /www/wwwroot/admin

  4. process_name=%(process_num)02d

  5. numprocs=5

  6. autostart=true

  7. autorestart=true

  8. startsecs=1

  9. startretries=20

  10. redirect_stderr=true

  11. user=root

  12. stdout_logfile= /www/wwwroot/admin/test.out.log

  13. stderr_logfile=/www/wwwroot/admin/test.err.log 

复制代码

之后执行启动:
  1. supervisord -/etc/supervisord.conf

  2. supervisorctl reload

复制代码


我在执行的时候遇到错误了,下面会说错误的处理的问题以及解决办法;

现在我们来测试;
首先在测试的时候执行 stop 将进程停止,之后再打开一个终端连接redis,我们执行登录,执行后登录后的队列任务会在redis一直存在;
  1. supervisorctl stop test 或者直接 supervisorctl stop all

复制代码


可以看到是没有被执行的!现在我们开supervisorctl 的test进程


接下来说一下问题:
问题1:
Unlinking stale socket /tmp/supervisor.sock
或者:
Error: Another program is already listening on a port that one of our HTTP servers is configured to use. Shut this program down first before starting supervisord.


解决办法:
  1. sudo unlink /tmp/supervisor.sock 

  2. or

  3. sudo unlink /var/run/supervisor.sock

复制代码

问题2:
gave up: redis entered FATAL state, too many start retries too quickly

解决办法:

修改redis.conf的daemonize为no

其他问题暂时没有发现;
我在测试的时候进程kill掉居然都可以执行,所以将服务器重启了!

  • 2019-08-14 14:29:12

    浅谈nodejs和php

    现在,Web开发公司和开发人员可以选择多种技术栈来构建Web应用程序。早期网络发展,不同的技术被用于前端和后端开发。但是,随着Node.js的发布,布局发生了变化,因为它允许开发人员使用 JavaScript 编写后端代码。这最终催生了MEAN(MongoDB + Express +AngularJS + NodeJS )堆栈 web 开发框架,从前端到后端甚至是数据库(MongoDB -JSON)都使用 JavaScript。在 Node.js 之前,Web 开发通常是在 PHP 的帮助下完成的,因为它很容易与 HTML 集成,帮助开发人员立即构建动态网站。在这篇文章中,我们将比较 Node.js 和 PHP,看哪一个最适合当前的行业需求。

  • 2019-08-15 13:32:18

    Node.js是如何解决服务器高性能瓶颈问题的

    在Java、PHP或者.net等服务器端语言中,会为每一个客户端连接创建一个新的线程。而每个线程需要耗费大约2MB内存。也就是说,理论上,一个8GB内存的服务器可以同时连接的最大用户数为4000个左右。要让Web应用程序支持更多的用户,就需要增加服务器的数量,而Web应用程序的硬件成本当然就上升了。

  • 2019-08-15 13:33:53

    nodejs的10个性能优化技巧

    在我接触JavaScript(无论浏览器还是NodeJS)的时间里,总是遇到有朋友有多线程的需求。而在NodeJS方面,有朋友甚至直接说到,NodeJS是单线程的,无法很好的利用多核CPU。那么我们在使用过程中,就要非常注意性能优化了

  • 2019-08-16 13:18:48

    使用ffmpeg进行ts切片并AES-128加密

    由于解密的key文件都是公开的,所以并不能算上完全加密,用户只要把你的key+m3u8里的ts切片文件全部下载,用ffmpeg还是能解,这时就要考虑url的key防止用户直接下载和盗链。 ​

  • 2019-08-18 22:22:54

    Error:error: unable to remove file: Permission denied

    JNI里写的C++增加了函数或修改了,如果此时是Debug模式下,而且还没退出程序,就出现这个Permission denied的提示。解决也很简单:就是退出App即可。如果退出无响应,直接拔usb,重新插上也可以

  • 2019-08-19 10:24:29

    浅析Express中的路由与应用模式

    Express是一个基于Node.js的轻量级web开发框架,具有体积小,使用灵活等特点。查看Express的源码,如果不计供使用的中间件,主体框架只有一千余行代码,非常简练。

  • 2019-08-19 15:50:17

    记录PHP的进程和线程理解

    线程是进程的一个执行流,线程不能分配系统资源,它是进程的一部分,比进程更小的独立运行的单位。 解释一下:进程有两个特性:一是资源的所有权,一个是调度执行(指令集),线程是调度执行中的一部分,是指进程执行过程的路径,也叫程序执行流。线程有时候也叫轻量级进程。

  • 2019-08-20 08:51:52

    一台Linux服务器可以负载多少个连接?

    我们在压测一台目标服务器,想看下负载的连接数,当我们压到一定数量的时候,控制台突然报"too many open files",这是因为linux系统创建一个TCP连接的时候,都会创建一个socket句柄,每个socket句柄就是一个文件句柄。