Skip to content

Tor networking plugin for Docker containers. Route all container tcp traffic through Tor.

License

Notifications You must be signed in to change notification settings

flungo-docker/libnetwork-container

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

86 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

libnetwork-container

Docker network driver for routing through another container.

NOTE: This driver is currently in development and the functionality documented in this README.md is the goal of what this driver will provide and may not reflect the current functionality of the driver.

How it works?

This driver allows networks to be created where a container is used as the default gateway for that network. When a network is created a name for the router should be provided otherwise it will default to the network name suffixed with -router. When a container with that name is added to the network it will be configurd as the gateway for the network. If any other container is added it will be added as it normally would when using a bridge network.

Usage

Starting the Driver

NOTE: Make sure you are using Docker 1.9 or later

To start the driver and make it available for use with docker network, commands the following command should be used:

$ docker run -d \
    --net host \
    --cap-add NET_ADMIN \
    --name libnetwork-container \
    -v /run/docker/plugins:/run/docker/plugins \
    -v /var/run/docker.sock:/var/run/docker.sock \
    flungo/libnetwork-container

Create a router

To be able to create a network which routes through a container, a container that does the routing needs to be set up. A list of available routers that are designed for use with this driver is available in this README.md.

This example creates a router for the Tor network with the name tor-router:

$ docker run -d \
    --name tor-router \
    --cap-add NET_ADMIN \
    flungo/tor-router

# follow the logs to make sure it is bootstrapped successfully
$ docker logs -f tor-router

Create a network

The network can be created with the docker network create command using the container driver and specifying the me.flungo.network.container.router as the name of the container which should be used as the routing container.

The following example creates a network named tor which will use a router named tor-router:

$ docker network create -d container \
    -o me.flungo.network.container.router=tor-router \
    tor

Once the network is created, you will need to complete this step by adding your router to the network. For the Tor example, this is:

$ docker network connect tor tor-router

Run a container

The last step is to connect your containers to the new network. Again this should follow the standard practice you would use to run your container using a specific network.

With the Tor example, the following can be used to test that the request is router through the Tor network.

$ docker run --rm -it --net tor jess/httpie \
    -v --json https://check.torproject.org/api/ip

Routers

Below is a list of router images which are designed for use with this driver:

Development

Running the tests

Unit tests:

$ make test

Integration tests:

$ make dtest

Acknowledgements

Thanks to Jess Frazelle for the onion driver which this driver is based on and in turn the libnetwork team for writing the networking go plugin and of course the networking itself.

About

Tor networking plugin for Docker containers. Route all container tcp traffic through Tor.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Go 81.1%
  • Shell 12.4%
  • Makefile 6.5%