Skip to main content

Tunnel ports via AWS ECS Tasks

Project description

ECS Tunnel

Port forwarding for AWS ECS tasks. Hopefully filling a gap until AWS provide similar support natively.

Features:

  • Forward local port to local port on task
  • Forward local port to a remote host/port accessible from task (Requires netcat. See Prerequisites)
  • HTTP Proxy (Requires ncat. See Prerequisites)

Prerequisites

Remote address:port Forwarding

To forward a port to a remote address accessible from the running task, it's necessary to install a version of netcat that supports -e.

Alpine

On Alpine with Busybox shell (default), netcat is already available.

Debian

Netcat Version Debian Package
Original Netcat netcat-traditional
NMAP Ncat ncat

HTTP Proxy

  • NMAP Ncat
Debian Package Alpine Package
ncat nmap-ncat

Installation

pip3 install ecs-tunnel

Usage

Usage: ecs-tunnel [OPTIONS]

Options:
  -c, --cluster CLUSTER_NAME      [required]
  -t, --task TASK_ID              [required]
  -n, --container CONTAINER_NAME  Container name. Required if task is running
                                  more than one container
  -L, --local LOCAL_PORT[:REMOTE_ADDR]:REMOTE_PORT
                                  Forward a local port to a remote
                                  address/port. Requires Busybox nc, netcat-
                                  traditional or NMAP Ncat installed (Netcat
                                  with support for "-e") on a given ECS task
  -H, --http-proxy PORT           Setup an HTTP(S) Proxy on given port.
                                  Requires NMAP Ncat installed on given ECS
                                  task
  --region AWS_REGION
  --profile AWS_PROFILE_NAME
  --aws-exec BIN                  aws command line executable. (default:
                                  "aws")
  --verbose
  --version                       Show the version and exit.
  --help                          Show this message and exit.

Examples

Tunnel local port 8000 to port 8080 on the remote task:

ecs-tunnel -L 8000:8080 -c my-cluster -t 7e2c99a9c63eb1fc3949d9e966d91f3b

Tunnel local port 5432 to port 5432 on a remote host:

ecs-tunnel -L 5432:my-db-cluster:5432 -c my-cluster -t 7e2c99a9c63eb1fc3949d9e966d91f3b

Setup HTTP proxy on port 8888:

ecs-tunnel -D 8888 -c my-cluster -t 7e2c99a9c63eb1fc3949d9e966d91f3b

But How?

Port forwarding to a port on an EC2 node is currently supported and documented using AWS Systems Manager, AWS Session Manager Plugin and the aws session command. By observing how aws ecs execute-command also used the AWS Session Manager, and taking insperation from SSH port forwarding, it was possible to write a quick wrapper that used the EC2 port forwarding profile with ECS tasks.

Unfortunately, the AWS Systems Manager doesn't seem to expose a way of forwading a local port to a remote port via the connected task. Instead, we use compatible versions of netcat to provide similar functionality.

Todo

  • Check for remote netcat support
  • Implement native Python session-manager using websockets

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

ecs-tunnel-0.1.2.tar.gz (7.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

ecs_tunnel-0.1.2-py3-none-any.whl (8.1 kB view details)

Uploaded Python 3

File details

Details for the file ecs-tunnel-0.1.2.tar.gz.

File metadata

  • Download URL: ecs-tunnel-0.1.2.tar.gz
  • Upload date:
  • Size: 7.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.7.1 importlib_metadata/4.10.0 pkginfo/1.8.2 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.9.7

File hashes

Hashes for ecs-tunnel-0.1.2.tar.gz
Algorithm Hash digest
SHA256 7eef7e8aa7d557d1971f9b63cd25c84f3153ceadf18a04763d609af05845c259
MD5 10ed511217df146d5ebf20ca2cba9075
BLAKE2b-256 b2a67f8b9777fec194df0ba239180495fe366fda8f299c5b57eb23b6c8e0d5b6

See more details on using hashes here.

File details

Details for the file ecs_tunnel-0.1.2-py3-none-any.whl.

File metadata

  • Download URL: ecs_tunnel-0.1.2-py3-none-any.whl
  • Upload date:
  • Size: 8.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.7.1 importlib_metadata/4.10.0 pkginfo/1.8.2 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.9.7

File hashes

Hashes for ecs_tunnel-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 eb1bc2ab96124806c3d44d7980892d52e93aa8cdea0b4407be4e799faacedd47
MD5 bcecc24baed9df0f5ebb591d2ba1c468
BLAKE2b-256 a189f7ddc3cf7988b1e3ab32f47b26ed2f49fbaa84c0253435ec5bb75801419d

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page