Another documentation commit.

This commit is contained in:
Ash Wilson 2014-12-12 11:01:08 -05:00 committed by Matt Clay
parent 43ef3a2bd9
commit 6505ce3940

View file

@ -27,335 +27,300 @@ module: docker
version_added: "1.4" version_added: "1.4"
short_description: manage docker containers short_description: manage docker containers
description: description:
- Manage the life cycle of docker containers. - Manage the life cycle of docker containers.
options: options:
count: count:
description: description:
- Set number of containers to run - Number of matching containers that should be in the desired state.
required: False
default: 1 default: 1
aliases: []
image: image:
description: description:
- Set container image to use - Container image used to match and launch containers.
required: true required: true
default: null pull:
aliases: [] description:
- Control when container images are updated from the C(docker_url) registry.
- If "missing," images will be pulled only when missing from the host; if
- '"always," the registry will be checked for a newer version of the image'
- each time the task executes.
default: missing
choices: [ "missing", "always" ]
version_added: "1.9"
command: command:
description: description:
- Set command to run in a container on startup - Command used to match and launch containers.
required: false
default: null default: null
aliases: []
name: name:
description: description:
- Set name for container (used to find single container or to provide links) - Name used to match and uniquely name launched containers. Explicit names
required: false - are used to uniquely identify a single container or to link among
- containers. Mutually exclusive with a "count" other than "1".
default: null default: null
aliases: []
version_added: "1.5" version_added: "1.5"
ports: ports:
description: description:
- Set private to public port mapping specification using docker CLI-style syntax [([<host_interface>:[host_port]])|(<host_port>):]<container_port>[/udp] - List containing private to public port mapping specification. Use docker
required: false - 'CLI-style syntax: C(8000), C(9000:8000), or C(0.0.0.0:9000:8000) where'
- 8000 is a container port, 9000 is a host port, and 0.0.0.0 is a host
- interface.
default: null default: null
aliases: []
version_added: "1.5" version_added: "1.5"
expose: expose:
description: description:
- Set container ports to expose for port mappings or links. (If the port is already exposed using EXPOSE in a Dockerfile, you don't need to expose it again.) - List of additional container ports to expose for port mappings or links.
required: false - If the port is already exposed using EXPOSE in a Dockerfile, you don't
- need to expose it again.
default: null default: null
aliases: []
version_added: "1.5" version_added: "1.5"
publish_all_ports: publish_all_ports:
description: description:
- Publish all exposed ports to the host interfaces - Publish all exposed ports to the host interfaces.
required: false
default: false default: false
aliases: []
version_added: "1.5" version_added: "1.5"
volumes: volumes:
description: description:
- Set volume(s) to mount on the container - List of volumes to mount within the container using docker CLI-style
- 'syntax: C(/host:/container[:mode]) where "mode" may be "rw" or "ro".'
required: false required: false
default: null default: null
aliases: []
volumes_from: volumes_from:
description: description:
- Set shared volume(s) from another container - List of names of containers to mount volumes from.
required: false
default: null default: null
aliases: []
links: links:
description: description:
- Link container(s) to other container(s) (e.g. links=redis,postgresql:db) - List of other containers to link within this container with an optional
required: false - 'alias. Use docker CLI-style syntax: C(redis:myredis).'
default: null default: null
aliases: []
version_added: "1.5" version_added: "1.5"
memory_limit: memory_limit:
description: description:
- Set RAM allocated to container. It will be passed as a number of bytes. For example 1048576 = 1Gb - RAM allocated to the container as a number of bytes or as a human-readable
- string like "512MB". Leave as "0" to specify no limit.
required: false required: false
default: null default: null
aliases: [] aliases: []
default: 256MB default: 256MB
docker_url: docker_url:
description: description:
- URL of docker host to issue commands to - URL of the host running the docker daemon. This will default to the env
required: false - var DOCKER_HOST if unspecified.
default: unix://var/run/docker.sock default: ${DOCKER_HOST} or unix://var/run/docker.sock
aliases: [] docker_tls_cert:
description:
- Path to a PEM-encoded client certificate to secure the Docker connection.
default: ${DOCKER_CERT_PATH}/cert.pem
docker_tls_key:
description:
- Path to a PEM-encoded client key to secure the Docker connection.
default: ${DOCKER_CERT_PATH}/key.pem
docker_tls_cacert:
description:
- Path to a PEM-encoded certificate authority to secure the Docker connection.
default: ${DOCKER_CERT_PATH}/ca.pem
docker_api_version: docker_api_version:
description: description:
- Remote API version to use. This defaults to the current default as specified by docker-py. - Remote API version to use. This defaults to the current default as
required: false - specified by docker-py.
default: docker-py default remote API version default: docker-py default remote API version
aliases: []
version_added: "1.8" version_added: "1.8"
username: username:
description: description:
- Set remote API username - Remote API username.
required: false
default: null default: null
aliases: []
password: password:
description: description:
- Set remote API password - Remote API password.
required: false
default: null default: null
aliases: []
email: email:
description: description:
- Set remote API email - Remote API email.
required: false
default: null default: null
aliases: []
hostname: hostname:
description: description:
- Set container hostname - Container hostname.
required: false
default: null default: null
aliases: []
domainname: domainname:
description: description:
- Set container domain name - Container domain name.
required: false
default: null default: null
aliases: []
env: env:
description: description:
- Set environment variables (e.g. env="PASSWORD=sEcRe7,WORKERS=4") - Pass a dict of environment variables to the container.
required: false
default: null default: null
aliases: []
dns: dns:
description: description:
- Set custom DNS servers for the container - List of custom DNS servers for the container.
required: false required: false
default: null default: null
aliases: []
detach: detach:
description: description:
- Enable detached mode on start up, leaves container running in background - Enable detached mode to leave the container running in background.
required: false
default: true default: true
aliases: []
state: state:
description: description:
- Set the state of the container - Assert the container's desired state. "present" only asserts that the
- matching containers exist. "started" asserts that the matching containers
- both exist and are running, but takes no action if any configuration has
- changed. "reloaded" asserts that all matching containers are running and
- restarts any that have any images or configuration out of date. "restarted"
- unconditionally restarts (or starts) the matching containers. "stopped" and
- '"killed" stop and kill all matching containers. "absent" stops and then'
- removes any matching containers.
required: false required: false
default: present default: present
choices: [ "present", "running", "stopped", "absent", "killed", "restarted" ] choices:
aliases: [] - present
- started
- reloaded
- restarted
- killed
- absent
privileged: privileged:
description: description:
- Set whether the container should run in privileged mode - Whether the container should run in privileged mode or not.
required: false
default: false default: false
aliases: []
lxc_conf: lxc_conf:
description: description:
- LXC config parameters, e.g. lxc.aa_profile:unconfined - LXC configuration parameters, such as C(lxc.aa_profile:unconfined).
required: false
default:
aliases: []
name:
description:
- Set the name of the container (cannot use with count)
required: false
default: null default: null
aliases: []
version_added: "1.5"
stdin_open: stdin_open:
description: description:
- Keep stdin open - Keep stdin open after a container is launched.
required: false
default: false default: false
aliases: []
version_added: "1.6" version_added: "1.6"
tty: tty:
description: description:
- Allocate a pseudo-tty - Allocate a pseudo-tty within the container.
required: false
default: false default: false
aliases: []
version_added: "1.6" version_added: "1.6"
net: net:
description: description:
- Set Network mode for the container (bridge, none, container:<name|id>, host). Requires docker >= 0.11. - 'Network mode for the launched container: bridge, none, container:<name|id>'
required: false - or host. Requires docker >= 0.11.
default: false default: false
aliases: []
version_added: "1.8" version_added: "1.8"
registry: registry:
description: description:
- The remote registry URL to use for pulling images. - Remote registry URL to pull images from.
required: false default: DockerHub
default: ''
aliases: [] aliases: []
version_added: "1.8" version_added: "1.8"
restart_policy: restart_policy:
description: description:
- Set the container restart policy - Container restart policy.
required: false choices: ["no", "on-failure", "always"]
default: false default: null
aliases: []
version_added: "1.9" version_added: "1.9"
restart_policy_retry: restart_policy_retry:
description: description:
- Set the retry limit for container restart policy - Maximum number of times to restart a container. Leave as "0" for unlimited
required: false - retries.
default: false default: 0
aliases: []
version_added: "1.9" version_added: "1.9"
insecure_registry: insecure_registry:
description: description:
- Use insecure private registry by HTTP instead of HTTPS (needed for docker-py >= 0.5.0). - Use insecure private registry by HTTP instead of HTTPS. Needed for
required: false - docker-py >= 0.5.0.
default: false default: false
aliases: []
version_added: "1.9" version_added: "1.9"
author: Cove Schneider, Joshua Conner, Pavel Antonov author: Cove Schneider, Joshua Conner, Pavel Antonov, Ash Wilson
requirements: [ "docker-py >= 0.3.0", "docker >= 0.10.0" ] requirements: [ "docker-py >= 0.3.0", "docker >= 0.10.0" ]
''' '''
EXAMPLES = ''' EXAMPLES = '''
Start one docker container running tomcat in each host of the web group and bind tomcat's listening port to 8080 # Containers are matched either by name (if provided) or by an exact match of
on the host: # the image they were launched with and the command they're running. The module
# can accept either a name to target a container uniquely, or a count to operate
# on multiple containers at once when it makes sense to do so.
- hosts: web # Ensure that a data container with the name "mydata" exists. If no container
sudo: yes # by this name exists, it will be created, but not started.
tasks:
- name: run tomcat servers
docker: image=centos command="service tomcat6 start" ports=8080
The tomcat server's port is NAT'ed to a dynamic port on the host, but you can determine which port the server was - name: data container
mapped to using docker_containers: docker:
name: mydata
image: busybox
state: present
volumes:
- /data
- hosts: web # Ensure that a Redis server is running, using the volume from the data
sudo: yes # container. Expose the default Redis port.
tasks:
- name: run tomcat servers
docker: image=centos command="service tomcat6 start" ports=8080 count=5
- name: Display IP address and port mappings for containers
debug: msg={{inventory_hostname}}:{{item['HostConfig']['PortBindings']['8080/tcp'][0]['HostPort']}}
with_items: docker_containers
Just as in the previous example, but iterates over the list of docker containers with a sequence: - name: redis container
docker:
name: myredis
image: redis
command: redis-server --appendonly yes
state: started
expose:
- 6379
volumes_from:
- mydata
- hosts: web # Ensure that a container of your application server is running. This will:
sudo: yes # - pull the latest version of your application image from DockerHub.
vars: # - ensure that a container is running with the specified name and exact image.
start_containers_count: 5 # If any configuration options have changed, the existing container will be
tasks: # stopped and removed, and a new one will be launched in its place.
- name: run tomcat servers # - link this container to the existing redis container launched above with
docker: image=centos command="service tomcat6 start" ports=8080 count={{start_containers_count}} # an alias.
- name: Display IP address and port mappings for containers # - bind TCP port 9000 within the container to port 8080 on all interfaces
debug: msg="{{inventory_hostname}}:{{docker_containers[{{item}}]['HostConfig']['PortBindings']['8080/tcp'][0]['HostPort']}}" # on the host.
with_sequence: start=0 end={{start_containers_count - 1}} # - bind UDP port 9001 within the container to port 8081 on the host, only
# listening on localhost.
# - set the environment variable SECRET_KEY to "ssssh".
Stop, remove all of the running tomcat containers and list the exit code from the stopped containers: - name: application container
docker:
name: myapplication
image: someuser/appimage
state: reloaded
pull: always
links:
- "myredis:aliasedredis"
ports:
- "8080:9000"
- "127.0.0.1:8081:9001/udp"
env:
SECRET_KEY: ssssh
- hosts: web # Ensure that exactly five containers of another server are running with this
sudo: yes # exact image and command. If fewer than five are running, more will be launched;
tasks: # if more are running, the excess will be stopped.
- name: stop tomcat servers
docker: image=centos command="service tomcat6 start" state=absent
- name: Display return codes from stopped containers
debug: msg="Returned {{inventory_hostname}}:{{item}}"
with_items: docker_containers
Create a named container: - name: load-balanced containers
docker:
state: reloaded
count: 5
image: someuser/anotherappimage
command: sleep 1d
- hosts: web # Unconditionally restart a service container. This may be useful within a
sudo: yes # handler, for example.
tasks:
- name: run tomcat server
docker: image=centos name=tomcat command="service tomcat6 start" ports=8080
Create multiple named containers: - name: application service
docker:
name: myservice
image: someuser/serviceimage
state: restarted
- hosts: web # Stop all containers running the specified image.
sudo: yes
tasks:
- name: run tomcat servers
docker: image=centos name={{item}} command="service tomcat6 start" ports=8080
with_items:
- crookshank
- snowbell
- heathcliff
- felix
- sylvester
Create containers named in a sequence: - name: obsolete container
docker:
image: someuser/oldandbusted
state: stopped
- hosts: web # Stop and remove a container with the specified name.
sudo: yes
tasks:
- name: run tomcat servers
docker: image=centos name={{item}} command="service tomcat6 start" ports=8080
with_sequence: start=1 end=5 format=tomcat_%d.example.com
Create two linked containers:
- hosts: web
sudo: yes
tasks:
- name: ensure redis container is running
docker: image=crosbymichael/redis name=redis
- name: ensure redis_ambassador container is running
docker: image=svendowideit/ambassador ports=6379:6379 links=redis:redis name=redis_ambassador_ansible
Create containers with options specified as key-value pairs and lists:
- hosts: web
sudo: yes
tasks:
- docker:
image: namespace/image_name
links:
- postgresql:db
- redis:redis
Create containers with options specified as strings and lists as comma-separated strings:
- hosts: web
sudo: yes
tasks:
docker: image=namespace/image_name links=postgresql:db,redis:redis
Create a container with no networking:
- hosts: web
sudo: yes
tasks:
docker: image=namespace/image_name net=none
- name: obsolete container
docker:
name: ohno
image: someuser/oldandbusted
state: absent
''' '''
HAS_DOCKER_PY = True HAS_DOCKER_PY = True
@ -494,7 +459,7 @@ class DockerManager(object):
if len(parts) == 2: if len(parts) == 2:
self.volumes[parts[1]] = {} self.volumes[parts[1]] = {}
self.binds[parts[0]] = parts[1] self.binds[parts[0]] = parts[1]
# with bind mode # with bind mode
elif len(parts) == 3: elif len(parts) == 3:
if parts[2] not in ['ro', 'rw']: if parts[2] not in ['ro', 'rw']:
self.module.fail_json(msg='bind mode needs to either be "ro" or "rw"') self.module.fail_json(msg='bind mode needs to either be "ro" or "rw"')