syn重发_workerman 重发问题

//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
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值