Account for upstream targets in another DC.

Transparent proxies typically cannot dial upstreams in remote
datacenters. However, if their upstream configures a redirect to a
remote DC then the upstream targets will be in another datacenter.

In that sort of case we should use the WAN address for the passthrough.
This commit is contained in:
freddygv 2022-02-09 17:16:00 -07:00
parent cbea3d203c
commit ceb52d649a
2 changed files with 24 additions and 17 deletions

View File

@ -1891,6 +1891,7 @@ func TestState_WatchesAndUpdates(t *testing.T) {
Nodes: structs.CheckServiceNodes{ Nodes: structs.CheckServiceNodes{
{ {
Node: &structs.Node{ Node: &structs.Node{
Datacenter: "dc1",
Node: "node1", Node: "node1",
Address: "10.0.0.1", Address: "10.0.0.1",
}, },
@ -1916,6 +1917,7 @@ func TestState_WatchesAndUpdates(t *testing.T) {
}, },
{ {
Node: &structs.Node{ Node: &structs.Node{
Datacenter: "dc1",
Node: "node2", Node: "node2",
Address: "10.0.0.2", Address: "10.0.0.2",
RaftIndex: structs.RaftIndex{ RaftIndex: structs.RaftIndex{
@ -1948,6 +1950,7 @@ func TestState_WatchesAndUpdates(t *testing.T) {
structs.CheckServiceNodes{ structs.CheckServiceNodes{
{ {
Node: &structs.Node{ Node: &structs.Node{
Datacenter: "dc1",
Node: "node1", Node: "node1",
Address: "10.0.0.1", Address: "10.0.0.1",
}, },
@ -1973,6 +1976,7 @@ func TestState_WatchesAndUpdates(t *testing.T) {
}, },
{ {
Node: &structs.Node{ Node: &structs.Node{
Datacenter: "dc1",
Node: "node2", Node: "node2",
Address: "10.0.0.2", Address: "10.0.0.2",
RaftIndex: structs.RaftIndex{ RaftIndex: structs.RaftIndex{
@ -2065,6 +2069,7 @@ func TestState_WatchesAndUpdates(t *testing.T) {
Nodes: structs.CheckServiceNodes{ Nodes: structs.CheckServiceNodes{
{ {
Node: &structs.Node{ Node: &structs.Node{
Datacenter: "dc1",
Node: "node2", Node: "node2",
Address: "10.0.0.2", Address: "10.0.0.2",
RaftIndex: structs.RaftIndex{ RaftIndex: structs.RaftIndex{
@ -2099,6 +2104,7 @@ func TestState_WatchesAndUpdates(t *testing.T) {
structs.CheckServiceNodes{ structs.CheckServiceNodes{
{ {
Node: &structs.Node{ Node: &structs.Node{
Datacenter: "dc1",
Node: "node2", Node: "node2",
Address: "10.0.0.2", Address: "10.0.0.2",
RaftIndex: structs.RaftIndex{ RaftIndex: structs.RaftIndex{
@ -2144,6 +2150,7 @@ func TestState_WatchesAndUpdates(t *testing.T) {
Nodes: structs.CheckServiceNodes{ Nodes: structs.CheckServiceNodes{
{ {
Node: &structs.Node{ Node: &structs.Node{
Datacenter: "dc1",
Node: "node2", Node: "node2",
}, },
Service: &structs.NodeService{ Service: &structs.NodeService{
@ -2178,6 +2185,7 @@ func TestState_WatchesAndUpdates(t *testing.T) {
structs.CheckServiceNodes{ structs.CheckServiceNodes{
{ {
Node: &structs.Node{ Node: &structs.Node{
Datacenter: "dc1",
Node: "node2", Node: "node2",
}, },
Service: &structs.NodeService{ Service: &structs.NodeService{

View File

@ -111,9 +111,8 @@ func (s *handlerUpstreams) handleUpdateUpstreams(ctx context.Context, u cache.Up
continue continue
} }
// Make sure to use an external address when crossing partitions. // Make sure to use an external address when crossing partition or DC boundaries.
// Datacenter is not considered because transparent proxies cannot dial other datacenters. isRemote := !snap.Locality.Matches(node.Node.Datacenter, node.Node.PartitionOrDefault())
isRemote := !structs.EqualPartitions(node.Node.PartitionOrDefault(), s.proxyID.PartitionOrDefault())
csnIdx, addr, _ := node.BestAddress(isRemote) csnIdx, addr, _ := node.BestAddress(isRemote)
existing := upstreamsSnapshot.PassthroughIndices[addr] existing := upstreamsSnapshot.PassthroughIndices[addr]