Advanced features
AWS EC2 service discovery
The HAProxy Data Plane API scales your load balancer configuration to dynamically fit the current capacity of your pool of EC2 instances.
The HAProxy Data Plane API:
- Regularly polls the Amazon EC2 API.
- Automatically creates backends.
- Populates your backends with the server addresses of your EC2 instances.
- Uses the HAProxy Runtime API to minimize reloads during Amazon EC2 Auto Scaling events.

Add resource tags to your EC2 instances Jump to heading
Add the following resource tags to either:
- EC2 instances
- an AWS Auto Scaling Group launch template
The Data Plane API will discover tagged instances and populate a backend section in your load balancer configuration with their IP addresses. The instances may have been created either individually or from an Auto Scaling Group Launch Template.
| Tag | Description | Requisiteness | Example value | 
|---|---|---|---|
| HAProxy:Service:Name | A custom service name. | Mandatory | MyApp | 
| HAProxy:Service:Port | Port number that you want to send traffic to. | Mandatory | 80 | 
| HAProxy:Instance:Port | Overrides the service port for a single instance. | Optional | 8080 | 
For example, in a launch template:

Enable service discovery on the load balancer Jump to heading
To enable service discovery:
- 
Add a section such as the following to the Data Plane API configuration file: dataplaneapi.ymlyamlservice_discovery:aws_regions:- accesskeyid: KAB[...]2X6description: Production environmentenabled: trueipv4address: privatename: my-discregion: eu-west-3retrytimeout: 10secretaccesskey: qjT[...]uXVserverslotsbase: 10serverslotsgrowthincrement: 0serverslotsgrowthtype: exponentialdataplaneapi.ymlyamlservice_discovery:aws_regions:- accesskeyid: KAB[...]2X6description: Production environmentenabled: trueipv4address: privatename: my-discregion: eu-west-3retrytimeout: 10secretaccesskey: qjT[...]uXVserverslotsbase: 10serverslotsgrowthincrement: 0serverslotsgrowthtype: exponentialAlternatively, you can run a curlcommand with JSON keys such as the following:nixcurl -X POST \-u admin:adminpwd \-H 'Content-Type: application/json' \-d '{"access_key_id":"KAB[...]2X6","description":"Production environment","enabled":true,"ipv4_address":"private","name":"my-disc","region":"eu-west-3","secret_access_key":"qjT[...]uXV","retry_timeout":10}' \http://localhost:5555/v3/service_discovery/awsnixcurl -X POST \-u admin:adminpwd \-H 'Content-Type: application/json' \-d '{"access_key_id":"KAB[...]2X6","description":"Production environment","enabled":true,"ipv4_address":"private","name":"my-disc","region":"eu-west-3","secret_access_key":"qjT[...]uXV","retry_timeout":10}' \http://localhost:5555/v3/service_discovery/awsnixcurl -X POST \-u admin:adminpwd \-H 'Content-Type: application/json' \-d '{"access_key_id":"KAB[...]2X6","description":"Production environment","enabled":true,"ipv4_address":"private","name":"my-disc","region":"eu-west-3","secret_access_key":"qjT[...]uXV","retry_timeout":10}' \http://localhost:5555/v2/service_discovery/awsnixcurl -X POST \-u admin:adminpwd \-H 'Content-Type: application/json' \-d '{"access_key_id":"KAB[...]2X6","description":"Production environment","enabled":true,"ipv4_address":"private","name":"my-disc","region":"eu-west-3","secret_access_key":"qjT[...]uXV","retry_timeout":10}' \http://localhost:5555/v2/service_discovery/awsThis command sends configuration and authentication data to the Data Plane API’s AWS service discovery endpoint. Upon successful registration, it returns a JSON result and populates the Data Plane API configuration file. In this example, as we do not specify values for the server_slots_base,server_slots_growth_increment, andserver_slots_growth_typedirectives, default values will be used.Configuration directive JSON directive Description AccessKeyID access_key_id AWS Access Key ID Description description Service discovery description Enabled enabled trueorfalse. If set tofalse, the Data Plane API will not updateserversections in discoveredbackendsections. Data can become outdated if newer EC2 instances launch or if an existing instance reboots with a new IPv4 address.IPV4Address ipv4_address private(for the private network, reachable inside the AWS VPC) orpublic.Name name Service discovery name Region region AWS region RetryTimeout retry_timeout Interval of time in seconds between the reconciliation and the following. SecretAccessKey secret_access_key AWS Secret Access Key ServerSlotsBase server_slots_base The minimum amount of serverentries perbackendsection. Defaults to10.ServerSlotsGrowthIncrement server_slots_growth_increment The number of additional slots that are allocated for serverentries if there are additional entries. Defaults to0.ServerSlotsGrowthType server_slots_growth_type Function type to implement when the number of serverslots increases:exponentialorlinear. Defaults toexponential.EC2 instances with attached IAM roles If the EC2 instance where the Data Plane API is running has an IAM Role attached (as AmazonEC2ReadOnlyAccess), you do not need to specify credentials.
- 
Restart the service: If running the API via the HAProxy Process Manager, restart HAProxy. nixsudo systemctl restart hapee-extras-dataplaneapinixsudo systemctl restart hapee-extras-dataplaneapiIn the Services tab, restart the dataplaneapi service. 
- 
Check the load balancer configuration file. A new backend section displays: haproxy.cfg, hapee-lb.cfg, LB Layer7 tabhaproxybackend aws-eu-west-3-my-disc-MyApp-80server SRV_ONGQw 172.31.14.35:80 check weight 128server SRV_5hi3l 127.0.0.1:80 disabled weight 128server SRV_L2rw7 127.0.0.1:80 disabled weight 128server SRV_pG3MX 127.0.0.1:80 disabled weight 128server SRV_9WFsc 127.0.0.1:80 disabled weight 128server SRV_o2UU2 127.0.0.1:80 disabled weight 128server SRV_GMuw1 127.0.0.1:80 disabled weight 128server SRV_3Id36 127.0.0.1:80 disabled weight 128server SRV_6Ivld 127.0.0.1:80 disabled weight 128server SRV_jYF88 127.0.0.1:80 disabled weight 128haproxy.cfg, hapee-lb.cfg, LB Layer7 tabhaproxybackend aws-eu-west-3-my-disc-MyApp-80server SRV_ONGQw 172.31.14.35:80 check weight 128server SRV_5hi3l 127.0.0.1:80 disabled weight 128server SRV_L2rw7 127.0.0.1:80 disabled weight 128server SRV_pG3MX 127.0.0.1:80 disabled weight 128server SRV_9WFsc 127.0.0.1:80 disabled weight 128server SRV_o2UU2 127.0.0.1:80 disabled weight 128server SRV_GMuw1 127.0.0.1:80 disabled weight 128server SRV_3Id36 127.0.0.1:80 disabled weight 128server SRV_6Ivld 127.0.0.1:80 disabled weight 128server SRV_jYF88 127.0.0.1:80 disabled weight 128The name of the new backend comprises the following parts: aws-<AWS region>-<Service discovery name>-<HAProxy:Service:Name tag value>-<HAProxy:Service:Port tag value>This backend may only have several servers enabled out of the total number of servers specified by the ServerSlotsBasedirective. When you register more instances of the same service, the API fills in disabled server slots. You can thus scale up or down without a reload, in most cases.
- 
Edit the new backend as needed. For example, you can specify a load balancing algorithm via the balancedirective.
- 
Configure a frontendsection that routes traffic to this backend pool of servers. For example:haproxy.cfg, hapee-lb.cfg, LB Layer7 tabhaproxyfrontend examplebind :80default_backend aws-eu-west-3-my-disc-MyApp-80haproxy.cfg, hapee-lb.cfg, LB Layer7 tabhaproxyfrontend examplebind :80default_backend aws-eu-west-3-my-disc-MyApp-80
Do you have any suggestions on how we can improve the content of this page?