Swoole的client的简介
1、client客户端
Client提供了TCP/UDP socket的客户端的封装代码,使用时仅需 new Swoole\Client 即可。
除了普通的同步阻塞+select的使用方法外,Client还支持异步非阻塞回调。
2、同步阻塞客户端,示例代码
$client = new swoole_client(SWOOLE_SOCK_TCP);
if (!$client->connect('127.0.0.1', 9501, -1))
{
exit("connect failed. Error: {$client->errCode}\n");
}
$client->send("hello world\n");
echo $client->recv();
$client->close();
3、异步非阻塞客户端,示例代码
$client = new Swoole\Client(SWOOLE_SOCK_TCP, SWOOLE_SOCK_ASYNC);
$client->on("connect", function(swoole_client $cli) {
$cli->send("GET / HTTP/1.1\r\n\r\n");
});
$client->on("receive", function(swoole_client $cli, $data){
echo "Receive: $data";
$cli->send(str_repeat('A', 100)."\n");
sleep(1);
});
$client->on("error", function(swoole_client $cli){
echo "error\n";
});
$client->on("close", function(swoole_client $cli){
echo "Connection close\n";
});
$client->connect('127.0.0.1', 9501);
4、示例代码分析
(1)、建立client连接
$client = new Swoole\Client(SWOOLE_TCP | SWOOLE_ASYNC | SWOOLE_SSL);
- 第一个SWOOLE_TCP代表客户端是tcp连接还支持 SWOOLE_UDP(udp连接)
- 第二个参数便是时候是异步客户端的区分SWOOLE_ASYNC 表示异步
- 第三个参数SSL/TLS,依赖openssl库,需要在编译swoole时增加enable-openssl或with-openssl-dir,必须在定义Client时增加SWOOLE_SSL。目前注意的是低于1.9.5版本在设置ssl_key_file后会自动启用SSL
(2)、连接事件的监听,会进入回调函数
(3)、接收事件的监听,会进入回调函数
如果客户端有返回数据在这里面可以看到具体的返回值,如果是异步客户端,发送数据就要在回调函数里面进行
(4)、error报错事件的监听,会进入回调函数
(5)、关闭事件的监听,会进入回调函数
(6)、同步阻塞和异步非阻塞的区别
同步阻塞的时候,向服务端发送数据和接受服务端的返回值都是直接写在外部;
$client->send("hello world\n");
echo $client->recv();
异步非阻塞,则需要回调函数里面来做
$client->on("connect", function(swoole_client $cli) {
$cli->send("GET / HTTP/1.1\r\n\r\n");
});
$client->on("receive", function(swoole_client $cli, $data){
echo "Receive: $data";
$cli->send(str_repeat('A', 100)."\n");
sleep(1);
});