7.tcp粘包处理1

1.什么是 TCP 粘包?
TCP 粘包是指发送方发送的若干包数据 到 接收方接收时粘成一包,从接收缓冲区看,后一包数据的头紧接着前一包数据的尾。
2.TCP 出现粘包的原因?
发送方:发送方需要等缓冲区满才发送出去,造成粘包
接收方:接收方不及时接收缓冲区的包,造成多个包接收
3.粘包的处理

//-----客户端处理
$client = new swoole_client(SWOOLE_SOCK_TCP,SWOOLE_SOCK_SYNC);
$client->connect('127.0.0.1',9800);
//发送数据,需要做粘包处理
//$client->send('我是客户端');

//为了处理粘包,我们和服务端约定一个分隔符(比如\r\n)
for($i=0;$i<10;$i++){
    $client->send("123456\r\n");
}

//接收数据
var_dump($client->recv());

//关闭,关闭不能这么草率,需要做应答
$client->close();

//-----服务端处理
//接收到客户端消息
$server->on('receive',function($server, $fd, $from_id, $data){
    //echo "接收到客户端消息:{$fd}".PHP_EOL;
    $server->send($fd, "Server: 我是服务端");
    $data = explode("\r\n",$data);
    /*foreach($data as $v){
        if(!empty($v)){
            var_dump($v);
        }
    }*/
    var_dump($data);
});


//处理打印 var_dump($data);
//处理之前看到的数据
123456123456123456123456123456123456

//处理之后看到的数据
array(11) {
  [0]=>
  string(6) "123456"
  [1]=>
  string(6) "123456"
  [2]=>
  string(6) "123456"
  [3]=>
  string(6) "123456"
  [4]=>
  string(6) "123456"
  [5]=>
  string(6) "123456"
  [6]=>
  string(6) "123456"
  [7]=>
  string(6) "123456"
  [8]=>
  string(6) "123456"
  [9]=>
  string(6) "123456"
  [10]=>
  string(0) ""
}

在swoole中怎么处理的呢?

//EOF 结束协议
//通过约定结束符,来确定包数据是否发送完毕
//开启open_eof_check=true,并用package_eof来设置一个完整数据结尾字符,同时设置自动拆分open_eof_split
$server->set([
    'worker_num'=>2,
    'open_eof_check'=>true,
    'package_eof'=>"\r\n",
    'open_eof_split'=>true
]);

注意:
1、要保证业务数据里不能出现package_eof设置的字符,否则将导致数据错误了。
2、可以手动拆包,去掉open_eof_split,自行 explode("\r\n", $data),然后循环发送





你可能感兴趣的:(7.tcp粘包处理1)