目录
1.简介
提供Go微服务客户端注册到Eureka中心。点击:github地址,欢迎各位多多star!
(已通过测试验证,用于正式生产部署)
2.原理
goeureka主要是通过REST请求来与server进行通信。
其中Java版本的核心实现请参看:com.netflix.discovery.DiscoveryClient
3.注册信息
注册eureka服务端的配置信息如下:
{
"instance": {
"instanceId" : "${ipAddress}:${appName}:${port}",
"hostName":"${ipAddress}",
"app":"${appName}",
"ipAddr":"${ipAddress}",
"vipAddress":"${appName}",
"overriddenstatus": "UNKNOWN",
"status":"UP",
"port": {
"$":${port},
"@enabled": true
},
"securePort": {
"$":${securePort},
"@enabled": false
},
"homePageUrl" : "http://${ipAddress}:${port}/",
"statusPageUrl": "http://${ipAddress}:${port}/info",
"healthCheckUrl": "http://${ipAddress}:${port}/health",
"dataCenterInfo" : {
"@class":"com.netflix.appinfo.InstanceInfo$DefaultDataCenterInfo",
"name": "MyOwn"
},
"metadata": {
"management.port" : "${port}"
}
}
}
4.功能特性
本项目封装了Eureka rest操作,实现了以下功能:
- 支持服务注册
- 支持服务租约续期
- 支持自动取消注册
- 支持通过代理注册
- 支持账户登录(不登陆,将opt设置为nil即可)
本插件中register 、heartbeat 和deregister基本上可以实现微服务注册到Eureka中心。register方法是通过心跳与Eureka服务端保持通信,当Eureka客户端和服务端注册成功后,则每30秒钟发送一次心跳。当您的微服务实例通过Sigterm或OS中断信号退出时,则本客户端会在关闭之前注销Eureka,以确保服务实例不会发生冲突。
5.使用方法
工具包的导入方法:
import "github.com/SimonWang00/goeureka"
如果您默认使用本地启动的Eureka Server,注册代码如下:
opt := make(map[string]string)
opt["username"] = "admin"
opt["password"] = "admin123"
// 加载配置
goeureka.RegisterClient("http://127.0.0.1:8028","",
"golang-server-test", strconv.Itoa(8888),
strconv.Itoa(43), opt)
Notes:
Notes: RegisterClient 为web server对应的端口号,涉及到异地机房联调采用docker部署的话,需要映射公网IP(添加注册代理),如59.172.3.26, 无需添加代理的话为""即可。
或者
goeureka.RegisterClient("http://127.0.0.1:8761","","my-goserver", "8000", "43",nil)
Notes:
- 第二项参数为空代表默认使用本机IP地址;
- nil代表opt不需要登录账户和密码注册;
6.接入示例
在http中使用:
import (
"fmt"
"github.com/SimonWang00/goeureka"
"net/http"
)
func main() {
opt := make(map[string]string)
opt["username"] = "admin"
opt["password"] = "admin123"
goeureka.RegisterClient("http://127.0.0.1:8761","","myapp", "8000", "43",opt)
http.HandleFunc("/hello", func(responseWriter http.ResponseWriter, request *http.Request) {
resp := "hello goeureka!"
_, _ = responseWriter.Write([]byte(resp))
})
// start server
if err := http.ListenAndServe("127.0.0.1:8000", nil); err != nil {
fmt.Println(err)
}
}
在gin框架中使用:
import (
"github.com/SimonWang00/goeureka"
"github.com/gin-gonic/gin"
)
func main() {
r := gin.Default()
r.GET("hello", func(c *gin.Context) {
c.String(200, "hello goeureka")
})
opt := make(map[string]string)
opt["username"] = "admin"
opt["password"] = "admin123"
goeureka.RegisterClient("http://127.0.0.1:8761","","myapp", "8000", "43",opt)
r.Run("127.0.0.1:8000")
}
7.测试
通过了测试,已经用于golang的微服务生产环境。
java端测试代码,内涵gateway-eureka.jar
版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。