mirror of
				https://github.com/openimsdk/open-im-server.git
				synced 2025-10-25 20:52:11 +08:00 
			
		
		
		
	feat: support redis sentinel.
This commit is contained in:
		
							parent
							
								
									d156e1e519
								
							
						
					
					
						commit
						e937a6582f
					
				| @ -1,7 +1,11 @@ | |||||||
| address: [ localhost:16379 ] | address: [localhost:16379] | ||||||
| username:  | username: | ||||||
| password: openIM123 | password: openIM123 | ||||||
| clusterMode: false | clusterMode: false | ||||||
| db: 0 | db: 0 | ||||||
| maxRetry: 10 | maxRetry: 10 | ||||||
| poolSize: 100 | poolSize: 100 | ||||||
|  | sentinelMode: | ||||||
|  |   enable: true | ||||||
|  |   masterName: "redis-master" | ||||||
|  |   sentinelsAddrs: ["127.0.0.1:26379", "127.0.0.1:26380", "127.0.0.1:26381"] | ||||||
|  | |||||||
| @ -64,6 +64,193 @@ services: | |||||||
|     sysctls: |     sysctls: | ||||||
|       net.core.somaxconn: 1024 |       net.core.somaxconn: 1024 | ||||||
|     command: redis-server /usr/local/redis/config/redis.conf --requirepass openIM123 --appendonly yes |     command: redis-server /usr/local/redis/config/redis.conf --requirepass openIM123 --appendonly yes | ||||||
|  |     healthcheck: | ||||||
|  |       test: ["CMD", "redis-cli", "-a", "openIM123", "ping"] | ||||||
|  |       interval: 10s | ||||||
|  |       timeout: 3s | ||||||
|  |       retries: 3 | ||||||
|  |       start_period: 30s | ||||||
|  |     networks: | ||||||
|  |       - openim | ||||||
|  | 
 | ||||||
|  |   redis-slave-1: | ||||||
|  |     image: "${REDIS_IMAGE}" | ||||||
|  |     container_name: redis-slave-1 | ||||||
|  |     ports: | ||||||
|  |       - "16380:6379" | ||||||
|  |     volumes: | ||||||
|  |       - "${DATA_DIR}/components/redis/slave1:/data" | ||||||
|  |     environment: | ||||||
|  |       TZ: Asia/Shanghai | ||||||
|  |       REDIS_MASTER_HOST: redis | ||||||
|  |       REDIS_MASTER_PORT: 6379 | ||||||
|  |       REDIS_MASTER_PASSWORD: openIM123 | ||||||
|  |       REDIS_SLAVE_PASSWORD: openIM123 | ||||||
|  |     restart: always | ||||||
|  |     command: > | ||||||
|  |       bash -c ' | ||||||
|  |       echo "port 6379" > /data/redis-slave.conf && | ||||||
|  |       echo "replicaof $${REDIS_MASTER_HOST} $${REDIS_MASTER_PORT}" >> /data/redis-slave.conf && | ||||||
|  |       echo "masterauth $${REDIS_MASTER_PASSWORD}" >> /data/redis-slave.conf && | ||||||
|  |       echo "requirepass $${REDIS_SLAVE_PASSWORD}" >> /data/redis-slave.conf && | ||||||
|  |       echo "appendonly yes" >> /data/redis-slave.conf && | ||||||
|  |       echo "replica-read-only yes" >> /data/redis-slave.conf && | ||||||
|  |       redis-server /data/redis-slave.conf | ||||||
|  |       ' | ||||||
|  |     depends_on: | ||||||
|  |       - redis | ||||||
|  |     networks: | ||||||
|  |       - openim | ||||||
|  | 
 | ||||||
