[−][src]Crate tcpwarp
A userspace tunnel between two hosts mapping ports on client machine to addresses reachable from server machine
tcp-warp server
tcp-warp client -c 8080:towel.blinkenlights.nl:23
nc 127.0.0.1 8080
Features
- A userspace tunnel to connect ports on client network with connections available on server side.
- Uses only single port.
- Client push of addresses to connect from server.
Installation
With cargo:
cargo install tcp-warp-cli
Usage
To create a tunnel we need to start a server listening on some port and then connect to it with a client.
Docker usage for server part
docker run --rm -d -p 18000:18000 tcpwarp/tcpwarp
or with custom listen port (ex: 18234):
docker run --rm -d -p 18234:18234 tcpwarp/tcpwarp tcp-warp server --listen=0.0.0.0:18234
Simple local running port remapper
-
Start server:
tcp-warp server
-
Start client:
tcp-warp client -c 8080:towel.blinkenlights.nl:23
-
Enjoy the show:
nc 127.0.0.1 8080
-
This example uses default listen and connect interfaces. In a real life scenario you need at least provide -t / --tunnel parameter to client:
tcp-warp client -t host:port ...
Both client and server have address on which they listen for incoming connections and client additionally have parameter to specify connection address.
Next we look at more specific example.
Use case: running Docker on machine without Docker daemon installed with Docker daemon behind SSH
Background:
- client: client machine runs on Windows, has Windows version of
tcp-warp
and Docker CLI installed. Client cannot run Docker daemon. - public: master node accessible with SSH from which Docker daemon node can be accessed.
- docker: docker daemon node accessible with SSH.
Target:
Run Docker over tcp transport, allowing client
to build and run containers. Environment should be available for each developer independent of other.
Solution:
Run on docker
machine Docker-in-Docker container (dind
) using tcp host protocol. Use DOCKER_HOST
environment variable on client
to connect to dind
. dind
is bindet to host port on docker
host and forwarded via public
with SSH port-forwarding.
The sequence of commands can be following:
Initial sequence (installation)
-
Go to
docker
node and start required containers:user@client $ ssh user1@public user1@public $ ssh user2@docker user2@docker $ docker run --rm --privileged -p 2375:2375 -p 18000:18000 -d --name some-docker docker:dind dockerd --host=tcp://0.0.0.0:2375 user2@docker $ DOCKER_HOST=tcp://127.0.0.1:2375 docker run --rm -p 18000:18000 -d --name some-docker-tcp-warp tcpwarp/tcpwarp
-
Disconnect from
docker
andpublic
nodes.
Normal sequence (usage)
-
Connect to
public
node withssh
and forward port fortcp-warp
:ssh -L 18000:docker:18000 user1@public
-
Connect to Docker daemon with
tcp-warp client
onclient
machine:tcp-warp client -c 10001:172.18.0.1:2375
172.18.0.1
here is the address of host node indind
. -
Export DOCKER_HOST environment variable on
client
machine:export DOCKER_HOST=tcp://127.0.0.1:10001
-
Run docker commands from
client
:docker ps docker run hello-world docker run -it alpine ash
Additional services
We can start additional services and relaunch tcp-warp client
with additional -c
for these services.
Simple example with whoami
service:
-
Create network to use for hostname resolution. Start
whoami
service with all above steps done. Connect tcp-warp container to new network:docker network create our-network docker run --rm -d --net our-network --name whoami containous/whoami docker network connect our-network some-docker-tcp-warp
-
Stop
tcp-warp client
. Start it with additional port mapping forwhoami
service:tcp-warp client -c 10001:172.18.0.1:2375 -c 8080:whoami:80
-
Test
whoami
service:$ curl http://localhost:8080/ Hostname: 9fe704cf0e87 IP: 127.0.0.1 IP: 172.18.0.3 IP: 172.19.0.3 RemoteAddr: 172.19.0.2:44612 GET / HTTP/1.1 Host: localhost:8080 User-Agent: curl/7.64.1
Structs
TcpWarpClient | |
TcpWarpConnection | |
TcpWarpPortConnection | |
TcpWarpProto | |
TcpWarpProtoClient | |
TcpWarpProtoHost | |
TcpWarpServer |
Enums
TcpWarpMessage | Command types. |