## 命令行開發常識
由于 CLI 開發,并不像 HTTP 服務開發一樣在 PHPer 中如此普及,所以該章節針對命令行開發的一些常識,整理說明一下:
>[danger] - 命令行應用全部是常駐內存的。
> - 命令行應用中開啟的 Mysql / Redis 等連接只要不主動去關閉該連接,那都是長連接。
## 命令行開發的分類
命令行開發的分類并不像 HTTP 服務一樣清晰,但 MixPHP 依然根據需求特征進行了分類:
- 控制臺程序,如:清理數據、統計數據、數據轉換等。
- 守護程序,如:消息隊列消費處理,數據入庫,消息推送,數據爬取等。
## 各分類在 MixPHP 中對應的開發目錄
各類型在框架中對應的目錄如下:
~~~txt
apps/
├── console
├── daemon
~~~
## 命令行開發注意事項
### 數據庫連接處理
**控制臺程序:**
控制臺程序是一次性執行,執行完就結束,所以不需要考慮數據庫連接超時問題,數據庫連接采用短連接即可。
**守護程序:**
守護程序實際上就是個一直在持續執行的控制臺程序,所以需要考慮數據庫連接超時問題,傳統 MVC 框架,需要手動使用 try/catch 來重啟循環流程,并手動重建數據庫連接,而 MixPHP 不需要,你只需要使用長連接版本的數據庫客戶端即可,MixPHP 會幫你重建連接,你什么都不需要處理。
### 蛻變為守護進程
PHP 在 CLI 模式下執行,正常是無法蛻變為一個守護進程的,通常傳統 PHP 開發是使用以下方法脫離終端在后臺運行。
~~~shell
php command.php >/dev/null 2>&1 &
~~~
MixPHP 提供了更方便的方法,只需要控制器代碼第一行,增加:
~~~
public function actionIndex()
{
// 蛻變為守護進程
ProcessHelper::daemon();
// ...
return ExitCode::OK;
}
~~~
>[danger] 該方法依賴 Swoole 擴展,Windows下無法執行。
### 命令行應用如何操作數據庫
命令行程序由于數據邏輯的復雜性,實際上是不適合 `MVC ` 分層開發的,所以我們 **不推薦以組件的形式在命令行使用數據庫客戶端**,我們推薦在命令行開發中直接在 `Command` 類中使用 `Class::newInstanceByConfig('libraries.[***]')` 通過配置實例化數據庫客戶端操作數據庫。
- 歡迎使用 MixPHP
- 安裝說明
- 常規安裝
- 只安裝命令行
- Apache/PHP-FPM安裝
- 開發與調試
- 開發注意事項
- 調試與錯誤
- 基礎架構
- 目錄結構
- 目錄設計
- URL訪問
- 命名空間
- 自動加載
- 入口文件
- 框架核心
- Application
- 配置
- 對象
- 組件
- 門面
- 系統服務
- 中間件
- 驗證器
- 驗證器定義
- 驗證規則
- 靜態調用
- 模型
- 日志
- 命令行
- 簡介
- 命令行開發常識
- 創建命令
- 執行與選項
- 控制臺程序
- 守護程序
- HTTP 服務
- 簡介
- 服務器
- 路由
- 請求
- 響應
- 控制器
- 視圖
- Token
- Session
- Cookie
- 文件上傳
- 圖片處理
- 分頁
- 驗證碼
- WebSocket 服務
- 簡介
- 回調函數
- 消息處理器
- 客戶端測試
- nginx代理
- 60s無消息斷線
- 多進程
- ProcessPoolTaskExecutor
- 流水線模式
- 推送模式
- 在 Supervisor 中使用
- 協程
- 簡介
- 如何開啟協程
- HTTP 協程開發
- 命令行協程開發
- 客戶端
- MySQL
- PDO
- PDOPersistent
- PDOMasterSlave
- PDOCoroutine
- Redis
- Redis
- RedisPersistent
- RedisCoroutine
- 外部工具庫
- 簡介
- think-orm
- psr-log
- 安全建議
- 常見問題
- 啟動多個 HTTP 服務器
- 連接多個數據庫
- 如何設置跨域
- mix-httpd service stop 無效
- No such file or directory
- 錯誤級別配置不生效
- 推進計劃
- 文檔歷史