golang 监听consul 配置中心

本文介绍如何使用Go语言实现对Consul中配置文件的实时监控,以便在配置变化时获取最新数据。通过设置Consul服务和使用Viper库,作者详细展示了如何配置、启动Consul并监听Key/Value数据变化的过程。

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

Consul 是用于分布式系统服务发现与配置,内置了服务注册与发现框架、分布一致性协议实现、健康检查、Key/Value 存储、多数据中心方案。Consul是使用Go语言编写的,使用很方便。有个需求,配置文件里面的参数经常会调整,变动后需要实时获取,今天来实现监听consul中key/value 数据的变化。

在ubuntu安装consul并配置启动服务,
$ wget https://releases.hashicorp.com/consul/1.2.0/consul_1.2.0_linux_amd64.zip
$ yum install unzip
$ unzip consul_0.7.2_linux_amd64.zip
$ mv consul /usr/local/bin/consul

配置好后,控制台可以输出consul,可以看到有输出。
在这里插入图片描述

因为是监控配置文件,所以搭配的是一台服务器。拉取consul 镜像后,通过docker来启动:
sudo docker run -d -p 8500:8500 --restart=always --name=consul consul:latest agent -server -bootstrap -ui -node=1 -client=‘0.0.0.0’
命令说明
-p8500:8500 端口映射:前表示主机部分,:后表示容器部分。
-restart=always 重启方式:表示docker会自动重启该容器
–name=consulconsul:latest 指定该容器名称,查看和进行操作都比较方便。
agent 启动 Agent 进程
-server启动 Consul Server 模式
-bootstrap表示这个节点是 Server-Leader 。
-ui启动 Web UI 管理器 可访问8500查看
-node 节点名称集群中必须是唯一的,默认是该节点的主机名。
-client启动 Consul Cilent 模式consul服务侦听地址 提供HTTP、DNS、RPC等服务默认是127.0.0.1对外提供服务改成0.0.0.0

成功启动后,浏览器输入 http://192.168.x.xxx:8500/ui查看
在这里插入图片描述

可以在Key/Value中添加所需要的配置,这里创建格式为yaml
在这里插入图片描述

接下来需要代码去监听consul配置的数据变化,在做出更改时,能够及时返回最新的数据。

package main

import (
	"bytes"
	"fmt"
	"log"
	"time"

	consulapi "github.com/hashicorp/consul/api"
	"github.com/hashicorp/consul/api/watch"
	"github.com/spf13/viper"
	_ "github.com/spf13/viper/remote"
)

var (
	defaultConfig *viper.Viper
	consulAddress string
	consulPath    string
)

func initConfig() *viper.Viper {
	consulAddress = "http://192.168.2.xxx:8500"
	consulPath = "config/local"
	defaultConfig = viper.New()
	defaultConfig.SetConfigType("yaml")
	consulClient, err := consulapi.NewClient(&consulapi.Config{Address: consulAddress})
	if err != nil {
		log.Fatalln("consul连接失败:", err)
	}
	kv, _, err := consulClient.KV().Get(consulPath, nil)
	if err != nil {
		log.Fatalln("consul获取配置失败:", err)
	}
	err = defaultConfig.ReadConfig(bytes.NewBuffer(kv.Value))
	if err != nil {
		log.Fatalln("Viper解析配置失败:", err)
	}
	go watchConfig()
	return defaultConfig
}
func watchConfig() {
	time.Sleep(time.Second * 10)
	params := make(map[string]interface{})
	params["type"] = "key"
	params["key"] = consulPath

	w, err := watch.Parse(params)
	if err != nil {
		log.Fatalln(err)
	}
	w.Handler = func(u uint64, i interface{}) {
		kv := i.(*consulapi.KVPair)
		hotconfig := viper.New()
		hotconfig.SetConfigType("yaml")
		err = hotconfig.ReadConfig(bytes.NewBuffer(kv.Value))
		if err != nil {
			log.Fatalln("Viper解析配置失败:", err)
		}
		defaultConfig = hotconfig
	}
	err = w.Run(consulAddress)
	if err != nil {
		log.Fatalln("监听consul错误:", err)
	}
}
func GetConfig() *viper.Viper {
	if defaultConfig == nil {
		defaultConfig = initConfig()
	}
	return defaultConfig
}
func main() {
	ReadOne()

	go func() {
		for {
			color := GetConfig().GetString("config.color")
			fmt.Println("color===", color)
			time.Sleep(time.Second * 10)
		}

	}()
	select {}
}

func ReadOne() {
	runtimeConfig := viper.New()
	runtimeConfig.AddRemoteProvider("consul", "http://192.168.2.xxx:8500", "config/local")
	runtimeConfig.SetConfigType("yaml")
	err := runtimeConfig.ReadRemoteConfig()
	if err != nil {
		log.Fatalln("viper read:", err)
	}
	err = runtimeConfig.WatchRemoteConfigOnChannel()
	if err != nil {
		log.Fatalln("viper watch err:", err)
	}
	go func() {
		for {
			price := runtimeConfig.GetString("config.price")
			fmt.Println("price:", price)
			time.Sleep(time.Second * 10)
		}

	}()

}

执行打印出来可以看到,成功获取到consul中配置的数据。
在这里插入图片描述

在微服务架构中,健康检查是一个关键的服务治理功能,它可以帮助系统及时发现服务实例的状态,并采取相应的措施。为了帮助你更好地掌握使用Consul实现微服务健康检查的技术,建议阅读《Consul在.NETCore微服务中的全方位服务治理与部署详解》。这篇文章全面介绍了Consul在微服务环境中的应用,对于理解健康检查的机制和实践非常有帮助。 参考资源链接:[Consul在.NETCore微服务中的全方位服务治理与部署详解](https://wenku.csdn.net/doc/6jt8c1sgpz?spm=1055.2569.3001.10343) 在Golang中,你可以通过Consul提供的HTTP API来实现健康检查。首先,你需要在你的服务中集成健康检查的逻辑,然后将检查结果上报给ConsulConsul支持多种健康检查方式,如HTTP、TCP和Docker检查等。这里以HTTP检查为例,展示如何在Golang中实现: 1. 在服务启动时,注册健康检查到Consul。你需要编写代码来启动一个HTTP服务器,该服务器能够响应Consul的健康检查请求。 2. 在Golang程序中,使用HTTP框架(如net/http包)创建一个服务监听特定端口。 3. 编写健康检查的处理函数,该函数应该返回一个HTTP状态码来指示服务是否健康。 4. 配置Consul客户端,使用API注册你的服务和健康检查信息。你需要提供服务的地址、端口以及健康检查的细节。 5. 启动Consul Agent,并确保它能访问你的健康检查端点。 通过这种方式,Consul Agent会定期向你的服务发起健康检查请求,根据你的返回状态码来判定服务是否健康,并据此更新Consul的服务列表。如果服务实例连续多次检查失败,Consul会将其标记为不健康,并根据预设的配置采取行动,比如停止路由请求到该实例。 除了上述基础应用外,文章中还详细介绍了如何在.NETCore微服务中使用Consul进行服务治理,包括配置管理、服务发现和故障转移等高级功能。对于深入理解Consul以及在微服务中实现复杂的服务治理场景,有着很大的帮助。 参考资源链接:[Consul在.NETCore微服务中的全方位服务治理与部署详解](https://wenku.csdn.net/doc/6jt8c1sgpz?spm=1055.2569.3001.10343)
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值