func main() { runtime.GOMAXPROCS(runtime.NumCPU()) config := app.NewProxyConfig() config.AddFlags(pflag.CommandLine) util.InitFlags() util.InitLogs() defer util.FlushLogs() verflag.PrintAndExitIfRequested() s, err := app.NewProxyServerDefault(config) if err != nil { fmt.Fprintf(os.Stderr, "%v\n", err) os.Exit(1) } if err = s.Run(pflag.CommandLine.Args()); err != nil { fmt.Fprintf(os.Stderr, "%v\n", err) os.Exit(1) } }
// NewKubeProxy creates a new hyperkube Server object that includes the // description and flags. func NewKubeProxy() *Server { config := kubeproxy.NewProxyConfig() hks := Server{ SimpleUsage: "proxy", Long: `The Kubernetes proxy server is responsible for taking traffic directed at services and forwarding it to the appropriate pods. It generally runs on nodes next to the Kubelet and proxies traffic from local pods to remote pods. It is also used when handling incoming external traffic.`, } config.AddFlags(hks.Flags()) hks.Run = func(_ *Server, args []string) error { s, err := kubeproxy.NewProxyServerDefault(config) if err != nil { return err } return s.Run(args) } return &hks }