如何使用 Example42 的 Puppet 模块【转】

2019-03-27 01:11|来源: 网路

现在我们差不多移植了100多台服务器到虚拟机,中间合并了很多功能类似的服务器(历史遗留问题)到同一虚拟机,并且整个配置过程完全用 Puppet 代码化,也就是说有一天我们实验室机房遭遇物理毁灭(刚看完 Battleship,有点激动~),只要再给我们合适的硬件设备(异地有备份数据)我们应该能在6小时内恢复整个基础设施(OS, DNS, DHCP, Provision, Firewall, Squid, Web, Database, LDAP, Email, VPN, Kerberos, NFS, HPC, Cloud, Monitor, Backup, …)。自从 Puppet/Chef 之类的自动化配置工具流行以后,现在甚至有了一个新职位叫做 DevOps.

 

安装好 Puppet 后,就可以开始自己写配置代码了,当然也可以在网上找到别人的配置代码直接拿过来用,更妙的是一些通用的 Puppet 配置代码,比如配置一台 Nginx/PHP/MySQL、配置 NFS、配置 DHCP、配置 DNS、配置 OpenNebula 等等已经有人写成模块了,直接拷过来就可以用了。Example42 就是这样的开源 Puppet 模块大集合,包含了众多常用的服务器配置。

 

首先去 Example42 下载 Puppet 模块代码:

$ git clone http://github.com/example42/puppet-modules.git

 

看看 Example42 包含了哪些模块吧,几乎常用的都有,不用自己亲自去写配置:

$ cd puppet-modules/
$ ls
activemq     example42        lighttpd     ntp          puppet           selinux       tftp
apache       Example42-tools  link         openldap     puppetdashboard  sendmail      timezone
apt          exim             logrotate    openntpd     puppetdb         snmpd         tomcat
autofs       firewall         lsb          openssh      puppi            solr          trac
backup       foo              mailscanner  openvpn      rails            spamassassin  users
bind         foreman          mailx        oracle       Rakefile         splunk        vagrant
clamav       git              maven        orientdb     README.rdoc      sqlgrey       varnish
cobbler      haproxy          mcollective  pam          redis            squid         virtualbox
collectd     hardening        monit        pentaho      repo             squirrelmail  vmware
common       hosts            monitor      php          resolver         ssh           vsftpd
concat       icinga           munin        phpsyslogng  rootmail         ssmtp         wget
controltier  iptables         mysql        portmap      rpmbuild         stdlib42      wordpress
cron         java             nagios       postfix      rsync            sudo          xinetd
dhcpd        jboss            network      postgresql   rsyslog          synbak        yum
DOCS         jenkins          nfs          powerdns     rvm              sysctl        zip
dovecot      libvirt          nginx        psad         samba            sysklogd
drupal       LICENSE          nrpe         psick        sarg             syslog-ng

 

把上面的 Example42 代码移到 /etc/puppet 目录,然后修改 Puppet 服务器的配置,加上 puppet-modules 模块路径,别忘了重启 puppetmaster 服务:

# mv puppet-modules /etc/puppet

# vi /etc/puppet/puppet.conf
...
[master]
    modulepath = /etc/puppet/puppet-modules

# /etc/init.d/puppetmaster

 

写个配置文件测试一下,自动配置 PHP + Apache + MySQL:

# vi /etc/puppet/manifests/node.pp

node 'web.vpsee.com' {
    include apache

    include php
    include php::pear
    include php::apc
    php::module { mysql: }
    php::module { curl: }
    php::module { gd: }
    php::module { idn: }
    php::module { imagick: }
    php::module { imap: }
    php::module { mcrypt: }
    php::module { ming: }
    php::module { ps: }
    php::module { pspell: }
    php::module { recode: }
    php::module { snmp: }
    php::module { tidy: }
    php::module { xmlrpc: }
    php::module { xsl: }
    php::module { ldap: }

    include mysql
}

 

在要配置的机器上执行下面一条命令就自动装上 Apache/PHP/MySQL 了,再不用自己手动去安装配置了:

# puppet agent --test --server=master.vpsee.com

 

原文地址:如何使用 Example42 的 Puppet 模块


