## 環境要求
* Linux, OS X, WSL
* PHP >= 7.2
* Swoole >= 4.4.4 (websocket >= 4.4.15)
## 環境搭建
### 安裝 Swoole 擴展
推薦 [編譯安裝](https://wiki.swoole.com/wiki/page/6.html):
~~~
$> wget ***.tar.gz
$> tar zxvf ***.tar.gz
$> cd swoole-src
$> phpize
$> ./configure --enable-openssl --with-php-config=/usr/local/php72/bin/php-config
$> make && sudo make install
~~~
### 安裝 MixPHP
> 不要使用 git clone 安裝
使用 [composer](https://www.phpcomposer.com/) 安裝:
```shell
// 常規安裝
composer create-project --prefer-dist mix/mix-skeleton mix ~2.1.0
// 忽略擴展檢查安裝
composer create-project --prefer-dist --ignore-platform-reqs mix/mix-skeleton mix ~2.1.0
```
## 確認安裝成功
查看幫助:
~~~
$> php bin/mix.php --help
~~~
啟動 HTTP 服務器:
~~~
$> php bin/mix.php web:start
~~~
訪問測試 (新開一個終端):
~~~
$> curl http://127.0.0.1:9501/
Hello World
~~~
如果顯示 "Hello World" 的歡迎語那就表示 MixPHP 已經正常運行。
### 安裝熱更新工具
- SwooleFor:[https://github.com/mix-php/swoolefor](https://github.com/mix-php/swoolefor)
### 增加 Nginx 反向代理
反向代理主要負責靜態文件處理和負載均衡,直接復制下面的配置。
~~~
server {
server_name www.test.com;
listen 80;
root /data/mix/public;
location / {
proxy_http_version 1.1;
proxy_set_header Connection "keep-alive";
proxy_set_header Host $http_host;
proxy_set_header Scheme $scheme;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
if (!-f $request_filename) {
proxy_pass http://127.0.0.1:9501;
}
}
}
~~~
>[info] 在 MixPHP 中通過讀取 $request->getHeaderLine('x-real-ip') 或者 $request->getHeaderLine('x-forwarded-for') 來獲取客戶端的真實IP。
- 歡迎使用 MixPHP
- 安裝說明
- 全棧安裝
- Phar 開發安裝
- 新手教程
- 命令行常識
- 進程管理
- 熱更新
- 全局變量
- 入門須知
- 命名空間
- 自動加載
- 入口文件
- 增改應用
- 核心功能
- 配置 (manifest.php)
- 協程
- 什么是協程
- 開啟協程
- PHP Stream Hook
- xgo + Channel
- WaitGroup + xdefer
- 連接池
- 協程池
- 定時器
- 依賴注入
- 事件調度
- 命令行
- 簡介
- Application
- 創建命令
- 命令參數
- 打印與顏色
- 守護進程
- 后臺運行
- Web/API 應用
- 簡介
- 服務器
- 路由
- 中間件
- 請求
- 文件上傳
- 響應
- 控制器
- 視圖
- Auth
- Session
- 客戶端
- GuzzleHttp
- 調試與錯誤
- 安全建議
- WebSocket 應用
- 簡介
- 服務器
- 客戶端
- JavaScript
- Swoole
- nginx代理
- 60s無消息斷線
- TCP 應用
- 簡介
- 服務器
- 客戶端
- Telnet
- PHP
- Swoole
- UDP 應用
- 簡介
- 服務器
- 客戶端
- NC
- Swoole
- Sync Invoke 同步調用
- 簡介
- 服務器
- 客戶端
- 公共組件
- 驗證器
- 驗證器定義
- 驗證規則
- 靜態調用
- 日志
- 緩存
- 數據庫
- Database
- ConnectionPool
- Connection
- QueryBuilder
- ExecutedEvent
- Redis
- ConnectionPool
- Connection
- CalledEvent
- 常見問題
- 如何利用CPU多核
- 連接多個數據庫
- 使用主從數據庫
- 如何設置跨域
- form-data 上傳文件失敗
- 輸出大于2M的文件失敗 (xlsx)
- 如何接入EasyWeChat
- 升級指導
- 不兼容修改-001
- 不兼容修改-002
- 不兼容修改-003