//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客户端却迟迟没有收到,这是为什么?
还请大神赐教
{"syn":"log","time":120}过了一分钟又出现了{"syn":"log","time":60}
这个说明是业务逻辑哪里出错了,看看哪里会组装这样的包可能会对定位有帮助
关于第二个问题要看业务代码里有没有在服务端给你写的这个客户端发送返回数据,没有当然就收不到了