swoole reload 代码热更新 example

简介:
server:
class
Server
{
   private $_serv = null;

   private $_e = null;

   public function __construct()
   {
       $this->_serv = new swoole_server("0.0.0.0", 9501);
       $this->_serv->set(array(
           'worker_num' => 8,
           'daemonize' => false,
           'max_request' => 10000,
           'dispatch_mode' => 2,
           'debug_mode'=> 1,
       ));

       $this->_serv->on('Start', array($this, 'onStart'));
       $this->_serv->on('WorkerStart', array($this, 'onWorkerStart'));
       $this->_serv->on('Connect', array($this, 'onConnect'));
       $this->_serv->on('Receive', array($this, 'onReceive'));
       $this->_serv->on('Close', array($this, 'onClose'));
       $this->_serv->start();
   }

   public function onStart($serv)
   {
       echo "start\n";
       cli_set_process_title('reload_master');
   }

   public function onWorkerStart($serv, $worker_id)
   {

       spl_autoload_register(function($class){

           $classPath = str_replace('\\', '/', $class) .'.php';
           if (file_exists($classPath)) {
               include $classPath;
           }

       });

       $this->_e = new \plugin\Event();

   }

   public function onConnect( $serv, $fd, $from_id ) {
       echo "Client {$fd} connect\n";

   }
   public function onReceive( swoole_server $serv, $fd, $from_id, $data ) {
       $serv->reload();//当接收到客户端消息时更新代码,下次再执行work代码时变(onWorkerStart),本次执行还是不变
       $this->_e->say();
       echo "Get Message From Client {$fd}:{$data}\n";
   }
   public function onClose( $serv, $fd, $from_id ) {
       echo "Client {$fd} close connection\n";
   }

}

new Server();

client:

$cli = new Swoole_client(SWOOLE_SOCK_TCP);

$cli->connect('127.0.0.1', 9501, 1);

fwrite(STDOUT, '输入消息:');
$msg = trim(fgets(STDIN));

$cli->send($msg);

wKiom1m05HKjm5pnAAA2-z0g36M768.png



本文转自 skinglzw 51CTO博客,原文链接:http://blog.51cto.com/skinglzw/1964105,如需转载请自行联系原作者

相关文章
|
4月前
|
Dart 前端开发 JavaScript
swoole(一)laravel8配置使用swoole(1)
然后在服务器使用命令行执行 复制代码
103 0
|
4月前
|
前端开发 应用服务中间件 网络安全
swoole(一)laravel8配置使用swoole(2)
将上边我使用xxx代替的部分改成你自己的信息。 特别说明一下:我这里使用了ssl证书,如果您没有相关的配置,把https那部分换掉就好。 具体的配置含义,请参考官方文档:
53 0
|
4月前
|
前端开发 小程序 JavaScript
swoole(一)laravel8配置使用swoole(3)
Laravel-swoole的优势就是将swoole插件集成至laravel-s插件中,当前laravel-s插件启动的时候,同时持久化的启动了swoole,不需要我们再服务器端再启动一次swoole。
40 0
|
Web App开发 JavaScript 中间件
开发chrome插件auto reload原理分析
开发chrome插件auto reload原理分析
384 0
|
PHP 开发工具
swoole-cli常见问题
由于系统的cacert证书有问题,可能会报该错误,在fpm环境的时候我们需要先下载好cacert.pem文件,并在php.ini中声明路径
365 0
|
数据采集 大数据 应用服务中间件
Nginx 集成 lua 脚本|学习笔记
快速学习 Nginx 集成 lua 脚本
1206 0
Nginx 集成 lua 脚本|学习笔记
|
Python
Python编程:reload热更新代码
Python编程:reload热更新代码
276 0
|
前端开发 JavaScript API
基于webpack的热重载live reload和热更新HMR(上)
在前端应用框架中不管是react还是vue,官方都提供了相应的脚手架方便开发者快速入手,当我们在开发时修改某个js或者css文件时,webpack会自动编译我们的文件,我们刷新浏览器就可以看到编译后的文件。为此我们会想,如果我们修改保存之后,文件被编译、浏览器自动刷新、或者浏览器局部刷新(不刷新整个浏览器),这样的话多好。当然,基于webpack打包工具的相关库已经实现了。下面对此部分流程做简单的分析
|
JavaScript 前端开发 开发者
基于webpack的热重载live reload和热更新HMR(中)
在前端应用框架中不管是react还是vue,官方都提供了相应的脚手架方便开发者快速入手,当我们在开发时修改某个js或者css文件时,webpack会自动编译我们的文件,我们刷新浏览器就可以看到编译后的文件。为此我们会想,如果我们修改保存之后,文件被编译、浏览器自动刷新、或者浏览器局部刷新(不刷新整个浏览器),这样的话多好。当然,基于webpack打包工具的相关库已经实现了。下面对此部分流程做简单的分析
|
缓存 前端开发 JavaScript
基于webpack的热重载live reload和热更新HMR(下)
在前端应用框架中不管是react还是vue,官方都提供了相应的脚手架方便开发者快速入手,当我们在开发时修改某个js或者css文件时,webpack会自动编译我们的文件,我们刷新浏览器就可以看到编译后的文件。为此我们会想,如果我们修改保存之后,文件被编译、浏览器自动刷新、或者浏览器局部刷新(不刷新整个浏览器),这样的话多好。当然,基于webpack打包工具的相关库已经实现了。下面对此部分流程做简单的分析