## 命令行开发常识 由于 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.[***]')` 通过配置实例化数据库客户端操作数据库。