Exposing services on the application network using YAML¶
Use YAML to create connectors and listeners for services on the application network.
After creating an application network by linking sites, you can expose services from one site using connectors and consume those services on other sites using listeners.
A routing key is a string that matches one or more connectors with one or more listeners.
For example, if you create a connector with the routing key backend, you need to create a listener with the routing key backend to consume that service.
This section assumes you have created and linked at least two sites.
Creating a connector using YAML¶
A connector binds a local workload to listeners in remote sites. Listeners and connectors are matched using routing keys.
For more information about connectors see Connector concept. For configuration details, see Connector resource.
Procedure
-
Create a workload that you want to expose on the network, for example:
-
Create a connector resource YAML file:
This creates a connector in theapiVersion: skupper.io/v2alpha1 kind: Connector metadata: name: backend namespace: east spec: routingKey: backend selector: app=backend port: 8080eastsite and exposes thebackenddeployment on the network on port 8080. You can create a listener on a different site using the matching routing keybackendto address this service.
To create the connector resource:
where <filename> is the name of a YAML file that is saved on your local filesystem.
- Check the connector status:
For example:
NAME STATUS ROUTING-KEY SELECTOR HOST PORT HAS MATCHING LISTENER MESSAGE
backend Pending backend app=backend 8080 false No matching listeners
spec.routingKey to your custom value.
Creating a listener using YAML¶
A listener binds a local connection endpoint to connectors in remote sites. Listeners and connectors are matched using routing keys.
For more information about listeners, see Listener concept. For configuration details, see Listener resource.
Procedure
-
Identify a connector that you want to use. Note the routing key of that connector.
-
Create a listener resource YAML file:
This creates a listener on the local system site and matches it with connectors that use the routing keyapiVersion: skupper.io/v2alpha1 kind: Listener metadata: name: backend namespace: west spec: routingKey: backend host: east-backend port: 8080backend. The listener accepts connections on port 8080 using the configured host value.
To create the listener resource:
where <filename> is the name of a YAML file that is saved on your local filesystem.
- Check the listener status:
For example:
NAME STATUS ROUTING-KEY HOST PORT MATCHING-CONNECTOR MESSAGE
backend Ready backend 0.0.0.0 8080 true OK
📌 NOTE
There must be a MATCHING-CONNECTOR for the service to operate.
Creating a multi-key listener using YAML¶
A multi-key listener binds a single local host and port to multiple routing keys in remote sites. Use a multi-key listener when you want one service endpoint to aggregate traffic from multiple connectors.
With multi-key listeners, you must choose a strategy which determines how the traffic is distributed:
- priority - Uses the first routing key in list that is available for traffic. If the connector becomes unavailable, the listener matches with the next available routing key in list.
- weighted - Uses the routing keys in proportion to the assigned weights. For example, if
backend1is assigned 25 andbackend2is assigned 75, then only a quarter of the TCP connections are directed tobackend1.
For configuration details, see Listener resource.
Prerequisites
- Multiple connectors created with different routing keys. See Creating a connector using YAML.
Procedure
-
Identify the connectors that you want to aggregate. Note the routing keys for each connector.
-
Determine which strategy is best for your use case. For example, failover is best achieved using the
prioritystrategy. -
Create a multi-key listener resource YAML file. For example:
This creates a listener namedapiVersion: skupper.io/v2alpha1 kind: MultiKeyListener metadata: name: mkl-backend spec: host: mkl-backend port: 9092 strategy: weighted: routingKeys: east-backend: 1 west-backend: 1mkl-backendthat exposes a single endpoint on port 9092 and distributes traffic evenly across theeast-backendandwest-backendrouting keys.
To prefer one routing key first and fall back to another, use the priority strategy:
apiVersion: skupper.io/v2alpha1
kind: MultiKeyListener
metadata:
name: mkl-backend-priority
spec:
host: mkl-backend-priority
port: 9095
strategy:
priority:
routingKeys:
- east-backend-http
- west-backend-http
To create the multi-key listener resource:
where <filename> is the name of a YAML file that is saved on your local filesystem.
```
📌 NOTE If you need to change strategy after you created a multi-key listener, you must delete and recreate the resource. This does not affect changing routing keys or weights.