Adoptable Cookbooks List

Looking for a cookbook to adopt? You can now see a list of cookbooks available for adoption!
List of Adoptable Cookbooks

Supermarket Belongs to the Community

Supermarket belongs to the community. While Chef has the responsibility to keep it running and be stewards of its functionality, what it does and how it works is driven by the community. The chef/supermarket repository will continue to be where development of the Supermarket application takes place. Come be part of shaping the direction of Supermarket by opening issues and pull requests or by joining us on the Chef Mailing List.

Select Badges

Select Supported Platforms

Select Status

RSS

docker-grid (41) Versions 0.3.6

Installs/Configures Docker Engine.

Policyfile
Berkshelf
Knife
cookbook 'docker-grid', '= 0.3.6', :supermarket
cookbook 'docker-grid', '= 0.3.6'
knife supermarket install docker-grid
knife supermarket download docker-grid
README
Dependencies
Changelog
Quality 67%

docker-grid Cookbook

This cookbook sets up Docker engine.

Contents

Requirements

platforms

  • CentOS, Red Hat Enterprise Linux >= 7.2 (in baremetal or LXD (Ubuntu >= 14.04))
  • Ubuntu >= 14.04 (in baremetal or LXD (Ubuntu >= 14.04))

packages

  • none.

Attributes

Key Type Description, example Default
['docker-grid']['install_flavor'] String 'dockerproject' or 'os-repository' 'dockerproject'
['docker-grid']['apt_repo']['url'] String 'https://apt.dockerproject.org/repo'
['docker-grid']['apt_repo']['keyserver'] String 'hkp://p80.pool.sks-keyservers.net:80'
['docker-grid']['apt_repo']['recv-keys'] String '58118E89F3A912897C070ADBF76221572C52609D'
['docker-grid']['apt_repo']['override_apt_line'] String If you set this attribute, apt-line settings with the ['docker-grid']['apt_repo']['url'] attribute is overrridden. e.g. 'deb https://apt.dockerproject.org/repo ubuntu-xenial main' ''
['docker-grid']['yum_repo']['baseurl'] String 'https://yum.dockerproject.org/repo/main/centos/$releasever/'
['docker-grid']['yum_repo']['gpgcheck'] String '0': disabled, '1': enabled. '1'
['docker-grid']['yum_repo']['gpgkey'] String 'https://yum.dockerproject.org/gpg'
['docker-grid']['compose']['skip_setup'] Boolean false
['docker-grid']['compose']['auto_upgrade'] Boolean upgrade/reinstall the docker-compose automatically. false
['docker-grid']['compose']['release_base_url'] String 'https://github.com/docker/compose/releases/download/1.9.0'
['docker-grid']['compose']['release_url'] String "#{node['docker-grid']['compose']['release_base_url']}/docker-compose-#{node['kernel']['name']}-#{node['kernel']['machine']}"
['docker-grid']['compose']['home_dir'] String '/opt/docker-compose'
['docker-grid']['compose']['app_dir'] String "#{node['docker-grid']['compose']['home_dir']}/app
['docker-grid']['engine']['skip_setup'] Boolean false
['docker-grid']['engine']['version_on_centos'] String Docker version for CentOS. '1.11.2-1'
['docker-grid']['engine']['version_on_ubuntu'] String Docker version for Ubuntu. '1.11.2-0'
['docker-grid']['engine']['version'] String Docker 1.9.x - 1.11.x is recommended for stability reasons. Note: this default value is overwritten by the version_on_{centos or ubuntu}. See default.rb
['docker-grid']['engine']['storage-driver_on_centos'] String Docker storage driver (overlay, devicemapper, ...) for CentOS. 'overlay'
['docker-grid']['engine']['storage-driver_on_ubuntu'] String Docker storage driver (aufs, overlay, ...) for Ubuntu. 'aufs'
['docker-grid']['engine']['storage-driver'] String See default.rb
['docker-grid']['engine']['userns-remap'] String e.g. 'default' (dockremap user/group) or your specified user/group name. Note: it is available in Docker 1.10/later and (Ubuntu or RHEL family 7.2/later). nil (inactive)
['docker-grid']['engine']['daemon_extra_options'] String ref. docker daemon --help. '-H fd://'
['docker-grid']['engine']['users_allow'] Array Non-root users allowed to manage Docker daemon. []
['docker-grid']['registry']['with_ssl_cert_cookbook'] Boolean If this attribute is true, node['docker-grid']['registry']['docker-compose']['config'] are are overridden by the following common_name attributes. false
['docker-grid']['registry']['ssl_cert']['common_name'] String Registry server common name for TLS node['fqdn']
['docker-grid']['registry']['docker-compose']['app_dir'] String "#{node['docker-grid']['compose']['app_dir']}/registry"
['docker-grid']['registry']['docker-compose']['host_data_volume'] String Data directory path on the host filesystem or nil (unset). '/var/lib/docker-registry'
['docker-grid']['registry']['docker-compose']['config_format_version'] String docker-compose.yml format version. '1' or '2' '1'
['docker-grid']['registry']['docker-compose']['service_name'] String Docker registry service name in the docker-compose.yml 'registry'
['docker-grid']['registry']['docker-compose']['config'] Hash docker-compose.yml configurations. See attributes/default.rb and Deploying a registry server See attributes/default.rb
['docker-grid']['registry']['docker-compose']['registry-config'] Hash See Overriding the entire configuration file nil