转自:http://www.cnblogs.com/eastson/archive/2012/07/30/2614858

相关问答

更多
  • @ ChrisPitman的评论指出了我正确的方向。 我需要设置正确的模块路径,以包括我们的自定义模块和预先构建的模块。 以下对我有用: sudo puppet apply --modulepath=/vagrant/puppet/modules:/etc/puppet/modules -e "include iwd-postgresql" @ChrisPitman's comments pointed me in the right direction. I needed to set up the c ...
  • 在你的清单中的某个地方,你声明一个依赖于Class[Puppet::Install]的File[/etc/puppet/hiera.yaml] Class[Puppet::Install] ,就像 file { '/etc/puppet/hiera.yaml': require => Class['puppet::install'] } 或者 Class['puppet::install'] -> file { '/etc/puppet/hiera.yaml': ... } 或那种静脉的东西。 你缺少的 ...
  • 看起来garethr-kubernetes软件包自2017年8月以来一直没有更新,所以你可能需要一个至少那个旧版本的kubeclient gem 。 看起来kubeclient 3.0最近刚出现,所以你可能想尝试2.5主要版本(目前为2.5.2)的最新版本。 It looks like the garethr-kubernetes package hasn't been updated since August 2017, so you probably need a version of the kube ...
  • 定义图书管理员应该找到木偶文件的位置 Vagrant.configure("2") do |config| config.librarian_puppet.puppetfile_dir = "puppet/box1" config.vm.provision :puppet do |puppet| puppet.manifests_path = "puppet/box_1/manifests" puppet.manifest_file = "site.pp" end defi ...
  • 检查您是否正确配置了Vagrant: 必须启用Puppet配置 您可以尝试显式设置module_path 尝试将目录puppet-nginx重命名为nginx (或创建符号链接) Check that you configured Vagrant properly: provisioning with Puppet must be enabled you can try to set module_path explicitly try to rename directory puppet-nginx to ...
  • mrepo适用于CentOS 6的EPEL。 虽然像Spacewalk , Katello和Pulp这样的工具(如msuchy指出的那样)也是潜在的替代品。 就像刚刚运行createrepo一样。 mrepo is available in EPEL for CentOS 6. Though tools like Spacewalk, Katello and Pulp (as msuchy indicated) are all potential alternatives as well. As is ju ...
  • 您可能想询问如何启动Control Repo 。 但在此之前,请务必阅读角色和配置文件设计模式。 为了帮助您入门,您将开始这样的事情: $ tree . └── modules ├── profile │   └── manifests │   ├── base │   │   └── filebeat.pp │   └── base.pp └── role └── manifests ├── ...
  • 可以使用Puppet从源代码构建应用程序而不使用execs,可能使用自定义编写类型和提供程序。 否则,是的,它必须是一些不同的exec资源,只有onlyif , creates等语句才能在每次代理运行时阻止它们运行。 Puppet的配置管理模型被称为期望的状态模型:您定义系统的最终状态并让系统。 这就是为什么在Puppet中通常会避免使用exec的原因:它们不适合所需的状态模型。 它还可以更新应用程序,或处理未知数,例如创建所需文件的编译部分失败。 在我看来, 我不建议使用配置管理从源代码构建应用程序 。 ...
  • Ansible具有可以应用于任务的条件。 但是, when不直接映射到Puppet时, unless它在Ansible变量上运行,而不是shell命令。 但是,您仍然可以按照自己的意愿行事。 以下是文档中的示例: tasks: - command: /bin/false register: result ignore_errors: True - command: /bin/something_else when: result|succeeded Ansible has ...
  • 我确信对于“最合适”的解决方案有很多意见,但我会给你我的。 实际上,Puppet设计用于支持多种环境中的多个应用程序,但有一些值得注意的警告: 必须将所有常见依赖项(在单个环境中)固定到同一版本 因此,如果您有三个需要Apache的应用程序,则只能有一个Apache模块 可以使用独特的名称引用所有应用程序 IE如果你有三个不同的node.js应用程序需要自己的模块,你需要三个唯一命名的模块(或清单) 您愿意同时处理多个应用程序的更新依赖关系的维护/维护 如果app1需要更新Apache模块依赖项,那么您可以 ...