原文出处:[https://segmentfault.com/a/1190000015768529](https://segmentfault.com/a/1190000015768529)
在使用Tp的消息队列 think-queue的时候进程意外结束了!导致项目没法运行;
所以用到了supervisor; 接下来跟大家分享一下自己的使用心得以及安装到使用的方法;
官网:[http://supervisord.org/introd...](http://supervisord.org/introduction.html)
首先安装 有很多办法;
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](https://segmentfault.com/img/bVbekgo?w=1415&h=714 "5b5888b468e0e.png")
![5b5888cf26f49.png](https://segmentfault.com/img/bVbekgv?w=718&h=254 "5b5888cf26f49.png")
![5b5888e4a6449.png](https://segmentfault.com/img/bVbekgy?w=1071&h=186 "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](https://segmentfault.com/img/bVbekgQ?w=889&h=195 "5b588a07dce5a.png")
我在执行的时候遇到错误了,下面会说错误的处理的问题以及解决办法;
现在我们来测试;
首先在测试的时候执行 stop 将进程停止,之后再打开一个终端连接redis,我们执行登录,执行后登录后的队列任务会在redis一直存在;
~~~
supervisorctl stop test 或者直接 supervisorctl stop all
~~~
![5b588ab662a08.png](https://segmentfault.com/img/bVbekg5?w=685&h=159 "5b588ab662a08.png")
可以看到是没有被执行的!现在我们开supervisorctl 的test进程
![5b5887de1f28b.png](https://segmentfault.com/img/bVbekg8?w=863&h=261 "5b5887de1f28b.png")
![5b588ac471aa8.png](https://segmentfault.com/img/bVbekha?w=1487&h=150 "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](https://segmentfault.com/img/bVbekhb?w=1453&h=126 "5b588add37fa1.png")
![5b588ae748e75.png](https://segmentfault.com/img/bVbekhd?w=907&h=145 "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掉居然都可以执行,所以将服务器重启了!
- PHP新特性
- 一些常识
- PHP常见header头
- Nginx配置文件
- 常用工具类
- PHP实现的一个时间帮助类
- PHP原生生成EXCEL
- PHP地理位置计算
- PHP获取服务器状态
- 驼峰转下划线
- 百度地图两点坐标距离计算
- 判断是否是url
- 邮件发送类
- 阿拉伯数字转化为大写
- 获取汉字首个拼音
- 根据身份证号获取星座
- 生成验证码类
- 生成唯一ID
- 身份证验证类
- PHP中文转拼音
- curl获取网页内容
- 快递查询api
- 快递API类
- 上传图片类
- 股票类
- 找回密码类
- 校验数据规则
- PHP获取收集相关信息
- 字符串截取助手函数
- 网页中提取关键字
- 检测浏览器语言
- PHP实现微信红包拆分算法
- 常用函数
- 微信相关
- 网络知识
- LX1 Laravel / PHP 扩展包视频教程
- THINKPHP5学习
- 高级查询
- Vue学习
- Vue全家桶
- Vue-CLI 3.x 自动部署项目至服务器
- Vue2全家桶
- Vue2全家桶之一:vue-cli(vue脚手架)超详细教程
- Vue2全家桶之二:vue-router(路由)详细教程,看这个就够了
- Vue2全家桶之三:vue-resource(不推荐)----axios(推荐)
- 前端相关
- sublime text3 配置less编译环境
- 服务器搭建相关
- supervisor
- Supervisor 安装与配置 Linux进程管理
- supervisor 永不挂掉的进程 安装以及使用
- Supervisor进程管理&开机自启
- php实现定时任务
- 使用sublime text3 连接sftp/ftp(远程服务器)
- Redis相关
- linux服务器重启后导致redis数据丢失
- 搜索引擎SEO
- 百度收录权威链接,指向真正需要收录的地址rel
- 软件相关
- sublime
- sublime Text3修改侧边栏的主题
- sublime和vscode比较
- Acrylic DNS Proxy 使用方法
- 技术类网址收藏