Usage

Recipes

docker-grid::default

This recipe does nothing.

docker-grid::compose

This recipe installs docker-compose.

docker-grid::engine

This recipe sets up Docker engine.

docker-grid::registry

This recipe sets up Docker Compose configurations for the Docker registry service.

Role Examples

  • roles/docker.rb: installs the docker-engine package.
name 'docker'
description 'Docker Engine distributed by dockerproject'

run_list(
  'recipe[docker-grid::engine]',
)

override_attributes(
  'docker-grid' => {
    'install_flavor' => 'dockerproject',
    'engine' => {
      'version_on_centos' => '1.11.2-1',
      'version_on_ubuntu' => '1.11.2-0',
      'storage-driver_on_centos' => 'overlay',
      'storage-driver_on_ubuntu' => 'overlay',  # default: 'aufs'
      #'userns-remap' => 'default',  # default: nil (inactive)
      'daemon_extra_options' => '-H fd:// --bip=192.168.128.1/24 --fixed-cidr=192.168.128.0/24',
    },
  },
)
  • roles/docker-rhel.rb: installs the docker package.
name 'docker-rhel'
description 'Docker Engine distributed by RHEL'

run_list(
  'recipe[docker-grid::engine]',
)

override_attributes(
  'docker-grid' => {
    'install_flavor' => 'os-repository',
    'engine' => {
      'version_on_centos' => '1.12.5-14',  # docker package
      'version_on_ubuntu' => '1.12.3-0ubuntu4~16.04.2',  # docker.io package
      'storage-driver_on_centos' => 'overlay',
      'storage-driver_on_ubuntu' => 'overlay',  # default: aufs
      #'userns-remap' => 'default',
      'daemon_extra_options' => '-H fd://',
      # for RHEL docker package >= 1.12: '-H fd://' option automatically removed by this cookbook.
      # See https://github.com/docker/docker/issues/22847
    },
  },
)
  • roles/docker-ubuntu.rb: installs the docker.io package.
name 'docker-ubuntu'
description 'Docker Engine distributed by Ubuntu'

run_list(
  'recipe[docker-grid::engine]',
)

override_attributes(
  'docker-grid' => {
    'install_flavor' => 'os-repository',
    'engine' => {
      'version_on_centos' => '1.12.5-14',  # docker package
      'version_on_ubuntu' => '1.12.3-0ubuntu4~16.04.2',  # docker.io package
      'storage-driver_on_centos' => 'overlay',
      'storage-driver_on_ubuntu' => 'overlay',  # default: aufs
      #'userns-remap' => 'default',
      'daemon_extra_options' => '-H fd://',
    },
  },
)
  • roles/docker-registry.rb
name 'docker-registry'
description 'Docker Registry Server'

