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