通過(guò) phpstorm 配置熱更新開(kāi)發(fā)環(huán)境
在開(kāi)發(fā) Hyperf/swoole 這樣的持久化應(yīng)用時(shí),每當(dāng)應(yīng)用代碼發(fā)生了變更時(shí),都需要重啟應(yīng)用使代碼生效,盡管在開(kāi)發(fā) CLI 應(yīng)用時(shí)這也是一個(gè)正確且合理地操作,因?yàn)槲覀冮_(kāi)發(fā)過(guò)程中仍需要關(guān)注 stdout 輸出的信息以判斷應(yīng)用的運(yùn)行狀態(tài)與結(jié)果。但這跟我們?cè)瓉?lái)開(kāi)發(fā) php-FPM 應(yīng)用的習(xí)慣有很大的差異,如果我們希望保持像 PHP-FPM 下的開(kāi)發(fā)習(xí)慣,保存代碼即生效的話,都能怎么做呢?
根據(jù)「Hyperf 官方文檔 – 協(xié)程組件庫(kù)」一章內(nèi)的介紹,有幾款第三方工具可以提供該功能的支持,但如果我們使用的是 phpstorm 來(lái)進(jìn)行開(kāi)發(fā),那么我們可以直接通過(guò) PHPStorm 里面的 FileWatcher 來(lái)實(shí)現(xiàn)該功能。
實(shí)現(xiàn)的原理就是通過(guò) FileWatcher 來(lái)監(jiān)聽(tīng)項(xiàng)目下的文件變更,然后執(zhí)行一個(gè) shell 腳本,通過(guò)這個(gè) shell 腳本來(lái)進(jìn)行應(yīng)用的重啟工作。
創(chuàng)建 reload.sh
立即學(xué)習(xí)“PHP免費(fèi)學(xué)習(xí)筆記(深入)”;
首先我們先在 skeleton 的 bin 目錄下創(chuàng)建一個(gè) reload.sh 文件,并寫(xiě)入以下 Shell 代碼:
#!/bin/bash basepath=$(cd?`dirname?$0`;?pwd) cd?$basepath if?[?-f?"../runtime/hyperf.pid"?];then cat?../runtime/hyperf.pid?|?awk?'{print?$1}'?|?xargs?kill?&&?rm?-rf?../runtime/hyperf.pid?&&?rm?-rf?../runtime/container fi php?hyperf.php?start
這里的 shell 腳本所做的事情就是判斷 ./runtime/hyperf.pid 文件是否存在,如果存在則根據(jù)這個(gè) pid 文件來(lái) kill 掉已運(yùn)行的應(yīng)用,并刪除掉這個(gè) pid 文件,隨后通過(guò)執(zhí)行 php bin/hyperf.php start 命令來(lái)啟動(dòng)應(yīng)用
設(shè)置應(yīng)用為守護(hù)進(jìn)程運(yùn)行
由于設(shè)置了熱更新,那我們也需要把應(yīng)用設(shè)置為守護(hù)進(jìn)程運(yùn)行,在 Hyperf 里可以通過(guò)在 config/autoload/server.php 的 settings 中增加 daemonize 并設(shè)置為 true,參考配置如下:
<?php // 這里省略了其它配置 return [ 'settings' =>?[ ????????'daemonize'?=>?1, ????], ];
配置 FileWatcher
接下來(lái)我們?cè)?PHPStorm 中配置 FileWatcher 的規(guī)則,通過(guò) Preferences -> Tools -> File Watchers 進(jìn)入配置頁(yè)面,然后點(diǎn)擊底部的 + 添加一個(gè)配置,參考配置如下:
Name:?php File?Type:?PHP Scope:?Project?Files Program:?sh Arguments:?$ProjectFileDir$/bin/reload.sh Show?Console:?Always
然后在列表我們要再將我們剛才創(chuàng)建的 watcher 勾選為 enabled
完成
至此,我們便完成了所有的配置,此時(shí)我們僅需通過(guò) sh bin/reload.php 命令來(lái)啟動(dòng)應(yīng)用,隨后更改文件我們便會(huì)在 ide 上看到如下的 output 窗口輸出重啟的信息了。