Açıklama Yok
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

register_consul.go 5.5KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198
  1. // consul/register.go
  2. package consul
  3. import (
  4. "fmt"
  5. "log"
  6. "time"
  7. "git.x2erp.com/qdy/go-base/client"
  8. "git.x2erp.com/qdy/go-base/config"
  9. "git.x2erp.com/qdy/go-base/config/subconfigs"
  10. "github.com/hashicorp/consul/api"
  11. )
  12. type ConsulFactory struct {
  13. config config.IConfig
  14. ip string
  15. }
  16. // Register 注册服务到Consul
  17. func Register(cfg config.IConfig) *ConsulFactory {
  18. serviceName := cfg.GetServiceConfig().ServiceName
  19. port := cfg.GetServiceConfig().Port
  20. consulConfig := cfg.GetConsulConfig()
  21. configHostname := client.GetServiceIP("")
  22. if consulConfig == nil || !consulConfig.IsConfigured() {
  23. log.Println("未配置consul注册发现中心,微服务按单体服务运行.")
  24. return &ConsulFactory{
  25. config: cfg,
  26. ip: configHostname,
  27. }
  28. }
  29. // 1. 获取IP
  30. ip := client.GetServiceIP(configHostname)
  31. log.Printf("注册服务 %s -> %s:%d 到 %s", serviceName, ip, port, consulConfig.Address)
  32. // 2. 创建Consul客户端配置
  33. apiConfig := api.DefaultConfig()
  34. if consulConfig.Address != "" {
  35. apiConfig.Address = consulConfig.Address
  36. log.Printf("使用Consul地址: %s", consulConfig.Address)
  37. } else {
  38. log.Printf("⚠️ 使用默认Consul地址: %s", apiConfig.Address)
  39. }
  40. if consulConfig.Token != "" {
  41. apiConfig.Token = consulConfig.Token
  42. }
  43. if consulConfig.Scheme != "" {
  44. apiConfig.Scheme = consulConfig.Scheme
  45. }
  46. // 3. 创建客户端
  47. client, err := api.NewClient(apiConfig)
  48. if err != nil {
  49. log.Fatalf("创建Consul客户端失败: %v", err)
  50. }
  51. // 4. 测试连接
  52. _, err = client.Agent().Self()
  53. if err != nil {
  54. log.Fatalf("无法连接到Consul服务器 %s: %v", apiConfig.Address, err)
  55. }
  56. log.Printf("✅ 成功连接到Consul服务器: %s", apiConfig.Address)
  57. // 5. 注册服务(完整健康检查配置)
  58. registration := &api.AgentServiceRegistration{
  59. ID: fmt.Sprintf("%s-%s-%d", serviceName, ip, port),
  60. Name: serviceName,
  61. Address: ip,
  62. Port: port,
  63. Tags: []string{"http", "microservice"},
  64. Check: &api.AgentServiceCheck{
  65. HTTP: fmt.Sprintf("http://%s:%d/health", ip, port),
  66. Interval: "10s",
  67. Timeout: "5s", // 关键:设置超时
  68. DeregisterCriticalServiceAfter: "1m", // 关键:失败后注销时间
  69. TLSSkipVerify: true, // 跳过TLS验证
  70. Status: "passing", // 初始状态
  71. },
  72. Meta: map[string]string{
  73. "registered_at": time.Now().Format(time.RFC3339),
  74. "port": fmt.Sprintf("%d", port),
  75. },
  76. }
  77. err = client.Agent().ServiceRegister(registration)
  78. if err != nil {
  79. log.Fatalf("consul注册失败: %v", err)
  80. }
  81. // 打印详细注册信息
  82. //log.Printf("✅ 服务已注册到Consul服务器: %s", consulConfig.Address)
  83. log.Printf("📋注册详情:")
  84. log.Printf("-服务名称: %s", serviceName)
  85. log.Printf("-服务地址: %s:%d", ip, port)
  86. log.Printf("-服务ID: %s", registration.ID)
  87. log.Printf("-健康检查: %s", registration.Check.HTTP)
  88. log.Printf("-检查间隔: %s", registration.Check.Interval)
  89. log.Printf("-检查超时: %s", registration.Check.Timeout)
  90. log.Printf("-失败注销: %s", registration.Check.DeregisterCriticalServiceAfter)
  91. return &ConsulFactory{
  92. config: cfg,
  93. ip: configHostname,
  94. }
  95. }
  96. // CheckRegistration 检查服务是否已注册
  97. func CheckRegistration(serviceName, configHostname string, port int, consulConfig *subconfigs.ConsulConfig) error {
  98. if consulConfig == nil || !consulConfig.IsConfigured() {
  99. log.Println("未配置consul注册发现中心,微服务按单体服务运行.")
  100. return nil
  101. }
  102. ip := client.GetServiceIP(configHostname)
  103. serviceID := fmt.Sprintf("%s-%s-%d", serviceName, ip, port)
  104. // 创建客户端
  105. apiConfig := api.DefaultConfig()
  106. if consulConfig.Address != "" {
  107. apiConfig.Address = consulConfig.Address
  108. }
  109. client, err := api.NewClient(apiConfig)
  110. if err != nil {
  111. return fmt.Errorf("创建Consul客户端失败: %v", err)
  112. }
  113. // 检查服务
  114. services, err := client.Agent().Services()
  115. if err != nil {
  116. return fmt.Errorf("获取服务列表失败: %v", err)
  117. }
  118. if svc, exists := services[serviceID]; exists {
  119. log.Printf("✅ 服务已注册:")
  120. log.Printf(" 服务ID: %s", svc.ID)
  121. log.Printf(" 服务名: %s", svc.Service)
  122. log.Printf(" 地址: %s:%d", svc.Address, svc.Port)
  123. // 检查健康状态
  124. checks, err := client.Agent().Checks()
  125. if err == nil {
  126. for checkID, check := range checks {
  127. if check.ServiceID == serviceID {
  128. log.Printf(" 健康检查[%s]: %s", checkID, check.Status)
  129. }
  130. }
  131. }
  132. return nil
  133. }
  134. return fmt.Errorf("服务未注册: %s", serviceID)
  135. }
  136. func (c *ConsulFactory) GetName() string {
  137. return "ConsulFactory"
  138. }
  139. // Close 注销服务
  140. func (c *ConsulFactory) Close() {
  141. serviceName := c.config.GetServiceConfig().ServiceName
  142. port := c.config.GetServiceConfig().Port
  143. consulConfig := c.config.GetConsulConfig()
  144. if consulConfig == nil || !consulConfig.IsConfigured() {
  145. log.Println("未配置consul注册发现中心,服务不用到注册中心进行注销.")
  146. }
  147. serviceID := fmt.Sprintf("%s-%s-%d", serviceName, c.ip, port)
  148. // 创建客户端
  149. apiConfig := api.DefaultConfig()
  150. if consulConfig != nil && consulConfig.Address != "" {
  151. apiConfig.Address = consulConfig.Address
  152. }
  153. client, err := api.NewClient(apiConfig)
  154. if err != nil {
  155. log.Printf("创建consul客户端失败: %v", err)
  156. return
  157. }
  158. // 注销服务
  159. err = client.Agent().ServiceDeregister(serviceID)
  160. if err != nil {
  161. log.Printf("从consul注销服务失败 (ID: %s): %v", serviceID, err)
  162. return
  163. }
  164. log.Printf("✅ 已从consul注销服务: %s", serviceID)
  165. return
  166. }