run_list(
  'recipe[docker-grid::registry]',
)

override_attributes(
  'docker-grid' => {
    'engine' => {
      'version_on_centos' => '1.11.2-1',
      'version_on_ubuntu' => '1.11.2-0',
      'storage-driver_on_centos' => 'overlay',
      'storage-driver_on_ubuntu' => 'overlay',  # default: 'aufs'
      'userns-remap' => '',
      'daemon_extra_options' => \
        '-H fd:// --bip=192.168.128.1/24 --fixed-cidr=192.168.128.0/24', \
        # for development environment only.
        #+ ' --insecure-registry registry.docker.example.com:5000',
    },
    'registry' => {
      'docker-compose' => {
        'config_format_version' => '1',
        'host_data_volume' => nil,
        'config' => {
          # in docker-compose.yml
          # See: https://docs.docker.com/registry/deploying/#/managing-with-compose
          'registry' => {
            'restart' => 'always',
            'image' => 'registry:2',
            'ports' => [
              '5000:5000',
            ],
            'environment' => {
              'REGISTRY_HTTP_TLS_CERTIFICATE' => '/certs/domain.crt',
              'REGISTRY_HTTP_TLS_KEY' =>         '/certs/domain.key',
              'REGISTRY_AUTH' =>                'htpasswd',
              'REGISTRY_AUTH_HTPASSWD_PATH' =>  '/auth/htpasswd',
              'REGISTRY_AUTH_HTPASSWD_REALM' => 'Registry Realm',
            },
            'volumes' => [
              '/path/data:/var/lib/registry',
              '/path/certs:/certs',
              '/path/auth:/auth',
            ],
          },
        },
      },
    },
  },
)
  • roles/docker-registry-with-ssl-cert.rb
name 'docker-registry-with-ssl-cert'
description 'Docker Registry Server'

run_list(
  'recipe[docker-grid::registry]',
)

registry_fqdn = 'registry.docker.example.com'

override_attributes(
  'docker-grid' => {
    'engine' => {
      'version_on_centos' => '1.11.2-1',
      'version_on_ubuntu' => '1.11.2-0',
      'storage-driver_on_centos' => 'overlay',
      'storage-driver_on_ubuntu' => 'overlay',  # default: 'aufs'
      'userns-remap' => '',
      'daemon_extra_options' => \
        '-H fd:// --bip=192.168.128.1/24 --fixed-cidr=192.168.128.0/24',
    },
    'registry' => {
      'with_ssl_cert_cookbook' => true,
      'ssl_cert' => {
        'common_name' => registry_fqdn,
      },
      'docker-compose' => {
        'config_format_version' => '1',
        'host_data_volume' => nil,
        'config' => {
          # in docker-compose.yml
          # See: https://docs.docker.com/registry/deploying/#/managing-with-compose
          'registry' => {
            'restart' => 'always',
            'image' => 'registry:2',
            'ports' => [
              '5000:5000',
            ],
            'environment' => {
              # REGISTRY_HTTP_TLS_{CERTIFICATE,KEY} will be set automatically.
              'REGISTRY_AUTH' =>                'htpasswd',
              'REGISTRY_AUTH_HTPASSWD_PATH' =>  '/auth/htpasswd',
              'REGISTRY_AUTH_HTPASSWD_REALM' => 'Registry Realm',
            },
            'volumes' => [
              # Volumes for the server certificate and key files will be set automatically.
              '/path/data:/var/lib/registry',
              '/path/auth:/auth',
            ],
          },
        },
      },
    },
  },
)
  • roles/docker-registry-by-entire-config.rb
name 'docker-registry-by-entire-config'
description 'Docker Registry Server'

run_list(
  'recipe[docker-grid::registry]',
)

