Go-手写注册中心

Registry

简单的内存注册中心

源码 https://github.com/shura1014/registry

快速使用

启动

默认启动端口 9999

go 复制代码
register := NewMemRegister()
register.Start()

curl http://127.0.0.1:9999/mem/probe

OK

服务注册

注册一个服务 : 建议使用应用级注册

例如注册upc应用地址 127.0.0.1:8888

go 复制代码
// curl  -POST -d '{"key":"upc","value":"127.0.0.1:8888"}' http://127.0.0.1:9999/mem/register
func TestServiceRegistry(t *testing.T) {
	// 模拟监听一个端口
	_, _ = net.Listen("tcp", ":8888")
	common.Wait()
}
  1. 启动服务

  2. 访问

curl -POST -d '{"key":"upc","value":"127.0.0.1:8888"}' http://127.0.0.1:9999/mem/register

  1. 查看注册中心日志
text 复制代码
[registry] 2023-08-31 11:05:27 /Users/wendell/GolandProjects/shura/registry/mem.go:52 INFO register /upc &[{127.0.0.1:8888}]

服务发现

curl -POST -d '{"key":"upc"}' http://127.0.0.1:9999/mem/discover

{"address":"127.0.0.1:8888"}

监听地址变化

客户端通过与注册中心建立长轮询监听服务地址,30秒一次,如果地址有变动立刻返回,否则30秒后返回304

例如

shell 复制代码
curl  -POST -d '["upc"]' http://127.0.0.1:9999/mem/monitor         
{"code":304}

有新的服务注册

go 复制代码
curl  -POST -d '["upc"]' http://127.0.0.1:9999/mem/monitor

{"appName":"/upc","code":200,"data":[{"address":"127.0.0.1:8888"},{"address":"127.0.0.1:8889"}]}

[registry] 2023-08-31 11:16:32 /Users/wendell/GolandProjects/shura/registry/mem.go:52 INFO register /upc &[{127.0.0.1:8888} {127.0.0.1:8889}]

有服务下线

手动关闭一个实例

shell 复制代码
curl  -POST -d '["upc"]' http://127.0.0.1:9999/mem/monitor

{"appName":"/upc","code":200,"data":[{"address":"127.0.0.1:8888"}]}

另一个也关掉

curl  -POST -d '["upc"]' http://127.0.0.1:9999/mem/monitor

{"appName":"/upc","code":200,"data":null}
相关推荐
molaifeng14 分钟前
像搭积木一样理解 Golang AST
开发语言·后端·golang
踏浪无痕17 分钟前
JobFlow 的延时调度:如何可靠地处理“30分钟后取消订单”
后端·面试·开源
SystickInt18 分钟前
C语言 UTC时间转化为北京时间
c语言·开发语言
黎雁·泠崖24 分钟前
C 语言动态内存管理进阶:常见错误排查 + 经典笔试题深度解析
c语言·开发语言
成为大佬先秃头31 分钟前
渐进式JavaScript框架:Vue 过渡 & 动画 & 可复用性 & 组合
开发语言·javascript·vue.js
嘻嘻嘻开心35 分钟前
Java IO流
java·开发语言
侧耳倾听11135 分钟前
RESTful API介绍
后端·restful
JIngJaneIL1 小时前
基于java+ vue家庭理财管理系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot
hakesashou1 小时前
python 随机函数可以生成字符串吗
开发语言·python
vipbic1 小时前
基于 Nuxt 4 + Strapi 5 构建高性能 AI 导航站
前端·后端