# Client TCP客户端连接池 [TOC] ## 添加连接池 首先我们打开AppServer,添加连接池的声明。 ```php $this->addAsynPool('RPC',new TcpClientPool($this->config,'test',"192.168.0.1:9093")); ``` >test指的是应用的配置名 使用tcpClientPool需要注意的是,你需要配置client.php ``` $config['tcpClient']['asyn_max_count'] = 10; $config['tcpClient']['test']['pack_tool'] = 'JsonPack'; ``` * asyn_max_count指的是连接池最大的数量 * pack_tool是使用封装器的名称。 注意,如果是和SD服务器通讯那么请使用SdTcpRpcPool,而不是TcpClientPool。 ## 使用方法 首先获取连接池 ``` /** * @var TcpClientPool */ public $rpc; public function __construct($proxy = ChildProxy::class) { parent::__construct($proxy); $this->rpc = get_instance()->getAsynPool("RPC"); } ``` 然后我们开始写业务逻辑 ``` public function http_tcpClient() { $data = ['controller_name'=>"TestController","method_name"=>"testTcp","data"=>"test"]; $this->rpc->setPath("TestController/testTcp",$data); $result = $this->rpc->coroutineSend($data); $this->http_output->end($result); } ``` >这里setPath方法将为$data添加一个path字段,框架规定必须有path字段,当然这个path字段不会被作为消息发出。 其中controller_name和method_name是作为SD的NormalRoute路由必须条件存在的字段,这个请根据需要访问的服务器实际情况进行设置。 框架会根据设置的封装器进行消息的封装,coroutineSend后面只需要携带原始消息,不必做多余的封装。 封装协议的操作请到封装器中书写。