首页
下载
文档
问答社区
视频
捐赠
源代码
AI 助理
赞助商
CRMEB
Apipost
腾讯云
微擎
禅道
51Talk
商业产品
Swoole AI 智能文档翻译器
Swoole-Compiler PHP 代码加密器
CRMEB 新零售社交电商系统
登录
注册
全部
提问
分享
讨论
建议
公告
开发框架
CodeGalaxy
发表新帖
Swoole\Process\Manager 重定向标准错误
### 问题描述 在使用Swoole\Process\Manager的过程中,由于没有找到跟server一样的设置log_file的方法,就自己在程序里将STDOUT和STDERR关闭了,然后重定向到日志文件里。 在程序运行的过程中,其中STDOUT是有作用的,但是STDERR就没有作用。 当关闭结束程序运行时,其中给STDOUT这个重定向报一个warning ![](/storage/article-column/TmrNar3YhHcgnZQH5Jcfi3DPzTpwBHyubEpvxyo5.png) ### Swoole版本,PHP版本,以及操作系统版本信息 ![](/storage/article-column/oLa79oJxqqyIbGHkkPfYZ012cGgFxYK0sf274j5A.png) ### 相关代码 ```php \Swoole\Process::daemon(); fclose(STDOUT); //fclose(STDERR); self::$stdout = fopen(self::$log_file,"a"); //self::$stderr = fopen(self::$log_file,"a"); ``` ### 你期待的结果是什么?实际看到的错误信息又是什么? 在Swoole\Process\Manager里,主进程和子进程如何才能重定向标准错误,如果将进程守护进程化的话,在程序运行的过程中,如果发生错误,这时不就无法打印日志,快速定位到错误了吗?
发布于3年前 · 4 次浏览 · 来自
提问
jw
### 问题描述 在使用Swoole\Process\Manager的过程中,由于没有找到跟server一样的设置log_file的方法,就自己在程序里将STDOUT和STDERR关闭了,然后重定向到日志文件里。 在程序运行的过程中,其中STDOUT是有作用的,但是STDERR就没有作用。 当关闭结束程序运行时,其中给STDOUT这个重定向报一个warning ![](/storage/article-column/TmrNar3YhHcgnZQH5Jcfi3DPzTpwBHyubEpvxyo5.png) ### Swoole版本,PHP版本,以及操作系统版本信息 ![](/storage/article-column/oLa79oJxqqyIbGHkkPfYZ012cGgFxYK0sf274j5A.png) ### 相关代码 ```php \Swoole\Process::daemon(); fclose(STDOUT); //fclose(STDERR); self::$stdout = fopen(self::$log_file,"a"); //self::$stderr = fopen(self::$log_file,"a"); ``` ### 你期待的结果是什么?实际看到的错误信息又是什么? 在Swoole\Process\Manager里,主进程和子进程如何才能重定向标准错误,如果将进程守护进程化的话,在程序运行的过程中,如果发生错误,这时不就无法打印日志,快速定位到错误了吗?
赞
0
分享
收藏
提问
分享
讨论
建议
公告
开发框架
CodeGalaxy
评论
2021-04-20
云天001
参考文档[不可捕获的致命错误和异常](https://wiki.swoole.com/#/getting_started/notice?id=%e4%b8%8d%e5%8f%af%e6%8d%95%e8%8e%b7%e7%9a%84%e8%87%b4%e5%91%bd%e9%94%99%e8%af%af%e5%92%8c%e5%bc%82%e5%b8%b8 "https://wiki.swoole.com/#/getting_started/notice?id=%e4%b8%8d%e5%8f%af%e6%8d%95%e8%8e%b7%e7%9a%84%e8%87%b4%e5%91%bd%e9%94%99%e8%af%af%e5%92%8c%e5%bc%82%e5%b8%b8") 通过 register_shutdown_function 进行终止捕获,在里面捕捉错误然后记录。
赞
0
回复
微信公众号
热门内容
作者其它话题
- 进程管理器(Process\Manager)在子进程正常退出或者异常退出时,怎么通知主进程
暂无回复的问答
- CodeGalaxy K3s 轻量集群节点之间如何实现负载均衡
- 关于openssl CURL WARNING swSSL_connect: SSL_connect(fd=69) failed. Error: error:141A318A:SSL routines:tls_process_ske_dhe:dh key too small[1|394]
- 多个模型如何进行事务异常回退?
- websocket开启wss报错
- 协程tcp服务器如何使用多进程?recv()方法接收信息,打印出来的pid一直是同一个。没用使用到多进程啊。