override_attributes(
  'docker-grid' => {
    'engine' => {
      'version_on_centos' => '1.11.2-1',
      'version_on_ubuntu' => '1.11.2-0',
      'storage-driver_on_centos' => 'overlay',
      'storage-driver_on_ubuntu' => 'overlay',  # default: 'aufs'
      'userns-remap' => '',
      'daemon_extra_options' => \
        '-H fd:// --bip=192.168.128.1/24 --fixed-cidr=192.168.128.0/24', \
        # for development environment only.
        #+ ' --insecure-registry registry.docker.example.com:5000',
    },
    'registry' => {
      'docker-compose' => {
        'registry-config' => {
          # NOT nil
          # in ./etc/config.yml
          # See: https://docs.docker.com/registry/configuration/#/overriding-the-entire-configuration-file
          'version' => '0.1',
          # ...
        },
        'config_format_version' => '1',
        'config' => {
          # in ./docker-compose.yml
          # See: https://docs.docker.com/registry/deploying/#/managing-with-compose
          'registry' => {
            'restart' => 'always',
            'image' => 'registry:2',
            'ports' => [
              '5000:5000',
            ],
            'environment' => {
              # -> ./etc/config.yml
            },
            'volumes' => [
              # Volumes for the ./etc/config.yml will be set automatically.
              #'./etc/config.yml:/etc/docker/registry/config.yml:ro',
              '/path/data:/var/lib/registry',
              '/path/auth:/auth',
            ],
          },
        },
      },
    },
  },
)

License and Authors

  • Author:: whitestar at osdn.jp
Copyright 2016-2017, whitestar

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

    http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.

Dependent cookbooks

platform_utils >= 0.4.4
ssl_cert >= 0.3.2

Contingent cookbooks

apt_utils Applicable Versions
athenz Applicable Versions
bubbleupnp-server Applicable Versions
concourse-ci Applicable Versions
dcos-grid Applicable Versions
etcd-grid Applicable Versions
gitlab-grid Applicable Versions
hc-vault Applicable Versions
jenkins-grid Applicable Versions
kubernetes-grid Applicable Versions
minim-server Applicable Versions
minio-grid Applicable Versions
nexus-grid Applicable Versions
screwdriver Applicable Versions
spinnaker Applicable Versions

docker-grid CHANGELOG

0.3.6

-

0.3.5

  • adds the ['docker-grid']['engine']['skip_setup'] attribute.
  • adds the ['docker-grid']['compose']['skip_setup'] attribute.

0.3.4

  • improves CentOS distributed docker package support.

0.3.3

  • adds OS distributed Docker Engine package support.
  • adds the ['docker-grid']['install_flavor'] attribute.

0.3.2

  • refactoring.

0.3.1

  • bug fix: systemctl daemon-reload timing.
  • adds the storage-driver automatic modifier for ZFS.

0.3.0

  • adds Docker in LXD support.

0.2.9

  • refactoring.
  • adds the platform_utils cookbook dependency.

0.2.8

  • adds the ['docker-grid']['registry']['docker-compose']['host_data_volume'] attribute.

0.2.7

  • adds the ['docker-grid']['compose']['home_dir'] attribute.
  • adds the ['docker-grid']['compose']['app_dir'] attribute.

0.2.6

  • bug fix: modifies apt-get update timing for the updated apt-line on Ubuntu.

0.2.5

  • adds docker service's handling of CA certificate update events.

0.2.4

  • improves the docker-grid::registry recipe.
  • adds the ['docker-grid']['registry']['docker-compose']['config_format_version'] attribute.
  • adds the ['docker-grid']['registry']['docker-compose']['service_name'] attribute.

0.2.3

  • adds the docker-grid::registry recipe.
  • adds the ssl_cert cookbook dependency.
  • adds the ['docker-grid']['apt_repo']['override_apt_line'] attribute.

0.2.2

  • adds the docker-grid::compose recipe.
  • adds the ['docker-grid']['engine']['users_allow'] attribute.
  • refactoring.

0.2.1

  • refactoring.

0.2.0

  • adds the ['docker-grid']['engine']['userns-remap'] attribute.

0.1.0

  • Initial release of docker-grid

Collaborator Number Metric
            

0.3.6 failed this metric

Failure: Cookbook has 0 collaborators. A cookbook must have at least 2 collaborators to pass this metric.

Foodcritic Metric
            

0.3.6 passed this metric

License Metric
            

0.3.6 passed this metric