2017-02-24 05:08:18 +01:00
# Ansible Role: Docker
2020-11-05 16:57:10 +01:00
[![CI ](https://github.com/geerlingguy/ansible-role-docker/workflows/CI/badge.svg?event=push )](https://github.com/geerlingguy/ansible-role-docker/actions?query=workflow%3ACI)
2017-02-24 05:08:18 +01:00
2017-05-03 17:43:11 +02:00
An Ansible Role that installs [Docker ](https://www.docker.com ) on Linux.
2017-02-24 05:08:18 +01:00
## Requirements
None.
## Role Variables
Available variables are listed below, along with default values (see `defaults/main.yml` ):
2017-05-10 05:29:25 +02:00
# Edition can be one of: 'ce' (Community Edition) or 'ee' (Enterprise Edition).
docker_edition: 'ce'
docker_package: "docker-{{ docker_edition }}"
2017-08-01 04:17:13 +02:00
docker_package_state: present
2017-02-24 05:08:18 +01:00
2018-09-04 18:29:18 +02:00
The `docker_edition` should be either `ce` (Community Edition) or `ee` (Enterprise Edition). You can also specify a specific version of Docker to install using the distribution-specific format: Red Hat/CentOS: `docker-{{ docker_edition }}-<VERSION>` ; Debian/Ubuntu: `docker-{{ docker_edition }}=<VERSION>` .
You can control whether the package is installed, uninstalled, or at the latest version by setting `docker_package_state` to `present` , `absent` , or `latest` , respectively. Note that the Docker daemon will be automatically restarted if the Docker package is updated. This is a side effect of flushing all handlers (running any of the handlers that have been notified by this and any other role up to this point in the play).
2018-05-02 04:18:30 +02:00
2018-05-18 23:58:50 +02:00
docker_service_state: started
2018-09-27 05:26:19 +02:00
docker_service_enabled: true
2018-05-18 23:58:50 +02:00
docker_restart_handler_state: restarted
Variables to control the state of the `docker` service, and whether it should start on boot. If you're installing Docker inside a Docker container without systemd or sysvinit, you should set these to `stopped` and set the enabled variable to `no` .
2018-09-27 05:26:19 +02:00
docker_install_compose: true
2020-06-10 00:08:35 +02:00
docker_compose_version: "1.26.0"
2017-05-03 18:06:24 +02:00
docker_compose_path: /usr/local/bin/docker-compose
2017-05-03 17:44:49 +02:00
Docker Compose installation options.
2021-08-27 22:51:15 +02:00
docker_repo_url: https://download.docker.com/linux
The main Docker repo URL, common between Debian and RHEL systems.
2017-05-10 05:29:25 +02:00
docker_apt_release_channel: stable
2018-05-02 21:43:02 +02:00
docker_apt_arch: amd64
2021-08-27 22:51:15 +02:00
docker_apt_repository: "deb [arch={{ docker_apt_arch }}] {{ docker_repo_url }}/{{ ansible_distribution | lower }} {{ ansible_distribution_release }} {{ docker_apt_release_channel }}"
2018-05-02 04:31:35 +02:00
docker_apt_ignore_key_error: True
2021-08-27 22:51:15 +02:00
docker_apt_gpg_key: "{{ docker_repo_url }}/{{ ansible_distribution | lower }}/gpg"
2017-05-03 17:44:49 +02:00
2020-12-27 07:14:37 +01:00
(Used only for Debian/Ubuntu.) You can switch the channel to `nightly` if you want to use the Nightly release.
2017-05-03 17:44:49 +02:00
2020-03-06 16:49:53 +01:00
You can change `docker_apt_gpg_key` to a different url if you are behind a firewall or provide a trustworthy mirror.
Usually in combination with changing `docker_apt_repository` as well.
2021-08-27 22:51:15 +02:00
docker_yum_repo_url: "{{ docker_repo_url }}/{{ (ansible_distribution == 'Fedora') | ternary('fedora','centos') }}/docker-{{ docker_edition }}.repo"docker_edition }}.repo
2020-12-27 07:14:37 +01:00
docker_yum_repo_enable_nightly: '0'
2019-12-11 16:27:09 +01:00
docker_yum_repo_enable_test: '0'
2021-08-27 22:51:15 +02:00
docker_yum_gpg_key: "{{ docker_repo_url }}/centos/gpg"
2017-05-03 17:44:49 +02:00
2020-12-27 07:14:37 +01:00
(Used only for RedHat/CentOS.) You can enable the Nightly or Test repo by setting the respective vars to `1` .
2017-02-24 05:08:18 +01:00
2020-03-06 16:49:53 +01:00
You can change `docker_yum_gpg_key` to a different url if you are behind a firewall or provide a trustworthy mirror.
Usually in combination with changing `docker_yum_repository` as well.
2017-09-03 11:21:17 +02:00
docker_users:
2017-10-18 11:01:02 +02:00
- user1
- user2
2018-05-07 00:47:34 +02:00
A list of system users to be added to the `docker` group (so they can use Docker on the server).
2017-09-03 11:21:17 +02:00
2018-10-08 20:53:22 +02:00
docker_daemon_options:
storage-driver: "devicemapper"
log-opts:
max-size: "100m"
Custom `dockerd` options can be configured through this dictionary representing the json file `/etc/docker/daemon.json` .
2017-05-31 06:03:14 +02:00
## Use with Ansible (and `docker` Python library)
2017-05-30 05:08:59 +02:00
2017-05-31 06:03:14 +02:00
Many users of this role wish to also use Ansible to then _build_ Docker images and manage Docker containers on the server where Docker is installed. In this case, you can easily add in the `docker` Python library using the `geerlingguy.pip` role:
2017-05-30 05:08:59 +02:00
2017-06-30 13:56:21 +02:00
```yaml
- hosts: all
vars:
pip_install_packages:
- name: docker
roles:
- geerlingguy.pip
- geerlingguy.docker
```
2017-05-30 05:08:59 +02:00
2017-02-24 05:08:18 +01:00
## Dependencies
None.
## Example Playbook
2017-06-30 13:56:21 +02:00
```yaml
- hosts: all
roles:
- geerlingguy.docker
```
2017-02-24 05:08:18 +01:00
## License
MIT / BSD
2021-10-12 11:52:20 +02:00
## Sponsors
* [We Manage ](https://we-manage.de ): Helping start-ups and grown-ups scaling their infrastructure in a sustainable way.
2021-10-12 16:52:24 +02:00
The above sponsor(s) are supporting Jeff Geerling on [GitHub Sponsors ](https://github.com/sponsors/geerlingguy ). You can sponsor Jeff's work too, to help him continue improving these Ansible open source projects!
2021-10-12 11:52:20 +02:00
2017-02-24 05:08:18 +01:00
## Author Information
This role was created in 2017 by [Jeff Geerling ](https://www.jeffgeerling.com/ ), author of [Ansible for DevOps ](https://www.ansiblefordevops.com/ ).