当前位置: 首页 > news >正文

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

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

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

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

cd /usr/local/lee   #这个lee是我自己建立的一个目录
wget https://pypi.python.org/packages/7b/17/88adf8cb25f80e2bc0d18e094fcd7ab300632ea00b601cbbbb84c2419eae/supervisor-3.3.2.tar.gz
tar -zxvf supervisor-3.3.2.tar.gz
cd supervisor-3.3.2
python setup.py install

02: yum安装:

yum install python-setuptools
easy_install supervisor

我们安装的时候使用wget的;
5b5888b468e0e.png

5b5888cf26f49.png

5b5888e4a6449.png

之后生成配置文件:

mkdir /etc/supervisor
echo_supervisord_conf > /etc/supervisord.conf

打开配置文件修改一点东西;

vim /etc/supervisord.conf

要将底部的

;[include]
;files = relative/directory/*.ini
修改为:
[include]
files=/etc/supervisor/*.conf 
(注意去掉分号,第一次安装的时候就因为没去掉分号出现了问题!);

之后创建一个文件 文件名随意 后缀为.conf的,我这里就创建一个test.conf的文件;
我的项目在/www/wwwroot/admin/目录下:

vim test.conf
#写入一些配置:
[program:test]   # 设置进程的名称,使用 supervisorctl 来管理进程时需要使用该进程名 我这里就叫做test了!
command=php think queue:work --queue saveLoginLog --daemon --tries 10;  #这个就是队列执行的命令
directory= /www/wwwroot/admin;  #命令执行的目录或者说执行 command 之前,先切换到工作目录 可以理解为在执行命令前会切换到这个目录
process_name=%(process_num)02d; #默认为 %(program_name)s,即 [program:x] 中的 x 这个是进程名,如果我们下面的numprocs参数为1的话,就不用管这个参数
                                 了,它默认值%(program_name)s也就是上面的那个program冒号后面的
numprocs=5; #进程数量当不为1时的时候,就是进程池的概念,注意process_name的设置
autostart=true; #是否自动启动
autorestart=true; #程序意外退出是否自动重启
startsecs=1;  自动重启间隔 
startretries=20;  当进程启动失败后,最大尝试启动的次数。。当超过3次后,supervisor将把此进程的状态置为FAIL 默认值为3 。。
redirect_stderr=true;  如果为true,则stderr的日志会被写入stdout日志文件中  理解为重定向输出的日志
user=root;  这个参数可以设置一个非root用户,当我们以root用户启动supervisord之后。我这里面设置的这个用户,也可以对supervisord进行管理
stdout_logfile= /www/wwwroot/admin/test.out.log; 子进程的stdout的日志路径 输出日志文件
stderr_logfile=/www/wwwroot/admin/test.err.log ; 错误日志文件 当redirect_stderr=true。这个就不用

上面有注释说明的看起来有点混乱,我们来写一个没有注释的:

[program:test] 
command=php think queue:work --queue saveLoginLog --daemon --tries 10
directory= /www/wwwroot/admin
process_name=%(process_num)02d
numprocs=5
autostart=true
autorestart=true
startsecs=1
startretries=20
redirect_stderr=true
user=root
stdout_logfile= /www/wwwroot/admin/test.out.log
stderr_logfile=/www/wwwroot/admin/test.err.log 

之后执行启动:

supervisord -c /etc/supervisord.conf
supervisorctl reload

5b588a07dce5a.png

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

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

supervisorctl stop test 或者直接 supervisorctl stop all

5b588ab662a08.png

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

5b588ac471aa8.png

接下来说一下问题:
问题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.

5b588add37fa1.png

5b588ae748e75.png

解决办法:

sudo unlink /tmp/supervisor.sock 
or
sudo unlink /var/run/supervisor.sock

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

解决办法:

修改redis.conf的daemonize为no

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

相关文章:

  • Vue-cli原理分析
  • 数据库sql优化
  • 阿里十年,只剩下这套Java开发体系了
  • MVC框架请求处理
  • Android路由框架AnnoRouter:使用Java接口来定义路由跳转
  • Android系统文件目录
  • 你应该知道H5的iPhoneX适配
  • vue刷新当前页面,11选5平台维护
  • final关键字,static关键字
  • js数组条件筛选——map()
  • was安装相关步骤(Linux)
  • Lambda表达式与函数式接口
  • Vuex持久化插件-解决刷新数据消失的问题
  • 关于性能测试的这点事,值得收藏~
  • 深入理解Spring Boot数据源与连接池原理
  • [nginx文档翻译系列] 控制nginx
  • 【腾讯Bugly干货分享】从0到1打造直播 App
  • Go 语言编译器的 //go: 详解
  • Java知识点总结(JavaIO-打印流)
  • Objective-C 中关联引用的概念
  • quasar-framework cnodejs社区
  • Rancher-k8s加速安装文档
  • Ruby 2.x 源代码分析:扩展 概述
  • Spark学习笔记之相关记录
  • Tornado学习笔记(1)
  • vue2.0一起在懵逼的海洋里越陷越深(四)
  • 对话 CTO〡听神策数据 CTO 曹犟描绘数据分析行业的无限可能
  • 对话:中国为什么有前途/ 写给中国的经济学
  • 回顾2016
  • 记一次和乔布斯合作最难忘的经历
  • 前端js -- this指向总结。
  • 如何借助 NoSQL 提高 JPA 应用性能
  • 算法-图和图算法
  • ​​​​​​​Installing ROS on the Raspberry Pi
  • ​用户画像从0到100的构建思路
  • !! 2.对十份论文和报告中的关于OpenCV和Android NDK开发的总结
  • # 深度解析 Socket 与 WebSocket:原理、区别与应用
  • (02)Cartographer源码无死角解析-(03) 新数据运行与地图保存、加载地图启动仅定位模式
  • (2)(2.4) TerraRanger Tower/Tower EVO(360度)
  • (Mac上)使用Python进行matplotlib 画图时,中文显示不出来
  • (多级缓存)多级缓存
  • (论文阅读22/100)Learning a Deep Compact Image Representation for Visual Tracking
  • (三分钟)速览传统边缘检测算子
  • (转)关于多人操作数据的处理策略
  • (转)原始图像数据和PDF中的图像数据
  • .apk文件,IIS不支持下载解决
  • .NET 自定义中间件 判断是否存在 AllowAnonymousAttribute 特性 来判断是否需要身份验证
  • .NET/C# 如何获取当前进程的 CPU 和内存占用?如何获取全局 CPU 和内存占用?
  • .net的socket示例
  • .NET面试题解析(11)-SQL语言基础及数据库基本原理
  • .NET运行机制
  • .Net转Java自学之路—基础巩固篇十三(集合)
  • .pyc文件是什么?
  • @data注解_SpringBoot 使用WebSocket打造在线聊天室(基于注解)
  • @ModelAttribute注解使用