OSDN Git Service

dcos-grid-0.4.0 dcos-grid-0.4.0
authorwhitestar <whitestar@gaea.test>
Sun, 9 Oct 2016 08:46:05 +0000 (17:46 +0900)
committerwhitestar <whitestar@gaea.test>
Sun, 9 Oct 2016 08:46:05 +0000 (17:46 +0900)
12 files changed:
cookbooks/dcos-grid/CHANGELOG.md
cookbooks/dcos-grid/README.md
cookbooks/dcos-grid/attributes/default.rb
cookbooks/dcos-grid/metadata.rb
cookbooks/dcos-grid/recipes/docker-engine.rb [new file with mode: 0644]
cookbooks/dcos-grid/recipes/node-commons.rb
cookbooks/dcos-grid/templates/default/etc/apt/preferences.d/docker.pref [deleted file]
cookbooks/dcos-grid/templates/default/etc/apt/sources.list.d/docker.list [deleted file]
cookbooks/dcos-grid/templates/default/etc/modules-load.d/overlay.conf [deleted file]
cookbooks/dcos-grid/templates/default/etc/systemd/system/docker.service.d/override.conf [deleted file]
cookbooks/dcos-grid/templates/default/etc/yum.repos.d/docker.repo [deleted file]
roles/dcos0.rb

index af720a8..d7341e0 100644 (file)
@@ -1,6 +1,10 @@
 dcos-grid CHANGELOG
 ===================
 
+0.4.0
+-----
+- separates the `docker-grid` cookbook.
+
 0.3.5
 -----
 - refactoring.
