Skip to content
Microservices Certification

Bringing Squid Proxy Into The 21st Century With AWS Fargate


When chatting about building and deploying purposes in the AWS ecosystem, 1 subject matter that will come up devoid of fall short is how to securely handle outbound net website traffic from non-public subnets. How can you run a managed setting that helps prevent data exfiltration or possible details leaks with a minimal volume of management overhead?

There are professional resources out there these types of as NextGen Firewall or Web Proxy that can filter/block outbound world wide web visitors but these equipment need a license as perfectly as ongoing servicing of the software program and the related AWS EC2 infrastructure.

AWS has released an superb posting on How to Include DNS Filtering to Your NAT Instance with Squid, that addresses the reasons for picking a Squid-based alternative to address this challenge.

Inspired by this alternative, I want to acquire the architecture and use present day AWS technologies like AWS Fargate and the Network Load Balancer to convey the alternative into the cloud-native realm.

Squid is chosen as open-supply application to whitelist and blacklist URL, and merged with Linux Alpine, fits completely in a container ecosystem.


The alternative is based on the subsequent ideas:

  • Supplies a protected web relationship to a huge AWS landscape (multi-account/ multi-region)
  • No Servers to Manage/Update/Up grade
  • Requirements to aid large bandwidth throughput
  • Remarkably offered remedy
  • Flexible expense primarily based on usage


Why did I use these AWS companies?

AWS Fargate is a compute motor for Amazon ECS that lets you to run containers with no owning to control servers or clusters. With AWS Fargate, you no for a longer time have to provision, configure, and scale clusters of virtual devices to operate containers. This eliminates the will need to select server varieties, make your mind up when to scale your clusters or optimize cluster packing. AWS Application Scaling enables you to configure automatic scaling for AWS Fargate in a subject of minutes.

AWS Community Load Balancer

operates at the connection level (Layer 4), routing connections to targets – Amazon EC2 circumstances, microservices certification, and containers – within just Amazon Digital Personal Cloud (Amazon VPC) based on IP protocol details. Great for load balancing of TCP targeted traffic, Community Load Balancer is capable of managing millions of requests for each second even though retaining extremely-reduced latencies.

AWS Cloudwatch Logs support enables you to acquire and retail outlet logs from your sources, apps, and products and services in around authentic-time. Working with the AWS ECS awslogs drivers will make it probable to publish the output log of Docker with no any added device.


Why use AWS Network Load Balancer?

AWS Community Load Balancer gives a incredibly versatile configuration and high-overall performance connection but it also introduces the capability to configure a “Provider Endpoint”. Utilizing Assistance Endpoint allows you to publish the Squid UTM Company across various accounts and across a number of locations, employing VPC PrivateLink Inter-Area, in a protected way controlling the allowed/blocked site visitors in a solitary location.


The answer

This alternative brings together the Infrastructure As A Code working with Terraform and the AWS ECS deploying a system to update the configuration of the Squid Farm, making use of a zero-downtime strategy.

This option enabled:

  • Online access applying a proxy with a managed whitelist/blacklist
  • Steer clear of employing AWS VPC peering with complex routing using AWS Company Endpoint
  • ECS provides the higher-availability expected sustaining the Fargate depend essential
  • No Patch/Updates will be demanded anymore to preserve the base OS


The ultimate resolution satisfies all ideas enabling the utilization of Squid in a really dynamic atmosphere:

  • AWS ECS will handle zero-downtime deployment on every single configuration alter and also guaranteeing the significant-availability and load scaling system of AWS Fargate.  
  • AWS Network Loadbalancer will warranty superior throughput and ultra-reduced latency cross area and cross-account connectivity.

These solutions, mixed with each other, will remodel and modernise the URL filtering with Squid into a cloud-helpful design.

All terraform code and Docker configurations are offered on GitHub you should support us boost this alternative.

If you have any implementation or troubleshooting thoughts, remember to open an concern in our repository.