Multiple parents
Set up route delegation for a child HTTPRoute resource that can receive traffic from one or more parent HTTPRoute resources.
Configuration overview
In this guide you walk through a route delegation example that demonstrates route delegation between two parent HTTPRoute and two child HTTPRoute resources that forward traffic to an httpbin sample app. The following image illustrates the route delegation hierarchy:
parent1
and parent2
HTTPRoutes:
- The parent HTTPRoute resource
parent1
serves traffic for thedelegation-parent1.example
domain. - The parent HTTPRoute resource
parent2
serves traffic for thedelegation-parent2.example
domain. - Both parent HTTPRoute resources have routes that delegate traffic as follows:
/anything/team1
delegates traffic to the child HTTPRoute resourcechild-team1
in namespaceteam1
./anything/team2
delegates traffic to the child HTTPRoute resourcechild-team2
in namespaceteam2
.
child-team1
HTTPRoute:
- The child HTTPRoute resource
child-team1
matches incoming traffic for the/anything/team1/foo
prefix path and routes that traffic to the httpbin app in namespaceteam1
. The resource does not select any parent HTTPRoute resource in theparentRef
section. Both parent HTTPRoute resources can therefore delegate traffic to this child HTTPRoute resource.
child-team2
HTTPRoute:
- The child HTTPRoute resource
child-team2
matches incoming traffic for the/anything/team2/bar
exact prefix path and routes that traffic to the httpbin app in namespaceteam2
. The resource selects theparent1
HTTPRoute resource in theparentRef
section. Because of that, only theparent1
HTTPRoute resource can delegate traffic to this child HTTPRoute resource. Theparent2
HTTPRoute resource cannot delegate traffic to this child.
Before you begin
Create the namespaces for
team1
andteam2
.Deploy the httpbin app into both namespaces.
Verify that the httpbin apps are up and running.
Example output:
Setup
Create the
parent1
HTTPRoute resource that matches incoming traffic on thedelegation-parent1.example
domain. The HTTPRoute resource specifies two routes:/anything/team1
: The routing decision is delegated to a child HTTPRoute resource in theteam1
namespace./anything/team2
: The routing decision is delegated to a child HTTPRoute resource in theteam2
namespace.
Create the second
parent2
HTTPRoute resource that serves traffic for thedelegation-parent2.example
domain. The HTTPRoute resource specifies two routes:/anything/team1
: The routing decision is delegated to a child HTTPRoute resource in theteam1
namespace./anything/team2
: The routing decision is delegated to a child HTTPRoute resource in theteam2
namespace.
Create the child HTTPRoute resource
child-team1
in theteam1
namespace that matches traffic on the/anything/team1/foo
prefix and routes traffic to the httpbin app in theteam1
namespace. The child HTTPRoute resource does not select a specific parent HTTPRoute resource. Because of that, the child HTTPRoute resource is automatically selected by all parent HTTPRoute resources that delegate traffic to this child.Create the child HTTPRoute resource
child-team2
in theteam2
namespace that matches traffic on the/anything/team1/bar
exact prefix and routes traffic to the httpbin app in theteam2
namespace. The child HTTPRoute resource specifies theparent1
HTTPRoute resource in thespec.parentRefs
section. Because of that, onlyparent1
can delegate traffic to this child.Send a request to the
delegation-parent1.example
domain along the/anything/team1/foo
path. Verify that you get back a 200 HTTP response code.Example output:
Send another request to the
delegation-parent1.example
domain along the/anything/team2/bar
path. Verify that you get back a 200 HTTP response code.Example output:
Now, send a request to the
delegation-parent2.example
domain along the/anything/team1/foo
path. Verify that you get back a 200 HTTP response code.Example output:
Send another request to the
delegation-parent2.example
domain. This time, you send traffic along the/anything/team2/bar
path. Notice that although theparent2
HTTPRoute resource delegates traffic to thechild-team2
HTTPRoute resource, the child resource allows traffic from theparent1
HTTPRoute resource only. Because of that, the request fails and you get back a 404 HTTP response code.Example output:
Cleanup
You can remove the resources that you created in this guide.