[ aws . globalaccelerator ]
Create a listener to process inbound connections from clients to an accelerator. Connections arrive to assigned static IP addresses on a port, port range, or list of port ranges that you specify. To see an AWS CLI example of creating a listener, scroll down to Example .
See also: AWS API Documentation
See ‘aws help’ for descriptions of global parameters.
create-listener
--accelerator-arn <value>
--port-ranges <value>
--protocol <value>
[--client-affinity <value>]
[--idempotency-token <value>]
[--cli-input-json | --cli-input-yaml]
[--generate-cli-skeleton <value>]
[--cli-auto-prompt <value>]
--accelerator-arn
(string)
The Amazon Resource Name (ARN) of your accelerator.
--port-ranges
(list)
The list of port ranges to support for connections from clients to your accelerator.
(structure)
A complex type for a range of ports for a listener.
FromPort -> (integer)
The first port in the range of ports, inclusive.
ToPort -> (integer)
The last port in the range of ports, inclusive.
Shorthand Syntax:
FromPort=integer,ToPort=integer ...
JSON Syntax:
[
{
"FromPort": integer,
"ToPort": integer
}
...
]
--protocol
(string)
The protocol for connections from clients to your accelerator.
Possible values:
TCP
UDP
--client-affinity
(string)
Client affinity lets you direct all requests from a user to the same endpoint, if you have stateful applications, regardless of the port and protocol of the client request. Clienty affinity gives you control over whether to always route each client to the same specific endpoint.
AWS Global Accelerator uses a consistent-flow hashing algorithm to choose the optimal endpoint for a connection. If client affinity is
NONE
, Global Accelerator uses the “five-tuple” (5-tuple) properties—source IP address, source port, destination IP address, destination port, and protocol—to select the hash value, and then chooses the best endpoint. However, with this setting, if someone uses different ports to connect to Global Accelerator, their connections might not be always routed to the same endpoint because the hash value changes.If you want a given client to always be routed to the same endpoint, set client affinity to
SOURCE_IP
instead. When you use theSOURCE_IP
setting, Global Accelerator uses the “two-tuple” (2-tuple) properties— source (client) IP address and destination IP address—to select the hash value.The default value is
NONE
.Possible values:
NONE
SOURCE_IP
--idempotency-token
(string)
A unique, case-sensitive identifier that you provide to ensure the idempotency—that is, the uniqueness—of the request.
--cli-input-json
| --cli-input-yaml
(string)
Reads arguments from the JSON string provided. The JSON string follows the format provided by --generate-cli-skeleton
. If other arguments are provided on the command line, those values will override the JSON-provided values. It is not possible to pass arbitrary binary values using a JSON-provided value as the string will be taken literally. This may not be specified along with --cli-input-yaml
.
--generate-cli-skeleton
(string)
Prints a JSON skeleton to standard output without sending an API request. If provided with no value or the value input
, prints a sample input JSON that can be used as an argument for --cli-input-json
. Similarly, if provided yaml-input
it will print a sample input YAML that can be used with --cli-input-yaml
. If provided with the value output
, it validates the command inputs and returns a sample output JSON for that command.
--cli-auto-prompt
(boolean)
Automatically prompt for CLI input parameters.
See ‘aws help’ for descriptions of global parameters.
To create a listener
The following create-listener
example creates a listener with two ports.
aws globalaccelerator create-listener \
--accelerator-arn arn:aws:globalaccelerator::123456789012:accelerator/1234abcd-abcd-1234-abcd-1234abcdefgh \
--port-ranges FromPort=80,ToPort=80 FromPort=81,ToPort=81 \
--protocol TCP \
--region us-west-2
Output:
{
"Listener": {
"PortRanges": [
{
"ToPort": 80,
"FromPort": 80
},
{
"ToPort": 81,
"FromPort": 81
}
],
"ClientAffinity": "NONE",
"Protocol": "TCP",
"ListenerArn": "arn:aws:globalaccelerator::012345678901:accelerator/1234abcd-abcd-1234-abcd-1234abcdefgh/listener/0123vxyz"
}
}
For more information, see Listeners in AWS Global Accelerator in the AWS Global Accelerator Developer Guide.
Listener -> (structure)
The listener that you’ve created.
ListenerArn -> (string)
The Amazon Resource Name (ARN) of the listener.
PortRanges -> (list)
The list of port ranges for the connections from clients to the accelerator.
(structure)
A complex type for a range of ports for a listener.
FromPort -> (integer)
The first port in the range of ports, inclusive.
ToPort -> (integer)
The last port in the range of ports, inclusive.
Protocol -> (string)
The protocol for the connections from clients to the accelerator.
ClientAffinity -> (string)
Client affinity lets you direct all requests from a user to the same endpoint, if you have stateful applications, regardless of the port and protocol of the client request. Clienty affinity gives you control over whether to always route each client to the same specific endpoint.
AWS Global Accelerator uses a consistent-flow hashing algorithm to choose the optimal endpoint for a connection. If client affinity is
NONE
, Global Accelerator uses the “five-tuple” (5-tuple) properties—source IP address, source port, destination IP address, destination port, and protocol—to select the hash value, and then chooses the best endpoint. However, with this setting, if someone uses different ports to connect to Global Accelerator, their connections might not be always routed to the same endpoint because the hash value changes.If you want a given client to always be routed to the same endpoint, set client affinity to
SOURCE_IP
instead. When you use theSOURCE_IP
setting, Global Accelerator uses the “two-tuple” (2-tuple) properties— source (client) IP address and destination IP address—to select the hash value.The default value is
NONE
.