[meta-virtualization] [PATCH v2] puppet: add recipe for puppet 3.7.3
Bruce Ashfield
bruce.ashfield at gmail.com
Wed Dec 3 07:21:17 PST 2014
On Wed, Dec 3, 2014 at 4:07 AM, YangHaibo <b40869 at freescale.com> wrote:
> A simple demo is added
Fantastic.
I'll queue the patches and do a test build. With the chef support and
now puppet, we have
some nice functionality for configuration and deployment.
Cheers,
Bruce
> ---
> meta-openstack/recipes-support/puppet/README | 75 ++++++++++++++++++++++
> .../puppet/puppet/add_puppet_gemspec.patch | 23 +++++++
> .../recipes-support/puppet/puppet_3.7.3.bb | 31 +++++++++
> 3 files changed, 129 insertions(+)
> create mode 100644 meta-openstack/recipes-support/puppet/README
> create mode 100644 meta-openstack/recipes-support/puppet/puppet/add_puppet_gemspec.patch
> create mode 100644 meta-openstack/recipes-support/puppet/puppet_3.7.3.bb
>
> diff --git a/meta-openstack/recipes-support/puppet/README b/meta-openstack/recipes-support/puppet/README
> new file mode 100644
> index 0000000..2de808a
> --- /dev/null
> +++ b/meta-openstack/recipes-support/puppet/README
> @@ -0,0 +1,75 @@
> +What is Puppet
> +------------------------
> +Puppet is a configuration management system that allows you to define the
> +state of your IT infrastructure, then automatically enforces the correct state.
> +
> +
> +Basic Requirements
> +------------------------
> +Ruby 1.8.7 or later
> +Facter 1.7.0 or later
> +Hiera 1.0 or later
> +The json gem (any modern version)
> +
> +
> +Simple Demo
> +------------------------
> +In this simple demo, we have a CA master server named 'master' and ip is 192.168.2.83
> +and an agent node named 'agent', ip is 192.168.2.30.
> +
> +On master server, file 'test.cfg' is under /etc/puppet/files/, puppet will sync this
> +file to /opt/ folder on agent node.
> +
> +Step 1: Configure Puppet CA Master Server
> +1) create a puppet group and user
> +$ puppet resource group puppet ensure=presnt
> +$ puppet resource user puppet ensure=present gid=puppet shell='/sbin/nologin'
> +
> +2) create the CA certificate and the puppet master certificate
> +$ puppet master --verbose --no-daemonize
> +(Once it says Notice: Starting Puppet master version <VERSION>, type ctrl-C to kill the process)
> +
> +3) $ vi /etc/hosts
> +add new line:
> +192.168.2.30 agent
> +
> +4) start puppet master
> +$ puppet master --verbose --no-daemonize &
> +
> +
> +Step 2: Config Puppet Agent Node
> +1) Edit puppet.conf
> +$ echo "[main]
> +server = master" >> /etc/puppet/puppet.conf
> +
> +2) $ vi /etc/hosts
> +add new line:
> +192.168.2.83 master
> +
> +3) Request certificates
> +$ puppet agent --test --ca_server=t2080qds -w 60
> +(Accept the request on master server by this command: puppet cert sign --all)
> +
> +
> +Step 3: Add site map on master
> +1) Edit /etc/puppet/fileserver.conf to make /etc/puppet/files available
> +$ mkdir /etc/puppet/files
> +$ touch /etc/puppet/files/test.cfg
> +$ vi /etc/puppet/fileserver.conf
> +add following lines:
> +[extra_files]
> + path /etc/puppet/files
> + allow *
> +
> +2) Add a new sitemap
> +$ vi /etc/puppet/manifests/site.pp
> +add follwing lines:
> +file
> +{ "/opt/test.cfg":
> +source => "puppet:///extra_files/test.cfg",
> +}
> +
> +
> +Step 4: Run puppet on agent
> +$ puppet agent --test
> +$ ls /opt/
> diff --git a/meta-openstack/recipes-support/puppet/puppet/add_puppet_gemspec.patch b/meta-openstack/recipes-support/puppet/puppet/add_puppet_gemspec.patch
> new file mode 100644
> index 0000000..a5c8e3b
> --- /dev/null
> +++ b/meta-openstack/recipes-support/puppet/puppet/add_puppet_gemspec.patch
> @@ -0,0 +1,23 @@
> +diff -urN puppet-3.7.3_ori/puppet.gemspec puppet-3.7.3/puppet.gemspec
> +--- puppet-3.7.3_ori/puppet.gemspec 1970-01-01 08:00:00.000000000 +0800
> ++++ puppet-3.7.3/puppet.gemspec 2014-11-12 14:30:07.000000000 +0800
> +@@ -0,0 +1,19 @@
> ++$:.unshift(File.dirname(__FILE__) + '/lib')
> ++require 'puppet/version'
> ++
> ++Gem::Specification.new do |s|
> ++ s.name = 'puppet'
> ++ s.version = Puppet::PUPPETVERSION
> ++ s.platform = Gem::Platform::RUBY
> ++ s.summary = 'Open source Puppet is a configuration management system'
> ++ s.description = s.summary
> ++ s.author = 'Yang Haibo'
> ++ s.email = 'b40869 at freescale.com'
> ++ s.homepage = 'https://puppetlabs.com/puppet/puppet-open-source'
> ++ s.license = 'Apache 2.0'
> ++
> ++ s.bindir = 'bin'
> ++ s.executables = ['puppet', 'extlookup2hiera']
> ++ s.require_path = 'lib'
> ++ s.files = %w(LICENSE README.md Rakefile) + Dir.glob('{lib,spec}/**/*')
> ++end
> diff --git a/meta-openstack/recipes-support/puppet/puppet_3.7.3.bb b/meta-openstack/recipes-support/puppet/puppet_3.7.3.bb
> new file mode 100644
> index 0000000..afd9a23
> --- /dev/null
> +++ b/meta-openstack/recipes-support/puppet/puppet_3.7.3.bb
> @@ -0,0 +1,31 @@
> +SUMMARY = "Open source Puppet is a configuration management system"
> +HOMEPAGE = "https://puppetlabs.com/puppet/puppet-open-source"
> +LICENSE = "Apache-2.0"
> +LIC_FILES_CHKSUM = "file://LICENSE;md5=f257790c70561550fd666c6e0044fd89"
> +
> +SRC_URI = " \
> + https://downloads.puppetlabs.com/puppet/puppet-${PV}.tar.gz \
> + file://add_puppet_gemspec.patch \
> +"
> +SRC_URI[md5sum] = "cc294da1d51df07bcc7f6cf78bd90ce0"
> +SRC_URI[sha256sum] = "4a3bd7ddb51072c3dd898a8de158cde204a2d8fd0b84e8ac806b84c074348637"
> +
> +inherit ruby
> +
> +DEPENDS += " \
> + ruby \
> + facter \
> + hiera \
> +"
> +
> +RUBY_INSTALL_GEMS = "puppet-${PV}.gem"
> +
> +do_install_append() {
> + install -d ${D}${sysconfdir}/puppet
> + install -d ${D}${sysconfdir}/puppet/manifests
> + install -d ${D}${sysconfdir}/puppet/modules
> +
> + install -m 655 ${S}/conf/auth.conf ${D}${sysconfdir}/puppet/
> + install -m 655 ${S}/conf/fileserver.conf ${D}${sysconfdir}/puppet/
> + install -m 655 ${S}/conf/tagmail.conf ${D}${sysconfdir}/puppet/
> +}
> --
> 1.9.2
>
> --
> _______________________________________________
> meta-virtualization mailing list
> meta-virtualization at yoctoproject.org
> https://lists.yoctoproject.org/listinfo/meta-virtualization
--
"Thou shalt not follow the NULL pointer, for chaos and madness await
thee at its end"
More information about the meta-virtualization
mailing list