关于GatewayClient 介绍和使用

GatewayClient

## 源码

https://github.com/walkor/GatewayClientphp

根据GatewayWorker版本,选择合适的GatewayClient版本,请参照【如何知道使用的GatewayWorker版本号?html

 

 

注意:GatewayClient3.0.0之后支持composer并加了命名空间GatewayClient git

 

注意:

1.若是GatewayClientGatewayWorker不是在同一台服务器上,则须要先将start_gateway.php中的lanIp改为当前服务器的内网ip(若是不在一个内网可改为公网ip)。github

2.若是GatewayClient和GatewayWorker在同一台服务器上运行,则不用作任何更改,直接按照示例使用GatewayClient便可。服务器

3.经过GatewayClient发送的数据不会通过Event.php,而是直接经由Gateway进程转发给客户端session

4.GatewayClient没法接收客户端发来的数据。composer

 

## 安装(composer安装适用于3.0.0及以上版本)

composer require workerman/gatewayclient

## 客户端使用示例

require_once '/your/path/GatewayClient/Gateway.php'; /** * gatewayClient 3.0.0及以上版本加了命名空间 * 而3.0.0如下版本不须要use GatewayClient\Gateway; **/ use GatewayClient\Gateway; /** *====这个步骤是必须的==== *这里填写Register服务的ip(一般是运行GatewayWorker的服务器ip)和端口 *注意Register服务端口在start_register.php中能够找到(chat默认是1236) *这里假设GatewayClient和Register服务都在一台服务器上,ip填写127.0.0.1 *注意:ip不能是0.0.0.0 **/ Gateway::$registerAddress = '127.0.0.1:1236'; // 如下是调用示例,接口与GatewayWorker环境的接口一致 // 接口具体使用方法见《Lib\Gateway类提供的接口》一章 // 注意除了不支持sendToCurrentClient和closeCurrentClient方法 // 其它方法都支持 Gateway::sendToAll($data); Gateway::sendToClient($client_id, $data); Gateway::closeClient($client_id); Gateway::isOnline($client_id); Gateway::bindUid($client_id, $uid); Gateway::isUidOnline($uid); Gateway::getClientIdByUid($uid); Gateway::unbindUid($client_id, $uid); Gateway::sendToUid($uid, $data); Gateway::joinGroup($client_id, $group); Gateway::sendToGroup($group, $data); Gateway::leaveGroup($client_id, $group); Gateway::getClientCountByGroup($group); Gateway::getClientSessionsByGroup($group); Gateway::getAllClientCount(); Gateway::getAllClientSessions(); Gateway::setSession($client_id, $session); Gateway::updateSession($client_id, $session); Gateway::getSession($client_id);
相关文章
相关标签/搜索