| |
| ============== |
| Docker Formula |
| ============== |
| |
| Docker is a platform for developers and sysadmins to develop, ship, and run applications. Docker lets you quickly assemble applications from components and eliminates the friction that can come when shipping code. Docker lets you get your code tested and deployed into production as fast as possible. |
| |
| Sample Pillars |
| ============== |
| |
| Docker Host |
| ----------- |
| |
| .. code-block:: yaml |
| |
| docker: |
| host: |
| enabled: true |
| options: |
| bip: 172.31.255.1/16 |
| insecure_registries: |
| - 127.0.0.1 |
| - 10.0.0.1 |
| log-driver: json-file |
| log-opts: |
| max-size: 50m |
| |
| |
| Configure proxy for docker host |
| |
| .. code-block:: yaml |
| |
| docker: |
| host: |
| proxy: |
| enabled: true |
| http: http://user:pass@proxy:3128 |
| https: http://user:pass@proxy:3128 |
| no_proxy: |
| - localhost |
| - 127.0.0.1 |
| - docker-registry |
| |
| |
| Docker Swarm |
| ------------ |
| |
| Role can be master, manager or worker. Where master is the first manager that |
| will initialize the swarm. |
| |
| Metadata for manager (first node): |
| |
| .. code-block:: yaml |
| |
| docker: |
| host: |
| enabled: true |
| swarm: |
| role: manager |
| advertise_addr: 192.168.1.5 |
| bind: |
| address: 192.168.1.5 |
| port: 2377 |
| |
| Metadata for worker. |
| |
| .. code-block:: yaml |
| |
| docker: |
| host: |
| enabled: true |
| swarm: |
| role: worker |
| master: |
| host: 192.168.1.5 |
| port: 2377 |
| |
| Token to join to master node is obtained from grains using salt.mine. In case |
| of any ``join_token undefined`` issues, ensure you have ``docker_swarm_`` |
| grains available. |
| |
| Docker Client |
| ------------- |
| |
| Container |
| ~~~~~~~~~ |
| |
| .. code-block:: yaml |
| |
| docker: |
| client: |
| container: |
| jenkins: |
| # Don't start automatically |
| start: false |
| restart: unless-stopped |
| image: jenkins:2.7.1 |
| ports: |
| - 8081:8080 |
| - 50000:50000 |
| environment: |
| JAVA_OPTS: "-Dhudson.footerURL=https://www.example.com" |
| volumes: |
| - /srv/volumes/jenkins:/var/jenkins_home |
| |
| Using Docker Compose |
| ~~~~~~~~~~~~~~~~~~~~ |
| |
| There are two states that provides this functionality: |
| |
| - docker.client.stack |
| - docker.client.compose |
| |
| Stack is new and works with Docker Swarm Mode. Compose is legacy and works |
| only if node isn't member of Swarm. |
| Metadata for both states are similar and differs only in implementation. |
| |
| Stack |
| ^^^^^ |
| |
| .. code-block:: yaml |
| |
| docker: |
| client: |
| stack: |
| django_web: |
| enabled: true |
| update: true |
| environment: |
| SOMEVAR: somevalue |
| version: "3.1" |
| service: |
| db: |
| image: postgres |
| web: |
| image: djangoapp |
| volumes: |
| - /srv/volumes/django:/srv/django |
| ports: |
| - 8000:8000 |
| depends_on: |
| - db |
| |
| Compose |
| ^^^^^^^ |
| |
| There are three options how to install docker-compose: |
| |
| - distribution package (default) |
| - using Pip |
| - using Docker container |
| |
| Install docker-compose using Docker (default is distribution package) |
| |
| .. code-block:: yaml |
| |
| docker: |
| client: |
| compose: |
| source: |
| engine: docker |
| image: docker/compose:1.8.0 |
| django_web: |
| # Run up action, any positional argument to docker-compose CLI |
| # If not defined, only docker-compose.yml is generated |
| status: up |
| # Run image pull every time state is run triggering container |
| # restart in case it's changed |
| pull: true |
| environment: |
| SOMEVAR: somevalue |
| service: |
| db: |
| image: postgres |
| web: |
| image: djangoapp |
| volumes: |
| - /srv/volumes/django:/srv/django |
| ports: |
| - 8000:8000 |
| depends_on: |
| - db |
| |
| Service |
| ------- |
| |
| To deploy service in Swarm mode, you can use ``docker.client.service``: |
| |
| .. code-block:: yaml |
| |
| parameters: |
| docker: |
| client: |
| service: |
| postgresql: |
| environment: |
| POSTGRES_USER: user |
| POSTGRES_PASSWORD: password |
| POSTGRES_DB: mydb |
| restart: |
| condition: on-failure |
| image: "postgres:9.5" |
| ports: |
| - 5432:5432 |
| volume: |
| data: |
| type: bind |
| source: /srv/volumes/postgresql/maas |
| destination: /var/lib/postgresql/data |
| |
| |
| Docker Registry |
| --------------- |
| |
| .. code-block:: yaml |
| |
| docker: |
| registry: |
| log: |
| level: debug |
| formatter: json |
| cache: |
| engine: redis |
| host: localhost |
| storage: |
| engine: filesystem |
| root: /srv/docker/registry |
| bind: |
| host: 0.0.0.0 |
| port: 5000 |
| hook: |
| mail: |
| levels: |
| - panic |
| # Options are rendered as yaml as is so use hook-specific options here |
| options: |
| smtp: |
| addr: smtp.sendhost.com:25 |
| username: sendername |
| password: password |
| insecure: true |
| from: name@sendhost.com |
| to: |
| - name@receivehost.com |
| |
| Docker login to private registry |
| |
| .. code-block:: yaml |
| |
| docker: |
| host: |
| enabled: true |
| registry: |
| first: |
| address: private.docker.com |
| user: username |
| password: password |
| second: |
| address: private2.docker.com |
| user: username2 |
| password: password2 |
| |
| |
| More Information |
| ================ |
| |
| * https://docs.docker.com/installation/ubuntulinux/ |
| * https://github.com/saltstack-formulas/docker-formula |
| |
| |
| Documentation and Bugs |
| ====================== |
| |
| To learn how to install and update salt-formulas, consult the documentation |
| available online at: |
| |
| http://salt-formulas.readthedocs.io/ |
| |
| In the unfortunate event that bugs are discovered, they should be reported to |
| the appropriate issue tracker. Use Github issue tracker for specific salt |
| formula: |
| |
| https://github.com/salt-formulas/salt-formula-docker/issues |
| |
| For feature requests, bug reports or blueprints affecting entire ecosystem, |
| use Launchpad salt-formulas project: |
| |
| https://launchpad.net/salt-formulas |
| |
| You can also join salt-formulas-users team and subscribe to mailing list: |
| |
| https://launchpad.net/~salt-formulas-users |
| |
| Developers wishing to work on the salt-formulas projects should always base |
| their work on master branch and submit pull request against specific formula. |
| |
| https://github.com/salt-formulas/salt-formula-docker |
| |
| Any questions or feedback is always welcome so feel free to join our IRC |
| channel: |
| |
| #salt-formulas @ irc.freenode.net |