|  |   redis-slave-2: | ||||||
|  |     image: "${REDIS_IMAGE}" | ||||||
|  |     container_name: redis-slave-2 | ||||||
|  |     ports: | ||||||
|  |       - "16381:6379" | ||||||
|  |     volumes: | ||||||
|  |       - "${DATA_DIR}/components/redis/slave2:/data" | ||||||
|  |     environment: | ||||||
|  |       TZ: Asia/Shanghai | ||||||
|  |       REDIS_MASTER_HOST: redis | ||||||
|  |       REDIS_MASTER_PORT: 6379 | ||||||
|  |       REDIS_MASTER_PASSWORD: openIM123 | ||||||
|  |       REDIS_SLAVE_PASSWORD: openIM123 | ||||||
|  |     restart: always | ||||||
|  |     command: > | ||||||
|  |       bash -c ' | ||||||
|  |       echo "port 6379" > /data/redis-slave.conf && | ||||||
|  |       echo "replicaof $${REDIS_MASTER_HOST} $${REDIS_MASTER_PORT}" >> /data/redis-slave.conf && | ||||||
|  |       echo "masterauth $${REDIS_MASTER_PASSWORD}" >> /data/redis-slave.conf && | ||||||
|  |       echo "requirepass $${REDIS_SLAVE_PASSWORD}" >> /data/redis-slave.conf && | ||||||
|  |       echo "appendonly yes" >> /data/redis-slave.conf && | ||||||
|  |       echo "replica-read-only yes" >> /data/redis-slave.conf && | ||||||
|  |       redis-server /data/redis-slave.conf | ||||||
|  |       ' | ||||||
|  |     depends_on: | ||||||
|  |       - redis | ||||||
|  |     networks: | ||||||
|  |       - openim | ||||||
|  | 
 | ||||||
|  |   redis-sentinel-1: | ||||||
|  |     image: "${REDIS_IMAGE}" | ||||||
|  |     container_name: redis-sentinel-1 | ||||||
|  |     ports: | ||||||
|  |       - "26379:26379" | ||||||
|  |     volumes: | ||||||
|  |       - "${DATA_DIR}/components/redis/sentinel1:/data" | ||||||
|  |     environment: | ||||||
|  |       TZ: Asia/Shanghai | ||||||
|  |       SENTINEL_PORT: 26379 | ||||||
|  |       REDIS_MASTER_NAME: redis-master | ||||||
|  |       REDIS_MASTER_HOST: 127.0.0.1 | ||||||
|  |       REDIS_MASTER_PORT: 16379 | ||||||
|  |       REDIS_MASTER_PASSWORD: openIM123 | ||||||
|  |       SENTINEL_QUORUM: 2 | ||||||
|  |       SENTINEL_DOWN_AFTER: 30000 | ||||||
|  |       SENTINEL_PARALLEL_SYNCS: 1 | ||||||
|  |       SENTINEL_FAILOVER_TIMEOUT: 180000 | ||||||
|  |     restart: always | ||||||
|  |     command: > | ||||||
|  |       bash -c ' | ||||||
|  |       echo "port $${SENTINEL_PORT}" > /data/sentinel.conf && | ||||||
|  |       echo "sentinel monitor $${REDIS_MASTER_NAME} $${REDIS_MASTER_HOST} $${REDIS_MASTER_PORT} $${SENTINEL_QUORUM}" >> /data/sentinel.conf && | ||||||
|  |       echo "sentinel auth-pass $${REDIS_MASTER_NAME} $${REDIS_MASTER_PASSWORD}" >> /data/sentinel.conf && | ||||||
|  |       echo "sentinel down-after-milliseconds $${REDIS_MASTER_NAME} $${SENTINEL_DOWN_AFTER}" >> /data/sentinel.conf && | ||||||
|  |       echo "sentinel parallel-syncs $${REDIS_MASTER_NAME} $${SENTINEL_PARALLEL_SYNCS}" >> /data/sentinel.conf && | ||||||
|  |       echo "sentinel failover-timeout $${REDIS_MASTER_NAME} $${SENTINEL_FAILOVER_TIMEOUT}" >> /data/sentinel.conf && | ||||||
|  |       echo "sentinel resolve-hostnames yes" >> /data/sentinel.conf && | ||||||
|  |       echo "sentinel announce-hostnames yes" >> /data/sentinel.conf && | ||||||
|  |       redis-sentinel /data/sentinel.conf | ||||||
|  |       ' | ||||||
|  |     depends_on: | ||||||
|  |       redis: | ||||||
|  |         condition: service_healthy | ||||||
|  |       redis-slave-1: | ||||||
|  |         condition: service_started | ||||||
|  |       redis-slave-2: | ||||||
|  |         condition: service_started | ||||||
|  |     networks: | ||||||
|  |       - openim | ||||||
|  | 
 | ||||||
