An accelerator can reduce the time it takes to reach a server, it does this by routing your network packets through to AWS global network (rather than going through the general internet).
data:image/s3,"s3://crabby-images/7fde1/7fde19cdbbadc0b6b863993d0f83b98afb5ae209" alt=""
Let’s create one
An accelerator also able to load balance and you can specify the weights/traffic dials (percentage of traffic that goes to each endpoints).
data:image/s3,"s3://crabby-images/e1b2d/e1b2deb73feade0c0dd3ba9a45a98eca5344afe4" alt=""
data:image/s3,"s3://crabby-images/35738/35738b2e03a187e01aec63795c1a9e096f5c8e97" alt=""
data:image/s3,"s3://crabby-images/ff46a/ff46a7a134a181663517ad09dcd9744b303c0ab4" alt=""
data:image/s3,"s3://crabby-images/1ea5a/1ea5a6d1b3b95f8ac70f35773b810adad4626c32" alt=""
Configure the endpoint groups, I specified that 70% of traffic (Traffic dial) should go to my Singapore end group.
data:image/s3,"s3://crabby-images/84ec3/84ec38003807863ed57bc3ec6a8113cc48a03c57" alt=""
For each endpoint group I configure port overrides. Advantage of this is because in Linux for ports below to 1024 requires root privilege to run, I can use non root user to run services on higher ports. Running services as root is considered less secure (if the service gets cracked/hacked then the cracker/hacker will have root privilege).
data:image/s3,"s3://crabby-images/aa526/aa526616a015f359c4f2cbbc3384b5d645a338f2" alt=""
You can also customize the health check parameters
data:image/s3,"s3://crabby-images/1f6c5/1f6c5502391ccfd96bc58befcfacf30ae64cdab5" alt=""
Specify the endpoints in each endpoint group, here I am using EC2 instances, but they are other types you can choose from. I specified the same weight 128, which means I want traffic to be divided equally 50% 50% between the 2 instances.
data:image/s3,"s3://crabby-images/5ed3c/5ed3c356814d7f9e36d2953e86c647650233be61" alt=""
data:image/s3,"s3://crabby-images/4a909/4a9098f0f6534c87d4322bbe9e176be8664dcb7a" alt=""
Once created you can start testing.
On my instances, I have nginx running on port 80, 8080 and 8090.
Mine had a warning, I forgot to set the security groups to allow port 8080 and 8090. Let’s fix that.
data:image/s3,"s3://crabby-images/87ef9/87ef9a3062c00a1016550b1ff6f8f74bb14888a4" alt=""
data:image/s3,"s3://crabby-images/c510f/c510f85cc5252ca2440be8ea1567324980f301d4" alt=""
data:image/s3,"s3://crabby-images/c3d2b/c3d2b7c115254e45ef6fae60078ff58b0dbb0519" alt=""
data:image/s3,"s3://crabby-images/d6126/d6126d69d642a1f2150e9e17415a60e9c9a5e9ae" alt=""
data:image/s3,"s3://crabby-images/f1b2c/f1b2ca07d273cf51a610303dd5bbc9752f74cd65" alt=""
data:image/s3,"s3://crabby-images/b6941/b6941b888b98e3fb95facc8aa251bbafecb09955" alt=""
Is client IP preserved?
After checking the nginx access logs, yes, client IP is preserved, which is good and as advertised.
However, even though I specified health checks to be done every 30 seconds. Seems like the health checks are a lot more frequent.
data:image/s3,"s3://crabby-images/0906c/0906cc695450582da4d46960ef7b0fc737895624" alt=""
data:image/s3,"s3://crabby-images/ead14/ead1446da0c2b8ab0826d03b1690dc6e9a6b8fd3" alt=""
data:image/s3,"s3://crabby-images/d3edf/d3edf6b0e6363db4fd7ca5785a1dacbeaebc3ef5" alt=""
data:image/s3,"s3://crabby-images/d8aca/d8aca4c257811cf5ca668c7795df1095084b5455" alt=""
data:image/s3,"s3://crabby-images/78e5d/78e5d641ecf4e5fb3144e084e92e5cb0c654a9c2" alt=""
Unhealthy endpoints
Let’s see what is the behaviour of the accelerator when 1 or more endpoints are unhealthy. I stopped the nginx services on 2 of the Singapore instances.
data:image/s3,"s3://crabby-images/be4d0/be4d0ea774f6c0970a85994cbfb344f20598a80a" alt=""
The results are as expected, the accelerator will only choose the healthy endpoints. All good using any of the 2 accelerator IP addresses, the accelerator DNS name and Route53 DNS name.
data:image/s3,"s3://crabby-images/45452/454527771ff114e91c04fa3045b1236940edd8fc" alt=""
data:image/s3,"s3://crabby-images/33cb6/33cb68cc8575d639a01861d39c5fbe7bc9ae5bef" alt=""
data:image/s3,"s3://crabby-images/0c7dd/0c7ddb89458ba5875509347b91d42d9a5ab3bb63" alt=""
data:image/s3,"s3://crabby-images/1bfed/1bfed843ff5d5d519d31f397f09d57779e43f167" alt=""
AWS also provides a speed comparison tool so you can evaluate and see for yourself what are the speed improvements from where you are located. It is available on https://speedtest.globalaccelerator.aws/
data:image/s3,"s3://crabby-images/0cf95/0cf95adb17ed6c632bcd8790c363a47331760774" alt=""