gRPC服务健康检查(四):使用Golang实现gRPC服务健康检查工具

关键逻辑说明

因为gRPC健康检查协议是借助gRPC服务实现的,所以服务端是一个常规的gRPC服务。使用Golang实现健康检查工具的话,主要逻辑就是实现一个gRPC客户端。还有一个关键的点是工具要封装为CLI(命令行工具)类型:检测到服务健康的话,执行完成后需要返回0值(命令行工具中命令执行成功返回值为0),否则返回非0值。

示例代码

下面的Golang示例代码可以直接运行,编译后可以在命令行中运行查看效果。服务端可以使用我之前的文章《gRPC服务健康检查(一):Golang项目集成服务健康检查代码》中的服务端代码,运行起来作为被检测的服务端即可。

package main

import (
    "context"
    "flag"
    "fmt"
    "log"
    "os"
    "os/signal"
    "time"

    "google.golang.org/grpc"
    "google.golang.org/grpc/credentials/insecure"
    healthpb "google.golang.org/grpc/health/grpc_health_v1"
)

var (
    addr = flag.String("addr", "localhost:50051", "the address to connect to")
    // name = flag.String("name", defaultName, "Name to greet")
)

func init() {
    var flAddr string
    flagSet := flag.NewFlagSet("", flag.ContinueOnError)
    log.SetFlags(0)
    flagSet.StringVar(&flAddr, "addr", "", "the `address` to connect to")

    err := flagSet.Parse(os.Args[1:])
    if err != nil {
        os.Exit(1)
    }

    fmt.Println(flAddr)
}

func main() {
    retCode := 0
    defer func() {
        os.Exit(retCode)
    }()

    ctx, cancle := context.WithCancel(context.Background())

    c := make(chan os.Signal, 1)
    signal.Notify(c, os.Interrupt)
    go func() {
        sig := <-c
        if sig == os.Interrupt {
            log.Printf("cancellation received")
            cancle()
            return
        }
    }()

    dialCtx, dialCancel := context.WithTimeout(ctx, 10*time.Second)
    defer dialCancel()
    conn, err := grpc.DialContext(dialCtx, *addr, grpc.WithTransportCredentials(insecure.NewCredentials()))
    if err != nil {
        if err == context.DeadlineExceeded {
            log.Printf("timeout: failed to connect service %q within %v", *addr, time.Second)
        } else {
            log.Printf("error: failed to connect service at %q: %+v", *addr, err)
        }
        retCode = 2
        return
    }
    defer conn.Close()

    rpcCtx, rpcCancel := context.WithTimeout(ctx, time.Second)
    defer rpcCancel()
    resp, err := healthpb.NewHealthClient(conn).Check(rpcCtx, &healthpb.HealthCheckRequest{Service: ""})
    if err != nil {
        retCode = 3
        return
    }
    if resp.GetStatus() != healthpb.HealthCheckResponse_SERVING {
        log.Printf("service unhealthy (responded with %q)", resp.GetStatus().String())
        retCode = 4
        return
    }

    log.Printf("status: %v", resp.GetStatus().String())
}

小结

这个例子只是用来简单实现了一个服务健康检查工具,逻辑并不是特别完善,希望达到一个抛砖引玉的效果。更完善的实现可以参考grpc-health-probe(

github.com/grpc-ecosystem/grpc-health-probe)这个工具的官方代码。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

路多辛

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值