- 37
- 0
//SOCKET链接服务器
public function Connect($info)
{
$val=$info;
$w_file = '../config.txt';
file_put_contents($w_file,$val,FILE_APPEND);//'W+'读写方式打开
set_time_limit(0);
$host = self::TCP_SER_HOST;
$port = self::TCP_SER_PORT;
$socket = socket_create(AF_INET, SOCK_STREAM, SOL_TCP)or die("Could not create socket\n"); // 创建一个Socket
socket_set_option($socket,SOL_SOCKET,SO_RCVTIMEO,array("sec"=>self::SO_RCVTIMEO, "usec"=>0 ) );//超时时间设置7s
socket_set_option($socket,SOL_SOCKET,SO_SNDTIMEO,array("sec"=>self::SO_RCVTIMEO, "usec"=>0 ) );//超时时间设置7s
$connection = socket_connect($socket, $host, $port) or die("Could not connet TCP server\n");
socket_write($socket, $val) or die("Write failed\n"); // 数据传送 向服务器发送消息,将内容写入fd中
while (true)
{
$buff = socket_read($socket, 1024);//从套接字读取一个最大长度字节
if($buff)
{
$back=$buff;
break;
}
else
{
$back='{"kill":"kill","err":-10}';
break;
}
}
$back=json_decode($back, true);
socket_shutdown($socket);
socket_close($socket);
return $back;
}
该图是客户端的socket,通过它连接gatewayworker,采用的是tcp协议
现在遇到了两个问题:
问题一:调用客户端socket发送数据到服务器时,会出现重发的情况,排除了页面刷新情况,同时在connect()函数的第一行记录了日志,发现了重发指令,基本都是一分钟之后重发的。我的指令类似于{"syn":"log","time":120},然后一分钟之后,就会又出现一条指令{"syn":"log","time":60},时间刚好是一分钟,这种情况有时候会一直出现,有时候又不会出现,在connect()函数第一行打印出重发指令是说明这个函数被重新调用了吗?
问题二:我在gatewayworker的events文件中打印数据可以看到我客户端发送到服务端的数据,服务端发送到设备端,然后设备端发送到服务端的数据,从客户端发起指令,到服务端接受设备端回复的指令,中间也就两三秒的时间,但是我客户端却一直显示通信超时,从图中可以看到,我设置的通信超时的时间为7秒,发送和接受都是7秒,但是从服务端打印的数据来看,服务器时已经收到了设备回复的指令,只是socket客户端却迟迟没有收到,这是为什么?
还请大神赐教
0
打赏
收藏
点击回答
网站公告
- 扫一扫访问手机版
回答动态

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器更新之后。服务器里面有部分玩家要重新创建角色是怎么回事啊?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题函数计算不同地域的是不能用内网吧?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题ARMS可以创建多个应用嘛?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题在ARMS如何申请加入公测呀?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题前端小程序接入这个arms具体是如何接入监控的,这个init方法在哪里进行添加?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器刚到期,是不是就不能再导出存档了呢?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器的游戏版本不兼容 尝试更新怎么解决?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器服务器升级以后 就链接不上了,怎么办?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器转移以后服务器进不去了,怎么解决?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器修改参数后游戏进入不了,是什么情况?预计能赚取 0积分收益
- 回到顶部
- 回到顶部

