mirror of
				https://github.com/openimsdk/open-im-server.git
				synced 2025-10-26 21:22:16 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			47 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			47 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package zookeeper
 | |
| 
 | |
| import (
 | |
| 	"os"
 | |
| 	"strings"
 | |
| 	"time"
 | |
| 
 | |
| 	"github.com/OpenIMSDK/tools/discoveryregistry"
 | |
| 	openkeeper "github.com/OpenIMSDK/tools/discoveryregistry/zookeeper"
 | |
| 	"github.com/OpenIMSDK/tools/log"
 | |
| 	"github.com/openimsdk/open-im-server/v3/pkg/common/config"
 | |
| )
 | |
| 
 | |
| // NewZookeeperDiscoveryRegister creates a new instance of ZookeeperDR for Zookeeper service discovery and registration.
 | |
| func NewZookeeperDiscoveryRegister() (discoveryregistry.SvcDiscoveryRegistry, error) {
 | |
| 	schema := getEnv("ZOOKEEPER_SCHEMA", config.Config.Zookeeper.Schema)
 | |
| 	zkAddr := getZkAddrFromEnv(config.Config.Zookeeper.ZkAddr)
 | |
| 	username := getEnv("ZOOKEEPER_USERNAME", config.Config.Zookeeper.Username)
 | |
| 	password := getEnv("ZOOKEEPER_PASSWORD", config.Config.Zookeeper.Password)
 | |
| 
 | |
| 	return openkeeper.NewClient(
 | |
| 		zkAddr,
 | |
| 		schema,
 | |
| 		openkeeper.WithFreq(time.Hour),
 | |
| 		openkeeper.WithUserNameAndPassword(username, password),
 | |
| 		openkeeper.WithRoundRobin(),
 | |
| 		openkeeper.WithTimeout(10),
 | |
| 		openkeeper.WithLogger(log.NewZkLogger()),
 | |
| 	)
 | |
| }
 | |
| 
 | |
| // getEnv returns the value of an environment variable if it exists, otherwise it returns the fallback value.
 | |
| func getEnv(key, fallback string) string {
 | |
| 	if value, exists := os.LookupEnv(key); exists {
 | |
| 		return value
 | |
| 	}
 | |
| 	return fallback
 | |
| }
 | |
| 
 | |
| // getZkAddrFromEnv returns the value of an environment variable if it exists, otherwise it returns the fallback value.
 | |
| func getZkAddrFromEnv(fallback []string) []string {
 | |
| 	if value, exists := os.LookupEnv("ZOOKEEPER_ADDRESS"); exists {
 | |
| 		return strings.Split(value, ",")
 | |
| 	}
 | |
| 	return fallback
 | |
| }
 |