From 1f97c2e7d45010b6917552ae18687919b92dd454 Mon Sep 17 00:00:00 2001
From: zhangzengfei <zhangzengfei@smartai.com>
Date: 星期二, 24 五月 2022 20:09:39 +0800
Subject: [PATCH] add ctx initialize

---
 config.go |   38 ++++++++++++++++++++++++++++++++------
 1 files changed, 32 insertions(+), 6 deletions(-)

diff --git a/config.go b/config.go
index 81b019b..d76f85b 100644
--- a/config.go
+++ b/config.go
@@ -17,6 +17,7 @@
 package syncdb
 
 import (
+	"context"
 	"fmt"
 	"net"
 	"os"
@@ -50,8 +51,6 @@
 	ReplayOnJoinDefault = false
 	SnapshotPathDefault = "./serfSnapShot"
 	MaxEventBufferCount = 2048
-
-	TcpTransportPort = 30194 //tcp浼犺緭澶ф暟鎹噺鎺ュ彛
 )
 
 // DefaultConfig default config
@@ -62,6 +61,7 @@
 	agentConf.UserEventSizeLimit = MaxUserEventSize
 	agentConf.BindAddr = fmt.Sprintf("0.0.0.0:%d", DefaultBindPort)
 	agentConf.RPCAddr = fmt.Sprintf("0.0.0.0:%d", DefaultRPCPort)
+	agentConf.Ctx = context.Background()
 	return &Config{
 		Mode:        ModeSingle,
 		Config:      agentConf,
@@ -69,18 +69,44 @@
 	}
 }
 
+func (c *Config) MergeConf(s *Config) {
+	if s != nil {
+		if s.Ctx != nil {
+			c.Ctx = s.Ctx
+		} else {
+			c.Ctx = context.Background()
+		}
+		c.BindAddr = s.BindAddr
+		c.RPCAddr = s.RPCAddr
+		c.RPCPort = s.RPCPort
+		//serf蹇収鍦板潃
+		if s.SnapshotPath != "" {
+			c.SnapshotPath = s.SnapshotPath
+		}
+		if s.EncryptKey != "" {
+			//鎶ユ枃鍔犲瘑鐨刱ey
+			c.EncryptKey = s.EncryptKey
+		}
+		if s.RPCAuthKey != "" {
+			//RPC璁よ瘉鐨刱ey
+			c.RPCAuthKey = s.RPCAuthKey
+		}
+	}
+}
+
 // Config struct
 type Config struct {
 	// config from serf agent
 	*agent.Config
-	Mode string `json:"mode"`
+	Mode 		string 		`json:"mode"`
 
 	// name to group members into cluster
-	ClusterID string `json:"cluster_name"`
+	ClusterID 	string 		`json:"cluster_name"`
 
 	// port to communicate between cluster members
-	ClusterPort int `yaml:"cluster_port"`
-	RPCPort     int `yaml:"-"`
+	ClusterPort int 		`yaml:"cluster_port"`
+	RPCPort     int 		`yaml:"-"`
+	Ctx 		context.Context
 }
 
 // readConfigFile reads configuration from config file

--
Gitblit v1.8.0