swoole如何获取uid

尚
原创
2019-12-13 16:56:51 3741浏览

swoole中可以使用Server->bind获取uid,Server->bind将连接绑定一个用户定义的UID,可以设置dispatch_mode=5设置以此值进行hash固定分配。可以保证某一个UID的连接全部会分配到同一个Worker进程。

function Server->bind(int $fd, int $uid);

$fd:连接的ID

$uid:要绑定的UID,必须为非0的数字

未绑定UID时默认使用fd取模进行分配

同一个连接只能被bind一次,如果已经绑定了UID,再次调用bind会返回false
可以使用$serv->getClientInfo($fd) 查看连接所绑定UID的值
仅在设置dispatch_mode=5时有效

在默认的dispatch_mode=2设置下,Server会按照socket fd来分配连接数据到不同的Worker进程。因为fd是不稳定的,一个客户端断开后重新连接,fd会发生改变。

这样这个客户端的数据就会被分配到别的Worker。使用bind之后就可以按照用户定义的UID进行分配。即使断线重连,相同UID的TCP连接数据会被分配相同的Worker进程。

推荐学习: swoole视频教程

以上就是swoole如何获取uid的详细内容,更多请关注php中文网其它相关文章!

声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。