## 命令行开发常识
由于 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
- 错误级别配置不生效
- 推进计划
- 文档历史