Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/jmoney/aws-privatelink-poc
This is a POC to demonstrate an issue with AWS PrivateLink. The issue is what CIDR do you lock down the NLB in an VPC Endpoint Service too to allow the consumer to access the private link.
https://github.com/jmoney/aws-privatelink-poc
aws github-site license-management mkdocs
Last synced: about 1 month ago
JSON representation
This is a POC to demonstrate an issue with AWS PrivateLink. The issue is what CIDR do you lock down the NLB in an VPC Endpoint Service too to allow the consumer to access the private link.
- Host: GitHub
- URL: https://github.com/jmoney/aws-privatelink-poc
- Owner: jmoney
- License: apache-2.0
- Created: 2024-03-08T04:17:38.000Z (11 months ago)
- Default Branch: main
- Last Pushed: 2024-03-11T02:28:24.000Z (11 months ago)
- Last Synced: 2024-12-18T19:53:21.652Z (about 1 month ago)
- Topics: aws, github-site, license-management, mkdocs
- Language: HCL
- Homepage: https://www.jmoney.dev/aws-privatelink-poc
- Size: 28.3 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# private-link-poc
This is a POC to demonstrate an issue with AWS PrivateLink. The issue is that when the security group on the network load balancer for this provider is locked down to the consumer ip addresses there is a gateway timeout through a LB. The security group of the NLB needs to be set further upstream to the source IP addresses, in this case the private IPs of the ALB, rather than the consumer IPs.
## Setup
```bash
terraform init
terraform apply -var input_provider_ingress="alb"
```This will create a public ALB pointed at a VPC endpoint mapped to an NLB via a VPC Endpoint Service. The NLB is pointed at an instance running a simple echo server. The security group on the NLB is locked down to the ALB private IPs.
```bash
terraform init
terraform apply -var input_provider_ingress="consumers"
```This will create a public ALB pointed at a VPC endpoint mapped to an NLB via a VPC Endpoint Service. The NLB is pointed at an instance running a simple echo server. The security group on the NLB is locked down to the consumer private IPs.
## Testing
To test this POC, you can run the following command:
```bash
curl -s -v "http://$(terraform output -json | jq -r .public_lb_dns)/http"
```To log into the instance you can use session manager:
```bash
aws ssm start-session --target $(terraform output -json | jq -r .echo_server_id)
```## Requirements
| Name | Version |
|------|---------|
| [aws](#requirement\_aws) | 5.40.0 |## Providers
| Name | Version |
|------|---------|
| [aws](#provider\_aws) | 5.40.0 |## Modules
| Name | Source | Version |
|------|--------|---------|
| [consumer](#module\_consumer) | ./modules/consumer | n/a |
| [consumer\_network](#module\_consumer\_network) | ./modules/network_segment | n/a |
| [echo\_server](#module\_echo\_server) | ./modules/echo_server | n/a |
| [provider](#module\_provider) | ./modules/provider | n/a |
| [provider\_network](#module\_provider\_network) | ./modules/network_segment | n/a |## Resources
| Name | Type |
|------|------|
| [aws_lb.public_lb](https://registry.terraform.io/providers/hashicorp/aws/5.40.0/docs/resources/lb) | resource |
| [aws_lb_listener.public_lb](https://registry.terraform.io/providers/hashicorp/aws/5.40.0/docs/resources/lb_listener) | resource |
| [aws_lb_target_group.public_lb](https://registry.terraform.io/providers/hashicorp/aws/5.40.0/docs/resources/lb_target_group) | resource |
| [aws_lb_target_group_attachment.consumers](https://registry.terraform.io/providers/hashicorp/aws/5.40.0/docs/resources/lb_target_group_attachment) | resource |
| [aws_security_group.public_lb](https://registry.terraform.io/providers/hashicorp/aws/5.40.0/docs/resources/security_group) | resource |
| [aws_security_group_rule.private_link_provider_ingress](https://registry.terraform.io/providers/hashicorp/aws/5.40.0/docs/resources/security_group_rule) | resource |
| [aws_network_interface.alb_eni](https://registry.terraform.io/providers/hashicorp/aws/5.40.0/docs/data-sources/network_interface) | data source |
| [aws_network_interface.consumer_network_interface](https://registry.terraform.io/providers/hashicorp/aws/5.40.0/docs/data-sources/network_interface) | data source |
| [aws_network_interfaces.alb_enis](https://registry.terraform.io/providers/hashicorp/aws/5.40.0/docs/data-sources/network_interfaces) | data source |## Inputs
| Name | Description | Type | Default | Required |
|------|-------------|------|---------|:--------:|
| [provider\_ingress](#input\_provider\_ingress) | Where to grab the IPs for the NLB provider security group. | `string` | `"alb"` | no |## Outputs
| Name | Description |
|------|-------------|
| [consumer\_ips](#output\_consumer\_ips) | IP addresses of the consumer network interfaces |
| [echo\_server\_id](#output\_echo\_server\_id) | value of the echo server's instance ID |
| [private\_link\_vpcs](#output\_private\_link\_vpcs) | VPC IDs of the provider and consumer networks |
| [provider\_service\_name](#output\_provider\_service\_name) | value of the provider service name |
| [public\_lb\_dns](#output\_public\_lb\_dns) | value of the public load balancer's DNS name |