docker-conductor

command module
v0.0.0-...-a2b334f Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Sep 10, 2015 License: MIT Imports: 6 Imported by: 0

README

Docker logo belongs to Docker Inc

TODO

  • Health checks
  • TLS connections
  • Search/List containers for projects/hosts

docker-conductor

A way to automate and orchestrate docker deployments

Installation

go install github.com/joshrendek/docker-conductor

Usage

Run docker-conductor inside a directory with a conductor.yml in it.

Flags:

-f, --force=false: Force a redeploy of everything in the conductor.yml file
-n, --name="": Only run the instruction with this name
-p, --project="": Only run the instruction that are apart of this project

Healthchecks

You can either run a healthcheck as a command and conductor will replace any instances of $HOST with the host or ip.

Or you can run a healthcheck that is a script, for example: ./some_script.sh - the host will be available as a $HOST environment variable.

If scripts do not exit 0, the health check will fail, the reason and output of the script will print to STDOUT.

Only deploy test_project

docker-conductor -p test_project

Only deploy the instruction named foobar

docker-conductor -n foobar

Example conductor.yml

If you want to use a library image, just specify library infront (check example below)


- name: test redis
  healthcheck: curl $HOST
  hosts:
    - tcp://docker1.example.com:2375
  container:
    name: test-redis
    image: library/redis

- name: Descriptive Service Name
  healthcheck: ./some_script.sh
  project: test_project
  hosts:
    - tcp://docker1.example.com:2375
  container:
    name: running-container-name
    image: private.registry.example.com/yourname/your_image
    environment:
      - FOOBAR=baz
    ports:
      80/tcp: 8080
    volumes:
      - /tmp:/tmp
    dns:
      - 8.8.8.8

- name: Descriptive Service Name 2
  hosts:
    - tcp://docker1.example.com:2375
  container:
    name: foobar-baz
    image: private.registry.example.com/yourname/foobar_baz_image

License

The MIT License (MIT)

Copyright (c) 2015 Josh Rendek

Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all
copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
SOFTWARE.

Documentation

The Go Gopher

There is no documentation for this package.

Directories

Path Synopsis
Godeps
_workspace/src/github.com/fsouza/go-dockerclient
Package docker provides a client for the Docker remote API.
Package docker provides a client for the Docker remote API.
_workspace/src/github.com/fsouza/go-dockerclient/testing
Package testing provides a fake implementation of the Docker API, useful for testing purpose.
Package testing provides a fake implementation of the Docker API, useful for testing purpose.
_workspace/src/github.com/ogier/pflag
pflag is a drop-in replacement for Go's flag package, implementing POSIX/GNU-style --flags.
pflag is a drop-in replacement for Go's flag package, implementing POSIX/GNU-style --flags.
_workspace/src/gopkg.in/inconshreveable/log15.v2
Package log15 provides an opinionated, simple toolkit for best-practice logging that is both human and machine readable.
Package log15 provides an opinionated, simple toolkit for best-practice logging that is both human and machine readable.
_workspace/src/gopkg.in/inconshreveable/log15.v2/stack
Package stack implements utilities to capture, manipulate, and format call stacks.
Package stack implements utilities to capture, manipulate, and format call stacks.
_workspace/src/gopkg.in/yaml.v2
Package yaml implements YAML support for the Go language.
Package yaml implements YAML support for the Go language.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL