grpc-go源码剖析七十之保持链接keepalive介绍

本文介绍了gRPC-Go中Keepalive机制的作用,用于检测客户端和服务器之间的链接活跃性。Keepalive功能确保在规定时间内能接收到数据帧,否则可能表示链接异常。此外,服务器端还处理链接闲置和运行时长超时的情况。每个http2连接有一个独立的keepalive协程。健康检查关注服务器进程健康,而Keepalive关注数据传输。下文将探讨如何在客户端和服务器端启用Keepalive功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

从本节开始介绍保持链接原理;

1、keepalive相关介绍?

  • keepalive主要目的是
    • 用来检测客户端和服务器端的链接是否还在传输数据。
    • 在规定的时间内,链接是否还能接收到数据,如果能接收到数据,或者接收到各种类型的帧,就说明此链接当前运行正常;
    • 如果在规定的时间内,接收不到任何帧,此链接可能存在异常情况
  • 服务器端keeplive的其他两个功能:
    • 当链接处于idle状态的时长,超过了规定的时长时的处理逻辑
    • 任何链接运行时长,超过了规定的时间的处理逻辑
  • 一个http2Client或者http2Server对象,对应一个keepalive协程。在服务器端,并不是一个keepalive处理所有的链接。
  • 客户端和服务器端都可以单独启动keepalive功能,互不影响。