## 开发注意事项
MixPHP 的 Web 应用是运行在 HTTP 服务器 mix-httpd 内,而 mix-httpd 基于 swoole_server 开发,其本质上就是一个持续运行的命令行应用程序,所以会有下面这些注意事项。
### 1. 热更新
在开发阶段我们希望编写的代码能够实时生效, 马上看到效果, 这个时候我们需要热更新功能,实现热更新我们只需要在 mix-httpd 的启动命令加上 `-u` 参数,命令如下:
~~~shell
mix-httpd service start -d -u
~~~
>[info] - 该机制只能热加载应用层代码, 如果涉及 composer.json、路由、框架源码修改则需要重启服务器。
> - 需关闭 PHP 的 OPcache。
> - -u 会使 worker 只处理一次请求就销毁,所以不要在生产环境中使用。
开发阶段你也可以在 Apache/PHP-FPM 中部署,这样就能在 Windows 系统中做开发,也没有热更新问题,完成开发后再部署至 MixHttpd 即可。
### 2. 全局变量
有3类全局变量:
* 使用 `global` 关键词声明的变量
* 使用 `static` 关键词声明的类静态变量、函数静态变量
* PHP的超全局变量,包括 `$_GET`、`$_POST`、`$GLOBALS` 等
swoole_server 中**全局变量,类静态变量当次请求结束后不会被释放,下次请求时还在**,需要程序员自行处理这些变量的销毁工作,所以:
>[danger] 1. 不要有全局变量递增操作,如: Im::$msg[] = 'msg'; Im::$msg .= 'msg'; 。
> 2. 不要使用PHP提供的GET/POST,请使用框架提供的 request 组件。
### 3. exit/die
代码中任何位置都不能使用 `exit`、`die`,使用它们会导致当前进程终止运行,所以:
>[danger] 采用 app()->end(); 来替代 exit、die。
### 4. Session
基于 MixHttpd 的 Web 本质上是运行在一个CLI程序中,所以PHP原生的Session是无法使用的,MixPHP为该环境下单独实现了一套Session,所以:
>[danger] 不要使用PHP提供的Session,请使用MixPHP提供的 session 组件。
- 欢迎使用 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
- 错误级别配置不生效
- 推进计划
- 文档历史