|  |   redis-sentinel-2: | ||||||
|  |     image: "${REDIS_IMAGE}" | ||||||
|  |     container_name: redis-sentinel-2 | ||||||
|  |     ports: | ||||||
|  |       - "26380:26379" | ||||||
|  |     volumes: | ||||||
|  |       - "${DATA_DIR}/components/redis/sentinel2:/data" | ||||||
|  |     environment: | ||||||
|  |       TZ: Asia/Shanghai | ||||||
|  |       SENTINEL_PORT: 26379 | ||||||
|  |       REDIS_MASTER_NAME: redis-master | ||||||
|  |       REDIS_MASTER_HOST: 127.0.0.1 | ||||||
|  |       REDIS_MASTER_PORT: 16379 | ||||||
|  |       REDIS_MASTER_PASSWORD: openIM123 | ||||||
|  |       SENTINEL_QUORUM: 2 | ||||||
|  |       SENTINEL_DOWN_AFTER: 30000 | ||||||
|  |       SENTINEL_PARALLEL_SYNCS: 1 | ||||||
|  |       SENTINEL_FAILOVER_TIMEOUT: 180000 | ||||||
|  |     restart: always | ||||||
|  |     command: > | ||||||
|  |       bash -c ' | ||||||
|  |       echo "port $${SENTINEL_PORT}" > /data/sentinel.conf && | ||||||
|  |       echo "sentinel monitor $${REDIS_MASTER_NAME} $${REDIS_MASTER_HOST} $${REDIS_MASTER_PORT} $${SENTINEL_QUORUM}" >> /data/sentinel.conf && | ||||||
|  |       echo "sentinel auth-pass $${REDIS_MASTER_NAME} $${REDIS_MASTER_PASSWORD}" >> /data/sentinel.conf && | ||||||
|  |       echo "sentinel down-after-milliseconds $${REDIS_MASTER_NAME} $${SENTINEL_DOWN_AFTER}" >> /data/sentinel.conf && | ||||||
|  |       echo "sentinel parallel-syncs $${REDIS_MASTER_NAME} $${SENTINEL_PARALLEL_SYNCS}" >> /data/sentinel.conf && | ||||||
|  |       echo "sentinel failover-timeout $${REDIS_MASTER_NAME} $${SENTINEL_FAILOVER_TIMEOUT}" >> /data/sentinel.conf && | ||||||
|  |       echo "sentinel resolve-hostnames yes" >> /data/sentinel.conf && | ||||||
|  |       echo "sentinel announce-hostnames yes" >> /data/sentinel.conf && | ||||||
|  |       redis-sentinel /data/sentinel.conf | ||||||
|  |       ' | ||||||
|  |     depends_on: | ||||||
|  |       redis: | ||||||
|  |         condition: service_healthy | ||||||
|  |       redis-slave-1: | ||||||
|  |         condition: service_started | ||||||
|  |       redis-slave-2: | ||||||
|  |         condition: service_started | ||||||
|  |     networks: | ||||||
|  |       - openim | ||||||
|  | 
 | ||||||
|  |   redis-sentinel-3: | ||||||
|  |     image: "${REDIS_IMAGE}" | ||||||
|  |     container_name: redis-sentinel-3 | ||||||
|  |     ports: | ||||||
|  |       - "26381:26379" | ||||||
|  |     volumes: | ||||||
|  |       - "${DATA_DIR}/components/redis/sentinel3:/data" | ||||||
|  |     environment: | ||||||
|  |       TZ: Asia/Shanghai | ||||||
|  |       SENTINEL_PORT: 26379 | ||||||
|  |       REDIS_MASTER_NAME: redis-master | ||||||
|  |       REDIS_MASTER_HOST: 127.0.0.1 | ||||||
|  |       REDIS_MASTER_PORT: 16379 | ||||||
|  |       REDIS_MASTER_PASSWORD: openIM123 | ||||||
|  |       SENTINEL_QUORUM: 2 | ||||||
|  |       SENTINEL_DOWN_AFTER: 30000 | ||||||
|  |       SENTINEL_PARALLEL_SYNCS: 1 | ||||||
|  |       SENTINEL_FAILOVER_TIMEOUT: 180000 | ||||||
|  |     restart: always | ||||||
|  |     command: > | ||||||
|  |       bash -c ' | ||||||
|  |       echo "port $${SENTINEL_PORT}" > /data/sentinel.conf && | ||||||
|  |       echo "sentinel monitor $${REDIS_MASTER_NAME} $${REDIS_MASTER_HOST} $${REDIS_MASTER_PORT} $${SENTINEL_QUORUM}" >> /data/sentinel.conf && | ||||||
|  |       echo "sentinel auth-pass $${REDIS_MASTER_NAME} $${REDIS_MASTER_PASSWORD}" >> /data/sentinel.conf && | ||||||
|  |       echo "sentinel down-after-milliseconds $${REDIS_MASTER_NAME} $${SENTINEL_DOWN_AFTER}" >> /data/sentinel.conf && | ||||||
|  |       echo "sentinel parallel-syncs $${REDIS_MASTER_NAME} $${SENTINEL_PARALLEL_SYNCS}" >> /data/sentinel.conf && | ||||||
|  |       echo "sentinel failover-timeout $${REDIS_MASTER_NAME} $${SENTINEL_FAILOVER_TIMEOUT}" >> /data/sentinel.conf && | ||||||
|  |       echo "sentinel resolve-hostnames yes" >> /data/sentinel.conf && | ||||||
|  |       echo "sentinel announce-hostnames yes" >> /data/sentinel.conf && | ||||||
|  |       redis-sentinel /data/sentinel.conf | ||||||
|  |       ' | ||||||
|  |     depends_on: | ||||||
|  |       redis: | ||||||
|  |         condition: service_healthy | ||||||
|  |       redis-slave-1: | ||||||
|  |         condition: service_started | ||||||
|  |       redis-slave-2: | ||||||
|  |         condition: service_started | ||||||
|     networks: |     networks: | ||||||
|       - openim |       - openim | ||||||
| 
 | 
 | ||||||
