consul/connect: enable setting local_bind_address in upstream
This commit is contained in:
parent
b5f8a3eb93
commit
f45fc6c899
|
@ -286,9 +286,10 @@ func (cp *ConsulProxy) Canonicalize() {
|
|||
|
||||
// ConsulUpstream represents a Consul Connect upstream jobspec stanza.
|
||||
type ConsulUpstream struct {
|
||||
DestinationName string `mapstructure:"destination_name" hcl:"destination_name,optional"`
|
||||
LocalBindPort int `mapstructure:"local_bind_port" hcl:"local_bind_port,optional"`
|
||||
Datacenter string `mapstructure:"datacenter" hcl:"datacenter,optional"`
|
||||
DestinationName string `mapstructure:"destination_name" hcl:"destination_name,optional"`
|
||||
LocalBindPort int `mapstructure:"local_bind_port" hcl:"local_bind_port,optional"`
|
||||
Datacenter string `mapstructure:"datacenter" hcl:"datacenter,optional"`
|
||||
LocalBindAddress string `mapstructure:"local_bind_address" hcl:"local_bind_address,optional"`
|
||||
}
|
||||
|
||||
type ConsulExposeConfig struct {
|
||||
|
|
|
@ -228,9 +228,10 @@ func TestService_Connect_proxy_settings(t *testing.T) {
|
|||
Proxy: &ConsulProxy{
|
||||
Upstreams: []*ConsulUpstream{
|
||||
{
|
||||
DestinationName: "upstream",
|
||||
LocalBindPort: 80,
|
||||
Datacenter: "dc2",
|
||||
DestinationName: "upstream",
|
||||
LocalBindPort: 80,
|
||||
Datacenter: "dc2",
|
||||
LocalBindAddress: "127.0.0.2",
|
||||
},
|
||||
},
|
||||
LocalServicePort: 8000,
|
||||
|
@ -244,6 +245,7 @@ func TestService_Connect_proxy_settings(t *testing.T) {
|
|||
require.Equal(t, proxy.Upstreams[0].DestinationName, "upstream")
|
||||
require.Equal(t, proxy.Upstreams[0].LocalBindPort, 80)
|
||||
require.Equal(t, proxy.Upstreams[0].Datacenter, "dc2")
|
||||
require.Equal(t, proxy.Upstreams[0].LocalBindAddress, "127.0.0.2")
|
||||
require.Equal(t, proxy.LocalServicePort, 8000)
|
||||
}
|
||||
|
||||
|
|
|
@ -189,9 +189,10 @@ func connectUpstreams(in []structs.ConsulUpstream) []api.Upstream {
|
|||
upstreams := make([]api.Upstream, len(in))
|
||||
for i, upstream := range in {
|
||||
upstreams[i] = api.Upstream{
|
||||
DestinationName: upstream.DestinationName,
|
||||
LocalBindPort: upstream.LocalBindPort,
|
||||
Datacenter: upstream.Datacenter,
|
||||
DestinationName: upstream.DestinationName,
|
||||
LocalBindPort: upstream.LocalBindPort,
|
||||
Datacenter: upstream.Datacenter,
|
||||
LocalBindAddress: upstream.LocalBindAddress,
|
||||
}
|
||||
}
|
||||
return upstreams
|
||||
|
|
|
@ -315,17 +315,19 @@ func TestConnect_connectUpstreams(t *testing.T) {
|
|||
DestinationName: "foo",
|
||||
LocalBindPort: 8000,
|
||||
}, {
|
||||
DestinationName: "bar",
|
||||
LocalBindPort: 9000,
|
||||
Datacenter: "dc2",
|
||||
DestinationName: "bar",
|
||||
LocalBindPort: 9000,
|
||||
Datacenter: "dc2",
|
||||
LocalBindAddress: "127.0.0.2",
|
||||
}},
|
||||
connectUpstreams([]structs.ConsulUpstream{{
|
||||
DestinationName: "foo",
|
||||
LocalBindPort: 8000,
|
||||
}, {
|
||||
DestinationName: "bar",
|
||||
LocalBindPort: 9000,
|
||||
Datacenter: "dc2",
|
||||
DestinationName: "bar",
|
||||
LocalBindPort: 9000,
|
||||
Datacenter: "dc2",
|
||||
LocalBindAddress: "127.0.0.2",
|
||||
}}),
|
||||
)
|
||||
})
|
||||
|
|
|
@ -1513,9 +1513,10 @@ func apiUpstreamsToStructs(in []*api.ConsulUpstream) []structs.ConsulUpstream {
|
|||
upstreams := make([]structs.ConsulUpstream, len(in))
|
||||
for i, upstream := range in {
|
||||
upstreams[i] = structs.ConsulUpstream{
|
||||
DestinationName: upstream.DestinationName,
|
||||
LocalBindPort: upstream.LocalBindPort,
|
||||
Datacenter: upstream.Datacenter,
|
||||
DestinationName: upstream.DestinationName,
|
||||
LocalBindPort: upstream.LocalBindPort,
|
||||
Datacenter: upstream.Datacenter,
|
||||
LocalBindAddress: upstream.LocalBindAddress,
|
||||
}
|
||||
}
|
||||
return upstreams
|
||||
|
|
|
@ -3009,13 +3009,15 @@ func TestConversion_apiUpstreamsToStructs(t *testing.T) {
|
|||
require.Nil(t, apiUpstreamsToStructs(nil))
|
||||
require.Nil(t, apiUpstreamsToStructs(make([]*api.ConsulUpstream, 0)))
|
||||
require.Equal(t, []structs.ConsulUpstream{{
|
||||
DestinationName: "upstream",
|
||||
LocalBindPort: 8000,
|
||||
Datacenter: "dc2",
|
||||
DestinationName: "upstream",
|
||||
LocalBindPort: 8000,
|
||||
Datacenter: "dc2",
|
||||
LocalBindAddress: "127.0.0.2",
|
||||
}}, apiUpstreamsToStructs([]*api.ConsulUpstream{{
|
||||
DestinationName: "upstream",
|
||||
LocalBindPort: 8000,
|
||||
Datacenter: "dc2",
|
||||
DestinationName: "upstream",
|
||||
LocalBindPort: 8000,
|
||||
Datacenter: "dc2",
|
||||
LocalBindAddress: "127.0.0.2",
|
||||
}}))
|
||||
}
|
||||
|
||||
|
|
|
@ -2695,9 +2695,10 @@ func TestTaskGroupDiff(t *testing.T) {
|
|||
LocalServicePort: 8080,
|
||||
Upstreams: []ConsulUpstream{
|
||||
{
|
||||
DestinationName: "foo",
|
||||
LocalBindPort: 8000,
|
||||
Datacenter: "dc2",
|
||||
DestinationName: "foo",
|
||||
LocalBindPort: 8000,
|
||||
Datacenter: "dc2",
|
||||
LocalBindAddress: "127.0.0.2",
|
||||
},
|
||||
},
|
||||
Config: map[string]interface{}{
|
||||
|
@ -2986,6 +2987,12 @@ func TestTaskGroupDiff(t *testing.T) {
|
|||
Old: "",
|
||||
New: "foo",
|
||||
},
|
||||
{
|
||||
Type: DiffTypeAdded,
|
||||
Name: "LocalBindAddress",
|
||||
Old: "",
|
||||
New: "127.0.0.2",
|
||||
},
|
||||
{
|
||||
Type: DiffTypeAdded,
|
||||
Name: "LocalBindPort",
|
||||
|
|
|
@ -630,6 +630,7 @@ func hashConnect(h hash.Hash, connect *ConsulConnect) {
|
|||
hashString(h, upstream.DestinationName)
|
||||
hashString(h, strconv.Itoa(upstream.LocalBindPort))
|
||||
hashStringIfNonEmpty(h, upstream.Datacenter)
|
||||
hashStringIfNonEmpty(h, upstream.LocalBindAddress)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -1198,6 +1199,10 @@ type ConsulUpstream struct {
|
|||
|
||||
// Datacenter is the datacenter in which to issue the discovery query to.
|
||||
Datacenter string
|
||||
|
||||
// LocalBindAddress is the address the proxy will receive connections for the
|
||||
// upstream on.
|
||||
LocalBindAddress string
|
||||
}
|
||||
|
||||
func upstreamsEquals(a, b []ConsulUpstream) bool {
|
||||
|
@ -1224,9 +1229,10 @@ func (u *ConsulUpstream) Copy() *ConsulUpstream {
|
|||
}
|
||||
|
||||
return &ConsulUpstream{
|
||||
DestinationName: u.DestinationName,
|
||||
LocalBindPort: u.LocalBindPort,
|
||||
Datacenter: u.Datacenter,
|
||||
DestinationName: u.DestinationName,
|
||||
LocalBindPort: u.LocalBindPort,
|
||||
Datacenter: u.Datacenter,
|
||||
LocalBindAddress: u.LocalBindAddress,
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -286,9 +286,10 @@ func (cp *ConsulProxy) Canonicalize() {
|
|||
|
||||
// ConsulUpstream represents a Consul Connect upstream jobspec stanza.
|
||||
type ConsulUpstream struct {
|
||||
DestinationName string `mapstructure:"destination_name" hcl:"destination_name,optional"`
|
||||
LocalBindPort int `mapstructure:"local_bind_port" hcl:"local_bind_port,optional"`
|
||||
Datacenter string `mapstructure:"datacenter" hcl:"datacenter,optional"`
|
||||
DestinationName string `mapstructure:"destination_name" hcl:"destination_name,optional"`
|
||||
LocalBindPort int `mapstructure:"local_bind_port" hcl:"local_bind_port,optional"`
|
||||
Datacenter string `mapstructure:"datacenter" hcl:"datacenter,optional"`
|
||||
LocalBindAddress string `mapstructure:"local_bind_address" hcl:"local_bind_address,optional"`
|
||||
}
|
||||
|
||||
type ConsulExposeConfig struct {
|
||||
|
|
|
@ -54,6 +54,7 @@ job "countdash" {
|
|||
destination_name = "count-api"
|
||||
local_bind_port = 8080
|
||||
datacenter = "dc1"
|
||||
local_bind_address = "127.0.0.1"
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -84,6 +85,8 @@ job "countdash" {
|
|||
- `datacenter` `(string: "")` - The Consul datacenter in which to issue the
|
||||
discovery query. Defaults to the empty string, which Consul interprets as the
|
||||
local Consul datacenter.
|
||||
- `local_bind_address` - `(string: "")` - The address the proxy will receive
|
||||
connections for the upstream on.
|
||||
|
||||
The `NOMAD_UPSTREAM_ADDR_<destination_name>` environment variables may be used
|
||||
to interpolate the upstream's `host:port` address.
|
||||
|
|
Loading…
Reference in New Issue