mirror of
				https://github.com/openimsdk/open-im-server.git
				synced 2025-10-25 04:32:10 +08:00 
			
		
		
		
	resolve the prometheus discovery issue of multiple instances with same service
This commit is contained in:
		
							parent
							
								
									41a26c185b
								
							
						
					
					
						commit
						d743dc7d5c
					
				| @ -26,7 +26,6 @@ import ( | |||||||
| 	"github.com/openimsdk/tools/errs" | 	"github.com/openimsdk/tools/errs" | ||||||
| 	"github.com/openimsdk/tools/log" | 	"github.com/openimsdk/tools/log" | ||||||
| 	"github.com/openimsdk/tools/system/program" | 	"github.com/openimsdk/tools/system/program" | ||||||
| 	"github.com/openimsdk/tools/utils/jsonutil" |  | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| type Config struct { | type Config struct { | ||||||
| @ -96,10 +95,7 @@ func Start(ctx context.Context, index int, cfg *Config) error { | |||||||
| 
 | 
 | ||||||
| 			etcdClient := client.(*etcd.SvcDiscoveryRegistryImpl).GetClient() | 			etcdClient := client.(*etcd.SvcDiscoveryRegistryImpl).GetClient() | ||||||
| 
 | 
 | ||||||
| 			_, err = etcdClient.Put(ctx, prommetrics.BuildDiscoveryKey(prommetrics.APIKeyName), jsonutil.StructToJsonString(prommetrics.BuildDefaultTarget(registerIP, prometheusPort))) | 			prommetrics.Register(ctx, etcdClient, prommetrics.APIKeyName, registerIP, prometheusPort) | ||||||
| 			if err != nil { |  | ||||||
| 				return errs.WrapMsg(err, "etcd put err") |  | ||||||
| 			} |  | ||||||
| 		} else { | 		} else { | ||||||
| 			prometheusPort, err = datautil.GetElemByIndex(cfg.API.Prometheus.Ports, index) | 			prometheusPort, err = datautil.GetElemByIndex(cfg.API.Prometheus.Ports, index) | ||||||
| 			if err != nil { | 			if err != nil { | ||||||
|  | |||||||
| @ -38,7 +38,7 @@ func (p *PrometheusDiscoveryApi) Enable(c *gin.Context) { | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func (p *PrometheusDiscoveryApi) discovery(c *gin.Context, key string) { | func (p *PrometheusDiscoveryApi) discovery(c *gin.Context, key string) { | ||||||
| 	eResp, err := p.client.Get(c, prommetrics.BuildDiscoveryKey(key)) | 	eResp, err := p.client.Get(c, prommetrics.BuildDiscoveryKeyPrefix(key)) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		// Log and respond with an error if preparation fails. | 		// Log and respond with an error if preparation fails. | ||||||
| 		apiresp.GinError(c, errs.WrapMsg(err, "etcd get err")) | 		apiresp.GinError(c, errs.WrapMsg(err, "etcd get err")) | ||||||
|  | |||||||
| @ -26,7 +26,6 @@ import ( | |||||||
| 	"syscall" | 	"syscall" | ||||||
| 
 | 
 | ||||||
| 	"github.com/openimsdk/tools/discovery/etcd" | 	"github.com/openimsdk/tools/discovery/etcd" | ||||||
| 	"github.com/openimsdk/tools/utils/jsonutil" |  | ||||||
| 	"github.com/openimsdk/tools/utils/network" | 	"github.com/openimsdk/tools/utils/network" | ||||||
| 
 | 
 | ||||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/common/prommetrics" | 	"github.com/openimsdk/open-im-server/v3/pkg/common/prommetrics" | ||||||
| @ -178,10 +177,7 @@ func (m *MsgTransfer) Start(index int, cfg *Config) error { | |||||||
| 
 | 
 | ||||||
| 			etcdClient := client.(*etcd.SvcDiscoveryRegistryImpl).GetClient() | 			etcdClient := client.(*etcd.SvcDiscoveryRegistryImpl).GetClient() | ||||||
| 
 | 
 | ||||||
| 			_, err = etcdClient.Put(context.TODO(), prommetrics.BuildDiscoveryKey(prommetrics.MessageTransferKeyName), jsonutil.StructToJsonString(prommetrics.BuildDefaultTarget(registerIP, prometheusPort))) | 			prommetrics.Register(context.TODO(), etcdClient, prommetrics.MessageTransferKeyName, registerIP, prometheusPort) | ||||||
| 			if err != nil { |  | ||||||
| 				return errs.WrapMsg(err, "etcd put err") |  | ||||||
| 			} |  | ||||||
| 		} else { | 		} else { | ||||||
| 			prometheusPort, err = datautil.GetElemByIndex(cfg.MsgTransfer.Prometheus.Ports, index) | 			prometheusPort, err = datautil.GetElemByIndex(cfg.MsgTransfer.Prometheus.Ports, index) | ||||||
| 			if err != nil { | 			if err != nil { | ||||||
|  | |||||||
| @ -1,6 +1,13 @@ | |||||||
| package prommetrics | package prommetrics | ||||||
| 
 | 
 | ||||||
| import "fmt" | import ( | ||||||
|  | 	"context" | ||||||
|  | 	"fmt" | ||||||
|  | 
 | ||||||
|  | 	"github.com/openimsdk/tools/errs" | ||||||
|  | 	"github.com/openimsdk/tools/utils/jsonutil" | ||||||
|  | 	clientv3 "go.etcd.io/etcd/client/v3" | ||||||
|  | ) | ||||||
| 
 | 
 | ||||||
| const ( | const ( | ||||||
| 	APIKeyName             = "api" | 	APIKeyName             = "api" | ||||||
| @ -17,8 +24,12 @@ type RespTarget struct { | |||||||
| 	Labels  map[string]string `json:"labels"` | 	Labels  map[string]string `json:"labels"` | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func BuildDiscoveryKey(name string) string { | func BuildDiscoveryKeyPrefix(name string) string { | ||||||
| 	return fmt.Sprintf("%s/%s/%s", "openim", "prometheus_discovery", name) | 	return fmt.Sprintf("%s/%s/%s/", "openim", "prometheus_discovery", name) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | func BuildDiscoveryKey(name string, host string, port int) string { | ||||||
|  | 	return fmt.Sprintf("%s/%s/%s/%s:%d", "openim", "prometheus_discovery", name, host, port) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func BuildDefaultTarget(host string, ip int) Target { | func BuildDefaultTarget(host string, ip int) Target { | ||||||
| @ -29,3 +40,30 @@ func BuildDefaultTarget(host string, ip int) Target { | |||||||
| 		}, | 		}, | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | func Register(ctx context.Context, etcdClient *clientv3.Client, rpcRegisterName string, registerIP string, prometheusPort int) error { | ||||||
|  | 	// create lease | ||||||
|  | 	leaseResp, err := etcdClient.Grant(ctx, 30) | ||||||
|  | 	if err != nil { | ||||||
|  | 		return errs.WrapMsg(err, "failed to create lease in etcd") | ||||||
|  | 	} | ||||||
|  | 	// release | ||||||
|  | 	keepAliveChan, err := etcdClient.KeepAlive(ctx, leaseResp.ID) | ||||||
|  | 	if err != nil { | ||||||
|  | 		return errs.WrapMsg(err, "failed to keep alive lease") | ||||||
|  | 	} | ||||||
|  | 	// release resp | ||||||
|  | 	go func() { | ||||||
|  | 		for range keepAliveChan { | ||||||
|  | 		} | ||||||
|  | 	}() | ||||||
|  | 	putOpts := []clientv3.OpOption{} | ||||||
|  | 	if leaseResp != nil { | ||||||
|  | 		putOpts = append(putOpts, clientv3.WithLease(leaseResp.ID)) | ||||||
|  | 	} | ||||||
|  | 	_, err = etcdClient.Put(ctx, BuildDiscoveryKey(rpcRegisterName, registerIP, prometheusPort), jsonutil.StructToJsonString(BuildDefaultTarget(registerIP, prometheusPort)), putOpts...) | ||||||
|  | 	if err != nil { | ||||||
|  | 		return errs.WrapMsg(err, "etcd put err") | ||||||
|  | 	} | ||||||
|  | 	return nil | ||||||
|  | } | ||||||
|  | |||||||
| @ -29,7 +29,6 @@ import ( | |||||||
| 	conf "github.com/openimsdk/open-im-server/v3/pkg/common/config" | 	conf "github.com/openimsdk/open-im-server/v3/pkg/common/config" | ||||||
| 	"github.com/openimsdk/tools/discovery/etcd" | 	"github.com/openimsdk/tools/discovery/etcd" | ||||||
| 	"github.com/openimsdk/tools/utils/datautil" | 	"github.com/openimsdk/tools/utils/datautil" | ||||||
| 	"github.com/openimsdk/tools/utils/jsonutil" |  | ||||||
| 	"google.golang.org/grpc/status" | 	"google.golang.org/grpc/status" | ||||||
| 
 | 
 | ||||||
| 	kdisc "github.com/openimsdk/open-im-server/v3/pkg/common/discoveryregister" | 	kdisc "github.com/openimsdk/open-im-server/v3/pkg/common/discoveryregister" | ||||||
| @ -118,10 +117,7 @@ func Start[T any](ctx context.Context, discovery *conf.Discovery, prometheusConf | |||||||
| 
 | 
 | ||||||
| 			etcdClient := client.(*etcd.SvcDiscoveryRegistryImpl).GetClient() | 			etcdClient := client.(*etcd.SvcDiscoveryRegistryImpl).GetClient() | ||||||
| 
 | 
 | ||||||
| 			_, err = etcdClient.Put(ctx, prommetrics.BuildDiscoveryKey(rpcRegisterName), jsonutil.StructToJsonString(prommetrics.BuildDefaultTarget(registerIP, prometheusPort))) | 			prommetrics.Register(ctx, etcdClient, rpcRegisterName, registerIP, prometheusPort) | ||||||
| 			if err != nil { |  | ||||||
| 				return errs.WrapMsg(err, "etcd put err") |  | ||||||
| 			} |  | ||||||
| 		} else { | 		} else { | ||||||
| 			prometheusPort, err = datautil.GetElemByIndex(prometheusConfig.Ports, index) | 			prometheusPort, err = datautil.GetElemByIndex(prometheusConfig.Ports, index) | ||||||
| 			if err != nil { | 			if err != nil { | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user