「连载九」gRPC Deadlines

    那么,肯定是有问题了。今天将介绍 gRPC Deadlines 的用法,这一个必备技巧。内容也比较简单

    Deadlines 意指截止时间,在 gRPC 中强调 TL;DR(Too long, Don’t read)并建议始终设定截止日期,为什么呢?

    当未设置 Deadlines 时,将采用默认的 DEADLINE_EXCEEDED(这个时间非常大)

    这会使服务面临资源耗尽的风险,例如内存,这会增加服务的延迟,或者在最坏的情况下可能导致整个进程崩溃

    Client

    • context.WithTimeout:很常见的另外一个方法,是便捷操作。实际上是对于 WithDeadline 的封装
    • status.FromError:返回 GRPCStatus 的具体错误码,若为非法,则直接返回

    而在 Server 端,由于 Client 已经设置了截止时间。Server 势必要去检测它

    否则如果 Client 已经结束掉了,Server 还傻傻的在那执行,这对资源是一种极大的浪费

    验证

    重新启动 server.go 和 client.go,得到结果:

    本章节比较简单,你需要知道以下知识点:

    • 怎么设置 Deadlines
    • 为什么要设置 Deadlines

    你要清楚地明白到,gRPC Deadlines 是很重要的,否则这小小的功能点就会要了你生产的命 🤫

    资料