swoole中的php代码热更新
来源:互联网 发布:2000年流行网络歌曲 编辑:程序博客网 时间:2024/05/17 23:34
这里以ZPHP框架作为演示,实现swoole的代码热更新,在WorkerStart回调函数中,载入ZPHP框架:
use ZPHP\ZPHP;$zphp = null;$mimes = null;$http = new swoole_http_server('0.0.0.0',9501);$http->on('request', function (swoole_http_request $request, swoole_http_response $response){//......});$http->on('WorkerStart',function($serv, $worker_id){ //框架载入 require __DIR__ . DIRECTORY_SEPARATOR . 'zphp' . DIRECTORY_SEPARATOR . 'ZPHP' . DIRECTORY_SEPARATOR . 'ZPHP.php'; global $zphp; $zphp = ZPHP::run(__DIR__, false, 'default'); global $mimes; $mimes = require "mimes.php";});$http->start();
文件名为http_server.php
在后台运行此脚本:
php http_server.php &在浏览器输入192.168.1.116:9501进行http请求:
这是因为加载ZPHP框架后,访问了默认的控制器下的默认方法,其中一行代码为:
$data = $project."zchat runing in swoole!!!!\n";现在修改此行代码如下:
$data = $project."The code is modified!!!!\n";
在Linux中查看http_server的进程
ps axuf|grep http_server
如图,从上到下分别是swoole的master进程,manager进程和四个worker进程,worker进程正是由manager进程所创建的,想要热更新代码就需要重载worker进程
使用以下命令向manager进程发送一个信号来重载worker进程:
kill -USR1 5913再查看http_server的进程
可见4个worker进程的进程编号都和之前不同了,这说明manager进程已经重载了worker进程
刷新浏览器中的页面可见
:
热更新成功~
这里小小总结一下:
代码热更新其实更新的是"WorkerStart"回调函数里的内容,也就是说我们的业务代码都要放到"WorkerStart"回调函数中。
另外对于'kill -USR1 进程编号'这一命令,维基百科解释如下:
"USR1亦通常被用来告知应用程序重载配置文件;例如,向Apache HTTP服务器发送一个USR1信号将导致以下步骤的发生:停止接受新的连接,等待当前连接停止,重新载入配置文件,重新打开日志文件,重启服务器,从而实现相对平滑的不关机的更改。" —— https://zh.wikipedia.org/wiki/SIGUSR1%E5%92%8CSIGUSR2
0 0
- swoole中的php代码热更新
- swoole中的php代码热更新
- swoole之代码热更新实现
- Linux 下监控文件自动实现swoole framework热更新
- lua代码热更新
- NodeJS代码热更新
- Unity热更新代码
- PHP--swoole
- U3D 代码、资源热更新
- cocos2d-js 热更新代码
- cocos2d热更新代码分析
- skynet 热更新 lua 代码
- 使用php的swoole扩展实现数据实时更新(上)
- 使用php的swoole扩展实现数据实时更新(下)
- 游戏中的热更新漫谈
- 【Swoole】当SWOOLE遇上PHP
- 【Swoole】当SWOOLE遇上PHP
- PHP 热更新的简单程序
- windows下beego安装
- git的使用
- 儿童阅读书籍网站
- Spring学习笔记-IOC高级特性3-用Java Config简化XML配置
- Linux下CSITOOL和MATLAB安装心得
- swoole中的php代码热更新
- Activity、Fragment启动总结
- Size_t和int区别
- 整理比较Java集合类(List,Set, Queue, Map)
- Kafka笔记二之Topic操作,文件参数配置
- 2017河工大邀请赛G题_1266: 最大子段和_Dp
- 剑指offer-面试题35-第一个只出现一次的字符
- CodeForces
- 辗转相除法求最大公约数,最小公倍数。