hot-reload

用于开发过程中的代码热重载

组件要求

  • easyswoole/component: ^2.0
  • easyswoole/spl: ^1.3
  • easyswoole/utility: ^1.1

安装方法

composer require easyswoole/hot-reload

仓库地址

easyswoole/hot-reload

基本使用

单独使用

  1. // 创建一个服务
  2. require_once 'vendor/autoload.php';
  3. $server = new \Swoole\Server('0.0.0.0', '9801');
  4. $server->on('receive', function () {});
  5. // 设置监视器的选项
  6. $hotReloadOptions = new \EasySwoole\HotReload\HotReloadOptions;
  7. // 虚拟机中可以关闭Inotify检测
  8. $hotReloadOptions->disableInotify(true);
  9. // 可以设置多个监控目录的绝对路径
  10. $hotReloadOptions->setMonitorFolder([dirname(__FILE__)]);
  11. // 忽略某些后缀名不去检测
  12. $hotReloadOptions->setIgnoreSuffix(['php', 'txt']);
  13. // 自定义检测到变更后的事件
  14. $hotReloadOptions->setReloadCallback(function (\Swoole\Server $server) {
  15. echo "File change event triggered"; // 可以执行如清理临时目录等逻辑
  16. $server->reload(); // 接管变更事件 需要自己执行重启
  17. });
  18. $hotReload = new \EasySwoole\HotReload\HotReload($hotReloadOptions);
  19. $hotReload->attachToServer($server);
  20. $server->start();

EasySwoole框架中使用

请在全局事件(EasySwooleEvent)的mainServerCreate方法中进行注册

  1. class EasySwooleEvent {
  2. // 省略部分代码 ...
  3. /**
  4. * 服务启动时
  5. * @param EventRegister $register
  6. * @throws Exception
  7. */
  8. public static function mainServerCreate(EventRegister $register)
  9. {
  10. // 配置同上别忘了添加要检视的目录
  11. $hotReloadOptions = new \EasySwoole\HotReload\HotReloadOptions;
  12. $hotReload = new \EasySwoole\HotReload\HotReload($hotReloadOptions);
  13. $hotReloadOptions->setMonitorFolder([EASYSWOOLE_ROOT . '/App']);
  14. $server = ServerManager::getInstance()->getSwooleServer();
  15. $hotReload->attachToServer($server);
  16. }
  17. // 省略部分代码 ...
  18. }

注意

方便的热重载组件,在Linux环境下使用Inotify,其他环境或虚拟机内使用iNode脏检测扫描实现开发过程中的代码热重载,可自定义重载处理逻辑,由于可以自定义,也可以作为一个方便的文件变更事件触发器使用,在文件变更时执行一些逻辑

!!!警告!!! 仅供开发使用,请勿在生产环境使用,以免意外重启造成逻辑异常