command/connect/proxy: output information when starting similar to agent

pull/4275/head
Mitchell Hashimoto 2018-05-19 15:47:25 -07:00
parent 55c6d34ea0
commit 1db42050bd
No known key found for this signature in database
GPG Key ID: 744E147AA52F5B0A
1 changed files with 33 additions and 3 deletions

View File

@ -23,6 +23,13 @@ import (
) )
func New(ui cli.Ui, shutdownCh <-chan struct{}) *cmd { func New(ui cli.Ui, shutdownCh <-chan struct{}) *cmd {
ui = &cli.PrefixedUi{
OutputPrefix: "==> ",
InfoPrefix: " ",
ErrorPrefix: "==> ",
Ui: ui,
}
c := &cmd{UI: ui, shutdownCh: shutdownCh} c := &cmd{UI: ui, shutdownCh: shutdownCh}
c.init() c.init()
return c return c
@ -49,6 +56,7 @@ type cmd struct {
serviceAddr string serviceAddr string
upstreams map[string]proxyImpl.UpstreamConfig upstreams map[string]proxyImpl.UpstreamConfig
listen string listen string
register bool
// test flags // test flags
testNoStart bool // don't start the proxy, just exit 0 testNoStart bool // don't start the proxy, just exit 0
@ -92,6 +100,10 @@ func (c *cmd) init() {
"Address to listen for inbound connections to the proxied service. "+ "Address to listen for inbound connections to the proxied service. "+
"Must be specified with -service and -service-addr.") "Must be specified with -service and -service-addr.")
c.flags.BoolVar(&c.register, "register", false,
"Self-register with the local Consul agent. Only useful with "+
"-listen.")
c.http = &flags.HTTPFlags{} c.http = &flags.HTTPFlags{}
flags.Merge(c.flags, c.http.ClientFlags()) flags.Merge(c.flags, c.http.ClientFlags())
flags.Merge(c.flags, c.http.ServerFlags()) flags.Merge(c.flags, c.http.ServerFlags())
@ -143,6 +155,10 @@ func (c *cmd) Run(args []string) int {
return 1 return 1
} }
// Output this first since the config watcher below will output
// other information.
c.UI.Output("Consul Connect proxy starting...")
// Get the proper configuration watcher // Get the proper configuration watcher
cfgWatcher, err := c.configWatcher(client) cfgWatcher, err := c.configWatcher(client)
if err != nil { if err != nil {
@ -162,8 +178,7 @@ func (c *cmd) Run(args []string) int {
p.Close() p.Close()
}() }()
c.UI.Output("Consul Connect proxy starting") c.UI.Info("")
c.UI.Output("Log data will now stream in as it occurs:\n") c.UI.Output("Log data will now stream in as it occurs:\n")
logGate.Flush() logGate.Flush()
@ -185,11 +200,15 @@ func (c *cmd) configWatcher(client *api.Client) (proxyImpl.ConfigWatcher, error)
if err != nil { if err != nil {
return nil, err return nil, err
} }
c.UI.Info("Configuration mode: File")
return proxyImpl.NewStaticConfigWatcher(cfg), nil return proxyImpl.NewStaticConfigWatcher(cfg), nil
} }
// Use the configured proxy ID // Use the configured proxy ID
if c.proxyID != "" { if c.proxyID != "" {
c.UI.Info("Configuration mode: Agent API")
c.UI.Info(fmt.Sprintf(" Proxy ID: %s", c.proxyID))
return proxyImpl.NewAgentConfigWatcher(client, c.proxyID, c.logger) return proxyImpl.NewAgentConfigWatcher(client, c.proxyID, c.logger)
} }
@ -200,6 +219,9 @@ func (c *cmd) configWatcher(client *api.Client) (proxyImpl.ConfigWatcher, error)
"configure itself.") "configure itself.")
} }
c.UI.Info("Configuration mode: Flags")
c.UI.Info(fmt.Sprintf(" Service: %s", c.service))
// Convert our upstreams to a slice of configurations. We do this // Convert our upstreams to a slice of configurations. We do this
// deterministically by alphabetizing the upstream keys. We do this so // deterministically by alphabetizing the upstream keys. We do this so
// that tests can compare the upstream values. // that tests can compare the upstream values.
@ -210,7 +232,12 @@ func (c *cmd) configWatcher(client *api.Client) (proxyImpl.ConfigWatcher, error)
sort.Strings(upstreamKeys) sort.Strings(upstreamKeys)
upstreams := make([]proxyImpl.UpstreamConfig, 0, len(c.upstreams)) upstreams := make([]proxyImpl.UpstreamConfig, 0, len(c.upstreams))
for _, k := range upstreamKeys { for _, k := range upstreamKeys {
upstreams = append(upstreams, c.upstreams[k]) config := c.upstreams[k]
c.UI.Info(fmt.Sprintf(
" Upstream: %s => %s:%d",
k, config.LocalBindAddress, config.LocalBindPort))
upstreams = append(upstreams, config)
} }
// Parse out our listener if we have one // Parse out our listener if we have one
@ -232,9 +259,12 @@ func (c *cmd) configWatcher(client *api.Client) (proxyImpl.ConfigWatcher, error)
"knows the backend service address.") "knows the backend service address.")
} }
c.UI.Info(fmt.Sprintf(" Public listener: %s:%d => %s", host, int(port), c.serviceAddr))
listener.BindAddress = host listener.BindAddress = host
listener.BindPort = int(port) listener.BindPort = int(port)
listener.LocalServiceAddress = c.serviceAddr listener.LocalServiceAddress = c.serviceAddr
} else {
c.UI.Info(fmt.Sprintf(" Public listener: Disabled"))
} }
return proxyImpl.NewStaticConfigWatcher(&proxyImpl.Config{ return proxyImpl.NewStaticConfigWatcher(&proxyImpl.Config{