第3节、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);
		});

猜你喜欢

转载自blog.csdn.net/qq_41417172/article/details/89237853