# ports.php
配置服務器端口信息,這是一個非常重要的配置
```php
use Server\CoreBase\PortManager;
$config['ports'][] = [
'socket_type' => PortManager::SOCK_TCP,
'socket_name' => '0.0.0.0',
'socket_port' => 9091,
'pack_tool' => 'LenJsonPack',
'route_tool' => 'NormalRoute',
];
$config['ports'][] = [
'socket_type' => PortManager::SOCK_TCP,
'socket_name' => '0.0.0.0',
'socket_port' => 9092,
'pack_tool' => 'EofJsonPack',
'route_tool' => 'NormalRoute',
];
$config['ports'][] = [
'socket_type' => PortManager::SOCK_HTTP,
'socket_name' => '0.0.0.0',
'socket_port' => 8081,
'route_tool' => 'NormalRoute',
'method_prefix' => 'http_'
];
$config['ports'][] = [
'socket_type' => PortManager::SOCK_WS,
'socket_name' => '0.0.0.0',
'socket_port' => 8083,
'route_tool' => 'NormalRoute',
'pack_tool' => 'NonJsonPack',
'opcode' => PortManager::WEBSOCKET_OPCODE_TEXT
];
return $config;
```
通過此設置可以配置開啟多個端口,每個端口可以配置不同的封裝器和路由器。
其中http不需要封裝器可以不填寫。
可以通過命名回調函數來為每個端口提供不同的回調。
可以配置的字段名為:
```
-----------HTTP------------
request
handshake
------------WS-------------
open
message
close
handshake
---------TCP/UDP--------
connect
receive
close
packet
```
還有些特殊的配置
* method_prefix 設置該端口訪問的方法名前綴
* event_controller_name 設置該端口conect,close觸發的控制器名稱,不填默認使用Appserver設置的
* close_method_name 設置該端口close觸發的方法,不填默認使用Appserver設置的
* connect_method_name 設置該端口conect觸發的方法,不填默認使用Appserver設置的
>如果僅僅使用http協議可以直接使用下面的配置
>$config['ports'][] = [
'socket_type' => PortManager::SOCK_HTTP,
'socket_name' => '0.0.0.0', //0.0.0.0表示運行所有的ip訪問
'socket_port' => 8081, //開啟的端口為8081
'route_tool' => 'NormalRoute', //框架默認的路由就是NormalRoute
'method_prefix' => 'http_' //控制器訪問的前綴為'http_
];
## 關于前綴
框架為了隔離訪問添加了訪問方法前綴
比如8081端口設置了HTTP服務,method_prefix設置了前綴為http_。
通過NormalRoute作為默認路由的情況下,我們訪問localost:8081/Testcontroller/test將訪問到TestController控制器的http_test方法。
- SD3.X簡介
- 捐贈SD項目
- VIP服務
- 基礎篇
- 搭建環境
- 使用Composer安裝/更新SD框架
- 啟動命令
- 開發注意事項
- 框架配置
- 配置文件夾
- server.php
- ports.php
- business.php
- mysql.php
- redis.php
- timerTask.php
- log.php
- consul.php
- catCache.php
- client.php
- 自定義配置
- 框架入口
- MVC架構
- 加載器-Loader
- 控制器-Controller
- 模型-Model
- 視圖-View
- 同步任務-Task
- 封裝器
- Swoole編程指南-EOF協議
- Swoole編程指南-固定包頭協議
- 封裝器-Pack
- 路由器
- TCP相關
- 綁定UID
- Send系列
- Sub/Pub
- 獲取服務器信息
- Http相關
- HttpInput
- HttpOutput
- 默認路由規則
- WebSocket相關
- 使用SSL
- 公共函數
- 進階篇
- 內核優化
- 封裝器路由器原理剖析
- 對象池
- 上下文-Context
- 中間件
- 進程管理
- 創建自定義進程
- 進程間RPC
- 自定義進程如何使用連接池
- 異步連接池
- Redis
- Mysql
- Mqtt
- HttpClient
- Client
- AMQP
- RPC
- 日志工具-GrayLog
- 微服務-Consul
- Consul基礎
- 搭建Consul服務器
- SD中Consul配置
- 微服務
- 選舉-Leader
- Consul動態配置定時任務
- 熔斷與降級
- 集群-Cluster
- 高速緩存-CatCache
- 萬物-Actor
- Actor原型
- Actor的創建
- Actor間的通訊
- 消息派發-EventDispatcher
- 延遲隊列-TimerCallBack
- 協程
- 訂閱與發布
- MQTT簡易服務器
- AMQP異步任務調度
- 自定義命令-Console
- 調試工具Channel
- 特別注意事項
- 日常問題總結
- 實踐案例
- 物聯網自定義協議
- Actor在游戲的應用
- Mongodb以及一些同步擴展的使用
- 自定義進程使用MQTT客戶端
- 開發者工具
- SDHelper