index 9bc14f5..09b2d80 100644 (file)
@@ -8,6 +8,7 @@ This cookbook sets up your customized DC/OS cluster on bare metal, virtual machi
 - [Requirements](#requirements)
   - [platforms](#platforms)
   - [packages](#packages)
+  - [cookbooks](#cookbooks)
 - [Attributes](#attributes)
 - [Usage](#usage)
   - [Recipes](#recipes)
@@ -35,26 +36,29 @@ This cookbook sets up your customized DC/OS cluster on bare metal, virtual machi
 ### packages
 - none.
 
+### cookbooks
+- `docker-grid` (for `dcos-grid` ver. 0.4.0 or later).
+
 ## Attributes
 
 |Key|Type|Description, example|Default|
 |:--|:--|:--|:--|
 |`['dcos-grid']['dcos_release_url']`|String|DC/OS download URL.|`'https://downloads.dcos.io/dcos/stable/dcos_generate_config.sh'`|
 |`['dcos-grid']['dcos_cli_release_url']`|String|DC/OS CLI download URL (ver. 0.3.0 or later).|`'https://downloads.dcos.io/binaries/cli/linux/x86-64/0.4.10/dcos'`|
-|`['dcos-grid']['docker']['apt_repo']['url']`|String| (ver. 0.3.1 or later)|`'https://apt.dockerproject.org/repo'`|
-|`['dcos-grid']['docker']['apt_repo']['keyserver']`|String| (ver. 0.3.1 or later)|`'hkp://p80.pool.sks-keyservers.net:80'`|
-|`['dcos-grid']['docker']['apt_repo']['recv-keys']`|String| (ver. 0.3.1 or later)|`'58118E89F3A912897C070ADBF76221572C52609D'`|
-|`['dcos-grid']['docker']['yum_repo']['baseurl']`|String| (ver. 0.3.1 or later)|`'https://yum.dockerproject.org/repo/main/centos/$releasever/'`|
-|`['dcos-grid']['docker']['yum_repo']['gpgcheck']`|String|`'0'`: disabled, `'1'`: enabled (ver. 0.3.1 or later).|`'1'`|
-|`['dcos-grid']['docker']['yum_repo']['gpgkey']`|String| (ver. 0.3.1 or later)|`'https://yum.dockerproject.org/gpg'`|
+|`['dcos-grid']['docker']['apt_repo']['url']`|String|DEPRECATED: use `['docker-grid']['apt_repo']['url']` (ver. 0.4.0 or later)|`nil`|
+|`['dcos-grid']['docker']['apt_repo']['keyserver']`|String|DEPRECATED: use `['docker-grid']['apt_repo']['keyserver']` (ver. 0.4.0 or later)|`nil`|
+|`['dcos-grid']['docker']['apt_repo']['recv-keys']`|String|DEPRECATED: use `['docker-grid']['apt_repo']['recv-keys']` (ver. 0.4.0 or later)|`nil`|
+|`['dcos-grid']['docker']['yum_repo']['baseurl']`|String|DEPRECATED: use `['docker-grid']['yum_repo']['baseurl']` (ver. 0.4.0 or later)|`nil`|
+|`['dcos-grid']['docker']['yum_repo']['gpgcheck']`|String|DEPRECATED: use `['docker-grid']['yum_repo']['gpgcheck']` (ver. 0.4.0 or later). `'0'`: disabled, `'1'`: enabled.|`nil`|
+|`['dcos-grid']['docker']['yum_repo']['gpgkey']`|String|DEPRECATED: use `['docker-grid']['yum_repo']['gpgkey']` (ver. 0.4.0 or later)|`nil`|
 |`['dcos-grid']['docker-engine']['setup']`|Boolean|Docker setup by this cookbook. If you will set up Docker by another cookbook, verify that this attribute is false. (ver. 0.3.0 or later)|`true`|
-|`['dcos-grid']['docker-engine']['version_on_centos']`|String|Docker version for CentOS (ver. 0.3.0 or later).|`'1.11.2-1'`|
-|`['dcos-grid']['docker-engine']['version_on_ubuntu']`|String|Docker version for Ubuntu (ver. 0.3.0 or later).|`'1.11.2-0'`|
-|`['dcos-grid']['docker-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}` (ver. 0.3.0 or later).|See default.rb|
-|`['dcos-grid']['docker-engine']['storage-driver_on_centos']`|String|Docker storage driver (overlay, devicemapper, ...) for CentOS (ver. 0.3.4 or later).|`'overlay'`|
-|`['dcos-grid']['docker-engine']['storage-driver_on_ubuntu']`|String|Docker storage driver (aufs, overlay, ...) for Ubuntu (ver. 0.3.4 or later).|`'aufs'`|
-|`['dcos-grid']['docker-engine']['storage-driver']`|String|(ver. 0.3.4 or later).|See default.rb|
-|`['dcos-grid']['docker-engine']['daemon_extra_options']`|String|ref. `docker daemon --help` (ver. 0.3.4 or later).|`'-H fd://'`|
+|`['dcos-grid']['docker-engine']['version_on_centos']`|String|DEPRECATED: use `['docker-grid']['engine']['version_on_centos']` (ver. 0.4.0 or later). Docker version for CentOS.|`nil`|
+|`['dcos-grid']['docker-engine']['version_on_ubuntu']`|String|DEPRECATED: use `['docker-grid']['engine']['version_on_ubuntu']` (ver. 0.4.0 or later). Docker version for Ubuntu.|`nil`|
+|`['dcos-grid']['docker-engine']['version']`|String|DEPRECATED: use `['docker-grid']['engine']['version']` (ver. 0.4.0 or later). 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|
+|`['dcos-grid']['docker-engine']['storage-driver_on_centos']`|String|DEPRECATED: use `['docker-grid']['engine']['storage-driver_on_centos']` (ver. 0.4.0 or later). Docker storage driver (overlay, devicemapper, ...) for CentOS.|`nil`|
+|`['dcos-grid']['docker-engine']['storage-driver_on_ubuntu']`|String|DEPRECATED: use `['docker-grid']['engine']['storage-driver_on_ubuntu']` (ver. 0.4.0 or later). Docker storage driver (aufs, overlay, ...) for Ubuntu.|`nil`|
+|`['dcos-grid']['docker-engine']['storage-driver']`|String|DEPRECATED: use `['docker-grid']['engine']['storage-driver']` (ver. 0.4.0 or later).|See default.rb|
+|`['dcos-grid']['docker-engine']['daemon_extra_options']`|String|DEPRECATED: use `['docker-grid']['engine']['daemon_extra_options']` (ver. 0.4.0 or later). ref. `docker daemon --help`.|`nil`|
 |`['dcos-grid']['bootstrap']['ip']`|String|Bootstrap node IP address.|`'127.0.0.1'`|
 |`['dcos-grid']['bootstrap']['port']`|String|Bootstrap node port number.|`'8080'`|
 |`['dcos-grid']['bootstrap']['genconf_dir']`|String|genconf directory path. Note: This is overridden by the value `"#{node['dcos-grid']['cloud-config']['target_dir']}/genconf"` in the `cloud-config` recipe (ver. 0.3.5 or later).|`'/opt/dcos-grid/genconf'`|
@@ -189,14 +193,16 @@ run_list(
 )
 
 override_attributes(
-  'dcos-grid' => {
-    'dcos_release_url' => 'https://downloads.dcos.io/dcos/stable/dcos_generate_config.sh',
-    #'dcos_release_url' => 'https://downloads.dcos.io/dcos/EarlyAccess/dcos_generate_config.sh',
-    'docker-engine' => {
+  'docker-grid' => {
+    'engine' => {
       'version_on_centos' => '1.11.2-1',
       'version_on_ubuntu' => '1.11.2-0',
       #'version' => '1.11.2-1.el7.centos',
     },
+  },
+  'dcos-grid' => {
+    'dcos_release_url' => 'https://downloads.dcos.io/dcos/stable/dcos_generate_config.sh',
+    #'dcos_release_url' => 'https://downloads.dcos.io/dcos/EarlyAccess/dcos_generate_config.sh',
     'bootstrap' => {
       'ip' => '192.168.56.100',
       'port' => '8080',
index b1fa770..9bae136 100644 (file)
 
 default['dcos-grid']['dcos_release_url'] = 'https://downloads.dcos.io/dcos/stable/dcos_generate_config.sh'
 default['dcos-grid']['dcos_cli_release_url'] = 'https://downloads.dcos.io/binaries/cli/linux/x86-64/0.4.10/dcos'
+# DEPRECATED: ['dcos-grid']['docker'][*] attributes. Use ['docker-grid'][*]
 default['dcos-grid']['docker']['apt_repo'] = {
-  'url' => 'https://apt.dockerproject.org/repo',
-  'keyserver' => 'hkp://p80.pool.sks-keyservers.net:80',
-  'recv-keys' => '58118E89F3A912897C070ADBF76221572C52609D',
+  'url' => nil,
+  'keyserver' => nil,
+  'recv-keys' => nil,
 }
 default['dcos-grid']['docker']['yum_repo'] = {
-  'baseurl' => 'https://yum.dockerproject.org/repo/main/centos/$releasever/',
-  'gpgcheck' => '1',
-  'gpgkey' => 'https://yum.dockerproject.org/gpg',
+  'baseurl' => nil,
+  'gpgcheck' => nil,
+  'gpgkey' => nil,
 }
+# DEPRECATED: ['dcos-grid']['docker-engine'][*] attributes except for ['dcos-grid']['docker-engine']['setup']
+#   Use ['docker-grid']['engine'][*]
 default['dcos-grid']['docker-engine']['setup'] = true
-default['dcos-grid']['docker-engine']['version_on_centos'] = '1.11.2-1'
-default['dcos-grid']['docker-engine']['version_on_ubuntu'] = '1.11.2-0'
-default['dcos-grid']['docker-engine']['version'] = node.value_for_platform(
-  ['centos', 'redhat'] => {
-    'default' => "#{node['dcos-grid']['docker-engine']['version_on_centos']}.el#{node['platform_version'].to_i}.#{node['platform']}",
-  },
-  'ubuntu' => {
-    'default' => "#{node['dcos-grid']['docker-engine']['version_on_ubuntu']}~#{node['lsb']['codename']}",
-  }
-)
-default['dcos-grid']['docker-engine']['storage-driver_on_centos'] = 'overlay'
-default['dcos-grid']['docker-engine']['storage-driver_on_ubuntu'] = 'aufs'
-default['dcos-grid']['docker-engine']['storage-driver'] = node.value_for_platform(
-  ['centos', 'redhat'] => {
-    'default' => node['dcos-grid']['docker-engine']['storage-driver_on_centos'],
-  },
-  'ubuntu' => {
-    'default' => node['dcos-grid']['docker-engine']['storage-driver_on_ubuntu'],
-  }
-)
-default['dcos-grid']['docker-engine']['daemon_extra_options'] = '-H fd://'
+default['dcos-grid']['docker-engine']['version_on_centos'] = nil
+default['dcos-grid']['docker-engine']['version_on_ubuntu'] = nil
+default['dcos-grid']['docker-engine']['version'] = nil
+default['dcos-grid']['docker-engine']['storage-driver_on_centos'] = nil
+default['dcos-grid']['docker-engine']['storage-driver_on_ubuntu'] = nil
+default['dcos-grid']['docker-engine']['storage-driver'] = nil
+default['dcos-grid']['docker-engine']['daemon_extra_options'] = nil
 default['dcos-grid']['bootstrap']['ip'] = '127.0.0.1'
 default['dcos-grid']['bootstrap']['port'] = '8080'
 default['dcos-grid']['bootstrap']['genconf_dir'] = '/opt/dcos-grid/genconf'
index 0f898d6..0f090d7 100644 (file)
@@ -5,7 +5,7 @@ maintainer_email ''
 license          'Apache 2.0'
 description      'Installs/Configures DC/OS Cluster Node.'
 long_description IO.read(File.join(File.dirname(__FILE__), 'README.md'))
-version          '0.3.5'
+version          '0.4.0'
 source_url       'http://scm.osdn.jp/gitroot/metasearch/grid-chef-repo.git'
 issues_url       'https://osdn.jp/projects/metasearch/ticket'
 
@@ -14,3 +14,6 @@ issues_url       'https://osdn.jp/projects/metasearch/ticket'
 end
 # Experimental
 supports 'ubuntu', '>= 16.04'
+
+# external cookbooks
+depends 'docker-grid', '>= 0.1.0'
diff --git a/cookbooks/dcos-grid/recipes/docker-engine.rb b/cookbooks/dcos-grid/recipes/docker-engine.rb
new file mode 100644 (file)
index 0000000..8b05677
--- /dev/null
@@ -0,0 +1,37 @@
+#
+# Cookbook Name:: dcos-grid
+# Recipe:: docker-engine
+#
+# Copyright 2016, 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.
+#
+
+# https://dcos.io/docs/1.8/administration/installing/custom/system-requirements/
+
+# for deprecated attributes
+[
+  'apt_repo',
+  'yum_repo',
+].each {|pkey|
+  node['dcos-grid']['docker'][pkey].each {|key, value|
+    node.override['docker-grid'][pkey][key] = value unless value.nil?
+  }
+}
+
+node['dcos-grid']['docker-engine'].each {|key, value|
+  next if key == 'setup'
+  node.override['docker-grid']['engine'][key] = value unless value.nil?
+}
+
+include_recipe 'docker-grid::engine'
index 437b22c..2da4fe3 100644 (file)
@@ -40,45 +40,8 @@ group 'nogroup' do
   action :create
 end
 
-bash 'systemctl_daemon-reload' do
-  code <<-EOH
-    systemctl daemon-reload
-  EOH
-  action :nothing
-end
-
 if node['dcos-grid']['docker-engine']['setup']
-  if node['dcos-grid']['docker-engine']['storage-driver'] == 'overlay'
-    bash 'load_overlayfs_kernel_module' do
-      code <<-EOH
-        modprobe overlay
-      EOH
-      not_if 'lsmod | grep overlay'
-    end
-
-    template '/etc/modules-load.d/overlay.conf' do
-      source  'etc/modules-load.d/overlay.conf'
-      owner 'root'
-      group 'root'
-      mode '0644'
-    end
-  end
-
-  directory '/etc/systemd/system/docker.service.d' do
-    owner 'root'
-    group 'root'
-    mode '0755'
-    action :create
-  end
-
-  template '/etc/systemd/system/docker.service.d/override.conf' do
-    source  'etc/systemd/system/docker.service.d/override.conf'
-    owner 'root'
-    group 'root'
-    mode '0644'
-    notifies :run, 'bash[systemctl_daemon-reload]'
-    notifies :restart, 'service[docker]'
-  end
+  include_recipe 'dcos-grid::docker-engine'
 end
 
 case node['platform_family']
@@ -111,32 +74,6 @@ when 'rhel'
     group 'root'
     mode '0644'
   end
-
-  # https://dcos.io/docs/1.8/administration/installing/custom/system-requirements/install-docker-centos/
-  if node['dcos-grid']['docker-engine']['setup']
-    template '/etc/yum.repos.d/docker.repo' do
-      source  'etc/yum.repos.d/docker.repo'
-      owner 'root'
-      group 'root'
-      mode '0644'
-    end
-
-    [
-      'docker-engine-selinux',
-      'docker-engine',
-    ].each {|pkg|
-      package pkg do
-        action :install
-        version node['dcos-grid']['docker-engine']['version']
-        # dockerrepo is disabled by default to prevent automatic update.
-        options '--enablerepo=dockerrepo'
-      end
-    }
-
-    service 'docker' do
-      action [:start, :enable]
-    end
-  end
 when 'debian'
   [
     'tar',
@@ -150,64 +87,6 @@ when 'debian'
     end
   }
 
-  # https://docs.docker.com/engine/installation/linux/ubuntulinux/
-  if node['dcos-grid']['docker-engine']['setup']
-    pkgs = [
-      'apt-transport-https',
-      'ca-certificates',
-    ]
-
-    if node['dcos-grid']['docker-engine']['storage-driver'] == 'aufs'
-      pkgs += [
-        "linux-image-extra-#{node['os_version']}",
-        'linux-image-extra-virtual',
-      ]
-    end
-
-    pkgs.each {|pkg|
-      package pkg do
-        action :install
-      end
-    }
-
-    template '/etc/apt/sources.list.d/docker.list' do
-      source  'etc/apt/sources.list.d/docker.list'
-      owner 'root'
-      group 'root'
-      mode '0644'
-    end
-
-    apt_repo_config = node['dcos-grid']['docker']['apt_repo']
-    bash 'apt-key_adv_docker_tools_key' do
-      code <<-"EOH"
-        apt-key adv --keyserver #{apt_repo_config['keyserver']} --recv-keys #{apt_repo_config['recv-keys']}
-        apt-get update
-      EOH
-      not_if 'apt-key list | grep -i docker'
-    end
-
-    # Pinning Docker version
-    template '/etc/apt/preferences.d/docker.pref' do
-      source  'etc/apt/preferences.d/docker.pref'
-      owner 'root'
-      group 'root'
-      mode '0644'
-    end
-
-    [
-      'docker-engine',
-    ].each {|pkg|
-      package pkg do
-        action :install
-        version node['dcos-grid']['docker-engine']['version']
-      end
-    }
-
-    service 'docker' do
-      action [:start, :enable]
-    end
-  end
-
   # work around for DC/OS service units
   link '/usr/bin/mkdir' do
     to '/bin/mkdir'
diff --git a/cookbooks/dcos-grid/templates/default/etc/apt/preferences.d/docker.pref b/cookbooks/dcos-grid/templates/default/etc/apt/preferences.d/docker.pref
deleted file mode 100644 (file)
index 83cbb76..0000000
+++ /dev/null
@@ -1,3 +0,0 @@
-Package: docker-engine
-Pin: version <%= node['dcos-grid']['docker-engine']['version'] %>
-Pin-Priority: 1001
diff --git a/cookbooks/dcos-grid/templates/default/etc/apt/sources.list.d/docker.list b/cookbooks/dcos-grid/templates/default/etc/apt/sources.list.d/docker.list
deleted file mode 100644 (file)
index 1c66e0c..0000000
+++ /dev/null
@@ -1 +0,0 @@
-deb <%= node['dcos-grid']['docker']['apt_repo']['url'] %> ubuntu-<%= node['lsb']['codename'] %> main
diff --git a/cookbooks/dcos-grid/templates/default/etc/modules-load.d/overlay.conf b/cookbooks/dcos-grid/templates/default/etc/modules-load.d/overlay.conf
deleted file mode 100644 (file)
index 08047cf..0000000
+++ /dev/null
@@ -1 +0,0 @@
-overlay
diff --git a/cookbooks/dcos-grid/templates/default/etc/systemd/system/docker.service.d/override.conf b/cookbooks/dcos-grid/templates/default/etc/systemd/system/docker.service.d/override.conf
deleted file mode 100644 (file)
index 4201456..0000000
+++ /dev/null
@@ -1,11 +0,0 @@
-<%
-extra_options = node['dcos-grid']['docker-engine']['daemon_extra_options']
-storage_driver = node['dcos-grid']['docker-engine']['storage-driver']
-storage_driver_option = ''
-if !storage_driver.nil? && !storage_driver.empty?
-  storage_driver_option = "--storage-driver=#{storage_driver}"
-end
--%>
-[Service]
-ExecStart=
-ExecStart=/usr/bin/docker daemon <%= storage_driver_option %> <%= extra_options %>
diff --git a/cookbooks/dcos-grid/templates/default/etc/yum.repos.d/docker.repo b/cookbooks/dcos-grid/templates/default/etc/yum.repos.d/docker.repo
deleted file mode 100644 (file)
index bb49415..0000000
+++ /dev/null
@@ -1,10 +0,0 @@
-<%
-config = node['dcos-grid']['docker']['yum_repo']
--%>
-[dockerrepo]
-name=Docker Repository
-baseurl=<%= config['baseurl'] %>
-# dockerrepo is disabled by default to prevent automatic update.
-enabled=0
-gpgcheck=<%= config['gpgcheck'] %>
-gpgkey=<%= config['gpgkey'] %>
index 25ce2cc..2428fd9 100644 (file)
@@ -12,13 +12,15 @@ default_attributes(
 )
 
 override_attributes(
-  'dcos-grid' => {
-    'dcos_release_url' => 'https://downloads.dcos.io/dcos/stable/dcos_generate_config.sh',
-    #'dcos_release_url' => 'https://downloads.dcos.io/dcos/EarlyAccess/dcos_generate_config.sh',
-    'docker-engine' => {
+  'docker-grid' => {
+    'engine' => {
       'version_on_centos' => '1.11.2-1',
       'version_on_ubuntu' => '1.11.2-0',
     },
+  },
+  'dcos-grid' => {
+    'dcos_release_url' => 'https://downloads.dcos.io/dcos/stable/dcos_generate_config.sh',
+    #'dcos_release_url' => 'https://downloads.dcos.io/dcos/EarlyAccess/dcos_generate_config.sh',
     'bootstrap' => {
       'ip' => '192.168.56.100',
       'port' => '8080',