Skip to content

客户端流导致的channel复用没有初始话 #19

@wangsir-mini

Description

@wangsir-mini

对于一个客户端流来说 服务端调用了SendAndClose

Image

客户端函数runReceiveCoroutine 对这个流进行revc 实际上进行了3次
第一次是正常的数据返回 但是客户端流只允许调用一次recv 就不会触发到GrpcClientrecv中的 if (($response === false && $channel->errCode === SWOOLE_CHANNEL_TIMEOUT) || ($response instanceof Response && ! $response->pipeline)) {

Image

第二次是关闭

第三次response 为false 走到了如下流程:

Image

closeRecv函数在进行channel 回收的时候没有判断channel里面是否有数据 直接进行了回收

下一个请求获取从channel池里面获取channel 获取到旧的channel 此时channel里面的数据 是第一次请求获取响应中的第二个响应及关闭响应 导致GrpcClient.php中recv进行读取的时候 读到的数据是关闭请求 之后才会触发重置和回收channal

Image
我尝试进行多读一次 和 在closeRecv进行channel->pop() 是可以解决这个问题

Image

Image

不知道是不是我的使用方式有什么问题?

Metadata

Metadata

Assignees

No one assigned

    Labels

    No labels
    No labels

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions