第2节、Swoole的server服务端的简介
  tioZNIEOTNwl 2023年11月02日 25 0



Swoole的server的简介

  • 1、Server服务端
  • 2、示例
  • 3、swoole_server参数说明
  • (1)$host
  • (2)$port监听的端口,如9501
  • (3)$mode运行的模式
  • (4)$sock_type


1、Server服务端

创建一个异步服务器程序,支持TCP、UDP、UnixSocket 3种协议,支持IPv4和IPv6,支持SSL/TLS单向双向证书的隧道加密。使用者无需关注底层实现细节,仅需要设置网络事件的回调函数即可。

请勿在使用Server创建之前调用其他异步IO的API,否则将会创建失败。可以在Server启动后onWorkerStart回调函数中使用。

2、示例

以下基本是固定写法,第一步定义好host和端口等;第二步便是设置选项;接着就是进入connect事件,和接收数据的事件,最后的还有服务端的关闭事件;最后的启动服务器一定不要忘了。

//创建Server对象,监听 127.0.0.1:9501端口
	$serv = new swoole_server("127.0.0.1", 9501); 
	
	//配置选项
	$serv->set(array(
	    'worker_num' => 4,    //worker process num
	    'backlog' => 128,   //listen backlog
	    'max_request' => 50,
	    'dispatch_mode'=>1, 
	));	

	//监听连接进入事件
	$serv->on('connect', function ($serv, $fd) {  
	    echo "Client: Connect.\n";
	});
	
	//监听数据接收事件
	$serv->on('receive', function ($serv, $fd, $from_id, $data) {
	    $serv->send($fd, "Server: ".$data);
	});
	
	//监听连接关闭事件
	$serv->on('close', function ($serv, $fd) {
	    echo "Client: Close.\n";
	});
	
	//启动服务器
	$serv->start();

3、swoole_server参数说明

$serv = new Server(string $host, int $port = 0, int $mode = SWOOLE_PROCESS, int $sock_type = SWOOLE_SOCK_TCP);

(1)$host

参数用来指定监听的ip地址,如127.0.0.1,或者外网地址,或者0.0.0.0监听全部地址 IPv4使用
127.0.0.1表示监听本机,0.0.0.0表示监听所有地址 IPv6使用::1表示监听本机,:: (相当于0:0:0:0:0:0:0:0) 表示监听所有地址

(2)$port监听的端口,如9501

如果$sock_type为UnixSocket Stream/Dgram,此参数将被忽略
监听小于1024端口需要root权限
如果此端口被占用server->start时会失败

(3)$mode运行的模式

SWOOLE_PROCESS多进程模式(默认)
SWOOLE_BASE基本模式

(4)$sock_type

指定Socket的类型,支持TCP、UDP、TCP6、UDP6、UnixSocket Stream/Dgram 6种

这里只做个简单的概述,可以去查看更详细的 swoole官网server手册


【版权声明】本文内容来自摩杜云社区用户原创、第三方投稿、转载,内容版权归原作者所有。本网站的目的在于传递更多信息,不拥有版权,亦不承担相应法律责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@moduyun.com

  1. 分享:
最后一次编辑于 2023年11月08日 0

暂无评论

推荐阅读
tioZNIEOTNwl