mirror of
https://github.com/etcd-io/etcd.git
synced 2024-09-27 06:25:44 +00:00

This is a simple solution to having the proxy keep up to date with the state of the cluster. Basically, it uses the cluster configuration provided at start up (i.e. with `-initial-cluster-state`) to determine where to reach peer(s) in the cluster, and then it will periodically hit the `/members` endpoint of those peer(s) (using the same mechanism that `-cluster-state=existing` does to initialise) to update the set of valid client URLs to proxy to. This does not address discovery (#1376), and it would probably be better to update the set of proxyURLs dynamically whenever we fetch the new state of the cluster; but it needs a bit more thinking to have this done in a clean way with the proxy interface. Example in Procfile works again.
51 lines
1.4 KiB
Go
51 lines
1.4 KiB
Go
/*
|
|
Copyright 2014 CoreOS, Inc.
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
you may not use this file except in compliance with the License.
|
|
You may obtain a copy of the License at
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
See the License for the specific language governing permissions and
|
|
limitations under the License.
|
|
*/
|
|
|
|
package proxy
|
|
|
|
import (
|
|
"net/http"
|
|
)
|
|
|
|
// GetProxyURLs is a function which should return the current set of URLs to
|
|
// which client requests should be proxied. This function will be queried
|
|
// periodically by the proxy Handler to refresh the set of available
|
|
// backends.
|
|
type GetProxyURLs func() []string
|
|
|
|
func NewHandler(t *http.Transport, urlsFunc GetProxyURLs) http.Handler {
|
|
return &reverseProxy{
|
|
director: newDirector(urlsFunc),
|
|
transport: t,
|
|
}
|
|
}
|
|
|
|
func readonlyHandlerFunc(next http.Handler) func(http.ResponseWriter, *http.Request) {
|
|
return func(w http.ResponseWriter, req *http.Request) {
|
|
if req.Method != "GET" {
|
|
w.WriteHeader(http.StatusNotImplemented)
|
|
return
|
|
}
|
|
|
|
next.ServeHTTP(w, req)
|
|
}
|
|
}
|
|
|
|
func NewReadonlyHandler(hdlr http.Handler) http.Handler {
|
|
readonly := readonlyHandlerFunc(hdlr)
|
|
return http.HandlerFunc(readonly)
|
|
}
|