Skip to content

binocarlos/powerstrip-weave

Repository files navigation

powerstrip-weave

A Powerstrip adapter that runs weave inside a container and ensures that containers are connected to the weave network before running their entrypoints.

run the adapter

$ docker run -d --name powerstrip-weave \
    --expose 80 \
    -v /var/run/docker.sock:/var/run/docker.sock \
    binocarlos/powerstrip-weave launch

The launch command does the following:

  • runs the weave container (by running weave launch)
  • runs a container called weavewait so its volume can be used to access the wait-for-weave binary
  • launches the HTTP adapter server

To ensure matching versions of the docker client / server - we mount the docker socket and docker binary from the host.

connect multiple hosts

If you are running multiple servers that you want to connect using weave - you pass the arguments you would normally pass to weave launch:

$ docker run -d --name powerstrip-weave \
    --expose 80 \
    -v /var/run/docker.sock:/var/run/docker.sock \
    binocarlos/powerstrip-weave launch 1.2.3.4 -password wEaVe

run powerstrip

First create a powerstrip configuration:

$ mkdir -p ~/powerstrip-demo
$ cat > ~/powerstrip-demo/adapters.yml <<EOF
endpoints:
  "POST /*/containers/create":
    pre: [weave]
  "POST /*/containers/*/start":
    post: [weave]
  "POST /*/containers/*/restart":
    post: [weave]
adapters:
  weave: http://weave/v1/extension
EOF

And then run the powerstrip container and link it to the powerstrip-weave container:

$ docker run -d --name powerstrip \
  -v /var/run/docker.sock:/var/run/docker.sock \
  -v ~/powerstrip-demo/adapters.yml:/etc/powerstrip/adapters.yml \
  --link powerstrip-weave:weave \
  -p 2375:2375 \
  clusterhq/powerstrip

run containers

Now you can use the normal docker client to run containers that will connect to the weave network and wait for the network to be connected before running the job.

First you must export the DOCKER_HOST variable to point at the powerstrip server:

$ export DOCKER_HOST=tcp://127.0.0.1:2375

You tell powerstrip-weave what IP address you want to give a container by using the WEAVE_CIDR environment variable of a container - here we run a database server:

$ docker run -d --name mysql \
    -e WEAVE_CIDR=10.255.0.1/8 \
    -e MYSQL_ROOT_PASSWORD=mysecretpassword \
    mysql

weave commands

You can get the status of the weave network by running the status command:

$ docker run --rm -it \
    -v /var/run/docker.sock:/var/run/docker.sock \
    binocarlos/powerstrip-weave status

You can run normal weave network commands like expose and attach:

$ docker run --rm \
    -v /var/run/docker.sock:/var/run/docker.sock \
    binocarlos/powerstrip-weave expose 10.255.0.1/8

You could even run weave run using this method although it would not wait for the weave network to be connected if you use this method.

shutdown

To shutdown cleanly (i.e. close the adapter / weave and remove the wait-for-weave volume container):

$ docker run --rm \
    -v /var/run/docker.sock:/var/run/docker.sock \
    binocarlos/powerstrip-weave stop

If you named the adapter container something different - pass the name as the first argument to the stop command:

$ docker run --rm \
    -v /var/run/docker.sock:/var/run/docker.sock \
    binocarlos/powerstrip-weave stop powerstrip-weave

examples

There is a walk-through example of running powerstrip-weave.

There is also an example of a fig stack that links 2 containers using weave IP addresses.

docker version

You must be running the docker server API >= 1.15 - you can check which you have by doing this:

$ docker version
Client version: 1.5.0
Client API version: 1.17
Go version (client): go1.4.1
Git commit (client): a8a31ef
OS/Arch (client): linux/amd64
Server version: 1.5.0
Server API version: 1.17
Go version (server): go1.4.1
Git commit (server): a8a31ef

The above shows a docker server version of 1.17 (so we are good)

notes

licence

Copyright 2015 Kai Davenport & Contributors

Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at

http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.

About

A Powerstrip plugin that runs weave inside a container and ensures that containers are connected to the weave network before running their entrypoints.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published