Docker logo belongs to Docker Inc
- Health checks
- TLS connections
- Search/List containers for projects/hosts
A way to automate and orchestrate docker deployments
go install github.com/joshrendek/docker-conductor
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
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
.
docker-conductor -p test_project
docker-conductor -n foobar
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
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.