diff --git a/.gitignore b/.gitignore index 81e2de79eb92..e100d1441189 100644 --- a/.gitignore +++ b/.gitignore @@ -9,3 +9,5 @@ tags /.retools/ vendor default* +*.bak +.vscode/ diff --git a/server/api/redirector.go b/server/api/redirector.go index 911f48e58bc7..fe45c7acbef9 100644 --- a/server/api/redirector.go +++ b/server/api/redirector.go @@ -14,10 +14,12 @@ package api import ( + "crypto/tls" "io/ioutil" "net/http" "net/url" "strings" + "sync" log "github.com/pingcap/log" "github.com/pingcap/pd/server" @@ -33,6 +35,8 @@ const ( errRedirectToNotLeader = "redirect to not leader" ) +var initHTTPClientOnce sync.Once + type redirector struct { s *server.Server } @@ -67,7 +71,20 @@ func (h *redirector) ServeHTTP(w http.ResponseWriter, r *http.Request, next http http.Error(w, err.Error(), http.StatusInternalServerError) return } - + initHTTPClientOnce.Do(func() { + var tlsConfig *tls.Config + tlsConfig, err = h.s.GetSecurityConfig().ToTLSConfig() + dialClient = &http.Client{ + Transport: &http.Transport{ + DisableKeepAlives: true, + TLSClientConfig: tlsConfig, + }, + } + }) + if err != nil { + http.Error(w, err.Error(), http.StatusInternalServerError) + return + } newCustomReverseProxies(urls).ServeHTTP(w, r) } diff --git a/tests/pdctl/cluster/cluster_test.go b/tests/pdctl/cluster/cluster_test.go index d3ec229c6563..f9aade310750 100644 --- a/tests/pdctl/cluster/cluster_test.go +++ b/tests/pdctl/cluster/cluster_test.go @@ -69,6 +69,7 @@ func (s *clusterTestSuite) TestClusterAndPing(c *C) { temp.Close() os.Stdout = old out, _ := ioutil.ReadFile(fname) + os.Remove(fname) c.Assert(strings.Contains(string(out), "no such file or directory"), IsTrue) // cluster status diff --git a/tests/pdctl/region/region_test.go b/tests/pdctl/region/region_test.go index c916e2a6c2ea..dacb279f95d8 100644 --- a/tests/pdctl/region/region_test.go +++ b/tests/pdctl/region/region_test.go @@ -68,6 +68,7 @@ func (s *regionTestSuite) TestRegionKeyFormat(c *C) { temp.Close() os.Stdout = old out, _ := ioutil.ReadFile(fname) + os.Remove(fname) c.Assert(strings.Contains(string(out), "unknown flag"), IsFalse) }