| @ -148,7 +335,7 @@ services: | |||||||
|       - "11002:80" |       - "11002:80" | ||||||
|     networks: |     networks: | ||||||
|       - openim |       - openim | ||||||
|        | 
 | ||||||
|   prometheus: |   prometheus: | ||||||
|     image: ${PROMETHEUS_IMAGE} |     image: ${PROMETHEUS_IMAGE} | ||||||
|     container_name: prometheus |     container_name: prometheus | ||||||
| @ -161,9 +348,9 @@ services: | |||||||
|       - ./config/instance-down-rules.yml:/etc/prometheus/instance-down-rules.yml |       - ./config/instance-down-rules.yml:/etc/prometheus/instance-down-rules.yml | ||||||
|       - ${DATA_DIR}/components/prometheus/data:/prometheus |       - ${DATA_DIR}/components/prometheus/data:/prometheus | ||||||
|     command: |     command: | ||||||
|       - '--config.file=/etc/prometheus/prometheus.yml' |       - "--config.file=/etc/prometheus/prometheus.yml" | ||||||
|       - '--storage.tsdb.path=/prometheus' |       - "--storage.tsdb.path=/prometheus" | ||||||
|       - '--web.listen-address=:${PROMETHEUS_PORT}' |       - "--web.listen-address=:${PROMETHEUS_PORT}" | ||||||
|     network_mode: host |     network_mode: host | ||||||
| 
 | 
 | ||||||
|   alertmanager: |   alertmanager: | ||||||
| @ -176,8 +363,8 @@ services: | |||||||
|       - ./config/alertmanager.yml:/etc/alertmanager/alertmanager.yml |       - ./config/alertmanager.yml:/etc/alertmanager/alertmanager.yml | ||||||
|       - ./config/email.tmpl:/etc/alertmanager/email.tmpl |       - ./config/email.tmpl:/etc/alertmanager/email.tmpl | ||||||
|     command: |     command: | ||||||
|       - '--config.file=/etc/alertmanager/alertmanager.yml' |       - "--config.file=/etc/alertmanager/alertmanager.yml" | ||||||
|       - '--web.listen-address=:${ALERTMANAGER_PORT}' |       - "--web.listen-address=:${ALERTMANAGER_PORT}" | ||||||
|     network_mode: host |     network_mode: host | ||||||
| 
 | 
 | ||||||
|   grafana: |   grafana: | ||||||
| @ -209,9 +396,8 @@ services: | |||||||
|       - /sys:/host/sys:ro |       - /sys:/host/sys:ro | ||||||
|       - /:/rootfs:ro |       - /:/rootfs:ro | ||||||
|     command: |     command: | ||||||
|       - '--path.procfs=/host/proc' |       - "--path.procfs=/host/proc" | ||||||
|       - '--path.sysfs=/host/sys' |       - "--path.sysfs=/host/sys" | ||||||
|       - '--path.rootfs=/rootfs' |       - "--path.rootfs=/rootfs" | ||||||
|       - '--web.listen-address=:19100' |       - "--web.listen-address=:19100" | ||||||
|     network_mode: host |     network_mode: host | ||||||
| 
 |  | ||||||
|  | |||||||
							
								
								
									
										2
									
								
								go.mod
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								go.mod
									
									
									
									
									
								
							| @ -13,7 +13,7 @@ require ( | |||||||
| 	github.com/grpc-ecosystem/go-grpc-prometheus v1.2.0 | 	github.com/grpc-ecosystem/go-grpc-prometheus v1.2.0 | ||||||
| 	github.com/mitchellh/mapstructure v1.5.0 | 	github.com/mitchellh/mapstructure v1.5.0 | ||||||
| 	github.com/openimsdk/protocol v0.0.73-alpha.12 | 	github.com/openimsdk/protocol v0.0.73-alpha.12 | ||||||
| 	github.com/openimsdk/tools v0.0.50-alpha.85 | 	github.com/openimsdk/tools v0.0.50-alpha.87 | ||||||
| 	github.com/pkg/errors v0.9.1 // indirect | 	github.com/pkg/errors v0.9.1 // indirect | ||||||
| 	github.com/prometheus/client_golang v1.18.0 | 	github.com/prometheus/client_golang v1.18.0 | ||||||
| 	github.com/stretchr/testify v1.9.0 | 	github.com/stretchr/testify v1.9.0 | ||||||
|  | |||||||
							
								
								
									
										4
									
								
								go.sum
									
									
									
									
									
								
							
							
						
						
									
										4
									
								
								go.sum
									
									
									
									
									
								
							| @ -349,8 +349,8 @@ github.com/openimsdk/gomake v0.0.15-alpha.5 h1:eEZCEHm+NsmcO3onXZPIUbGFCYPYbsX5b | |||||||
| github.com/openimsdk/gomake v0.0.15-alpha.5/go.mod h1:PndCozNc2IsQIciyn9mvEblYWZwJmAI+06z94EY+csI= | github.com/openimsdk/gomake v0.0.15-alpha.5/go.mod h1:PndCozNc2IsQIciyn9mvEblYWZwJmAI+06z94EY+csI= | ||||||
| github.com/openimsdk/protocol v0.0.73-alpha.12 h1:2NYawXeHChYUeSme6QJ9pOLh+Empce2WmwEtbP4JvKk= | github.com/openimsdk/protocol v0.0.73-alpha.12 h1:2NYawXeHChYUeSme6QJ9pOLh+Empce2WmwEtbP4JvKk= | ||||||
| github.com/openimsdk/protocol v0.0.73-alpha.12/go.mod h1:WF7EuE55vQvpyUAzDXcqg+B+446xQyEba0X35lTINmw= | github.com/openimsdk/protocol v0.0.73-alpha.12/go.mod h1:WF7EuE55vQvpyUAzDXcqg+B+446xQyEba0X35lTINmw= | ||||||
| github.com/openimsdk/tools v0.0.50-alpha.85 h1:OqTUYx6r7Zp/eH8FKB08XeNjPV405TUIG9QT6QQ+F+s= | github.com/openimsdk/tools v0.0.50-alpha.87 h1:42jaKZZ5874o+1qup9KKHYmCQJWO7ibOKppxr8rhIS0= | ||||||
| github.com/openimsdk/tools v0.0.50-alpha.85/go.mod h1:n2poR3asX1e1XZce4O+MOWAp+X02QJRFvhcLCXZdzRo= | github.com/openimsdk/tools v0.0.50-alpha.87/go.mod h1:n2poR3asX1e1XZce4O+MOWAp+X02QJRFvhcLCXZdzRo= | ||||||
| github.com/pelletier/go-toml/v2 v2.2.2 h1:aYUidT7k73Pcl9nb2gScu7NSrKCSHIDE89b3+6Wq+LM= | github.com/pelletier/go-toml/v2 v2.2.2 h1:aYUidT7k73Pcl9nb2gScu7NSrKCSHIDE89b3+6Wq+LM= | ||||||
| github.com/pelletier/go-toml/v2 v2.2.2/go.mod h1:1t835xjRzz80PqgE6HHgN2JOsmgYu/h4qDAS4n929Rs= | github.com/pelletier/go-toml/v2 v2.2.2/go.mod h1:1t835xjRzz80PqgE6HHgN2JOsmgYu/h4qDAS4n929Rs= | ||||||
| github.com/pierrec/lz4/v4 v4.1.21 h1:yOVMLb6qSIDP67pl/5F7RepeKYu/VmTyEXvuMI5d9mQ= | github.com/pierrec/lz4/v4 v4.1.21 h1:yOVMLb6qSIDP67pl/5F7RepeKYu/VmTyEXvuMI5d9mQ= | ||||||
|  | |||||||
| @ -323,14 +323,21 @@ type RPC struct { | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| type Redis struct { | type Redis struct { | ||||||
| 	Disable     bool     `yaml:"-"` | 	Disable      bool     `yaml:"-"` | ||||||
| 	Address     []string `yaml:"address"` | 	Address      []string `yaml:"address"` | ||||||
| 	Username    string   `yaml:"username"` | 	Username     string   `yaml:"username"` | ||||||
| 	Password    string   `yaml:"password"` | 	Password     string   `yaml:"password"` | ||||||
| 	ClusterMode bool     `yaml:"clusterMode"` | 	ClusterMode  bool     `yaml:"clusterMode"` | ||||||
| 	DB          int      `yaml:"db"` | 	DB           int      `yaml:"db"` | ||||||
| 	MaxRetry    int      `yaml:"maxRetry"` | 	MaxRetry     int      `yaml:"maxRetry"` | ||||||
| 	PoolSize    int      `yaml:"poolSize"` | 	PoolSize     int      `yaml:"poolSize"` | ||||||
|  | 	SentinelMode Sentinel `yaml:"sentinelMode"` | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | type Sentinel struct { | ||||||
|  | 	Enable        bool     `yaml:"enable"` | ||||||
|  | 	MasterName    string   `yaml:"masterName"` | ||||||
|  | 	SentinelAddrs []string `yaml:"sentinelsAddrs"` | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| type BeforeConfig struct { | type BeforeConfig struct { | ||||||
| @ -494,6 +501,11 @@ func (r *Redis) Build() *redisutil.Config { | |||||||
| 		DB:          r.DB, | 		DB:          r.DB, | ||||||
| 		MaxRetry:    r.MaxRetry, | 		MaxRetry:    r.MaxRetry, | ||||||
| 		PoolSize:    r.PoolSize, | 		PoolSize:    r.PoolSize, | ||||||
|  | 		Sentinel: &redisutil.Sentinel{ | ||||||
|  | 			Enable:        r.SentinelMode.Enable, | ||||||
|  | 			MasterName:    r.SentinelMode.MasterName, | ||||||
|  | 			SentinelAddrs: r.SentinelMode.SentinelAddrs, | ||||||
|  | 		}, | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -28,6 +28,8 @@ import ( | |||||||
| 	"go.mongodb.org/mongo-driver/mongo/options" | 	"go.mongodb.org/mongo-driver/mongo/options" | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
|  | const StructTagName = "yaml" | ||||||
|  | 
 | ||||||
| const ( | const ( | ||||||
| 	MaxSeq                 = "MAX_SEQ:" | 	MaxSeq                 = "MAX_SEQ:" | ||||||
| 	MinSeq                 = "MIN_SEQ:" | 	MinSeq                 = "MIN_SEQ:" | ||||||
| @ -54,13 +56,14 @@ func readConfig[T any](dir string, name string) (*T, error) { | |||||||
| 	if err := v.ReadInConfig(); err != nil { | 	if err := v.ReadInConfig(); err != nil { | ||||||
| 		return nil, err | 		return nil, err | ||||||
| 	} | 	} | ||||||
| 	fn := func(config *mapstructure.DecoderConfig) { | 
 | ||||||
| 		config.TagName = "mapstructure" |  | ||||||
| 	} |  | ||||||
| 	var conf T | 	var conf T | ||||||
| 	if err := v.Unmarshal(&conf, fn); err != nil { | 	if err := v.Unmarshal(&conf, func(config *mapstructure.DecoderConfig) { | ||||||
|  | 		config.TagName = StructTagName | ||||||
|  | 	}); err != nil { | ||||||
| 		return nil, err | 		return nil, err | ||||||
| 	} | 	} | ||||||
|  | 
 | ||||||
| 	return &conf, nil | 	return &conf, nil | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| @ -69,6 +72,7 @@ func Main(conf string, del time.Duration) error { | |||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return err | 		return err | ||||||
| 	} | 	} | ||||||
|  | 	fmt.Println("[seq] redis config", redisConfig) | ||||||
| 	mongodbConfig, err := readConfig[config.Mongo](conf, config.MongodbConfigFileName) | 	mongodbConfig, err := readConfig[config.Mongo](conf, config.MongodbConfigFileName) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return err | 		return err | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user