三、Puppet多环境部署

我们为puppetmaster建立3个环境,它们分别是开发环境(jqdev)、测试环境(jqtest)、生产环境(jqprd).

3.1 配置puppet.conf

在标签[master]中添加environments环境,其次创建对应的环境标签及配置创建目录

[root@puppetmaster1 puppet]# cd /etc/puppet/

[root@puppetmaster1 puppet]# mkdir -p environments/jqdev

[root@puppetmaster1 environments]# mkdir -p jqdev/{application/modules,environment/modules}

[root@puppetmaster1 puppet]# mkdir -p environments/jqprd

[root@puppetmaster1 environments]# mkdir -p jqprd/{application/modules,environment/modules}

[root@puppetmaster1 puppet]# mkdir -p environments/jqtest

[root@puppetmaster1 environments]# mkdir -p jqtest/{application/modules,environment/modules}

移动默认环境modules中的配置到jqprd对应的环境中

其中puppet和yum模块属于基础环境模块,motd属于应用环境模块,关于此类puppet,yum,motd模块方案,请参见kisspuppet.com。

[root@puppetmaster1 environments]# mv /etc/puppet/modules/puppet jqprd/environment/modules/ 
[root@puppetmaster1 environments]# mv /etc/puppet/modules/yum  jqprd/environment/modules/ 
[root@puppetmaster1 environments]# mv /etc/puppet/modules/motd jqprd/application/modules/

复制manifests文件至jqprd环境中

[root@puppetmaster1 environments]# cp /etc/puppet/manifests jqprd/ -r

删除掉默认环境manifests中site.pp文件内容

因为模块已经移除,其次默认环境production已经不再使用了。

[root@puppetmaster environments]# >/etc/puppet/manifests/site.pp

创建fileserverconfig文件

[root@puppetmaster ~]# cp /etc/puppet/fileserver.conf{,.jqdev}
[root@puppetmaster ~]# cp /etc/puppet/fileserver.conf{,.jqtest}
[root@puppetmaster ~]# cp /etc/puppet/fileserver.conf{,.jqprd}
[root@puppetmaster ~]# ll /etc/puppet/
total 88
-rw-r--r-- 1 root root  2569 Jan  7 07:51 auth.conf
-rw-r--r-- 1 root root    17 Mar  9 17:54 autosign.conf.bak
drwxr-xr-x 5 root root  4096 Mar 27 22:33 environments
-rw-r--r-- 1 root root   381 Jan  7 07:49 fileserver.conf
-rw-r--r-- 1 root root   381 Mar 27 22:46 fileserver.conf.jqdev  #指向jqdev环境
-rw-r--r-- 1 root root   381 Mar 27 22:46 fileserver.conf.jqprd  #指向jqmq环境
-rw-r--r-- 1 root root   381 Mar 27 22:46 fileserver.conf.jqtest   #指向jqdev环境
drwxr-xr-x 2 root root  4096 Mar 25 05:23 manifests
drwxr-xr-x 2 root root  4096 Mar 27 22:40 modules
-rw-r--r-- 1 root root  1063 Mar 27 21:55 puppet.conf
-rw-r--r-- 1 root root   853 Mar  9 00:48 puppet.conf.bak
-rw-r--r-- 1 root root 42031 Mar  9 03:25 puppet.conf.out

最后配置puppetmaster配置文件

[root@puppetmaster1 puppet]# grep -v "#" ./puppet.conf

[main]

logdir = /var/log/puppet

rundir = /var/run/puppet

ssldir = $vardir/ssl

[agent]

classfile = $vardir/classes.txt

localconfig = $vardir/localconfig

server = puppetmaster1.jq.com

certname = puppetmaster1_cert.jq.com

[master]

certname = puppetmaster1.jq.com

environments = jqdev,jqtest,jqprd

basemodulepath   = /etc/puppet/modules:/usr/share/puppet/modules

[jqdev]

modulepath = $confdir/environments/jqdev/environment/modules:$confdir/environments/jqdev/application/module

manifest = $confdir/environments/jqdev/manifests/site.pp

fileserverconfig = /etc/puppet/fileserver.conf.jqdev

[jqtest]

modulepath = $confdir/environments/jqtest/environment/modules:$confdir/environments/jqtest/application/modules

manifest = $confdir/environments/jqtest/manifests/site.pp

fileserverconfig = /etc/puppet/fileserver.conf.jqtest

[jqprd]

modulepath = $confdir/environments/jqprd/environment/modules:$confdir/environments/jqprd/application/modules

manifest = $confdir/environments/jqprd/manifests/site.pp

fileserverconfig = /etc/puppet/fileserver.conf.jqprd

重启puppetmaster服务

[root@puppetmaster1 ~]# /etc/init.d/puppetmaster restart
Stopping puppetmaster:                                     [  OK  ]
Starting puppetmaster:                                     [  OK  ]

在客户端测试

[root@ag1 yum.repos.d]# puppet agent -t --environment=jqprd

Info: Retrieving pluginfacts

Info: Retrieving plugin

Info: Loading facts

Info: Caching catalog for ag1_cert.jq.com

Info: Applying configuration version '1419413649'

本系统puppet均根据kisspuppet的博客(http://kisspuppet.com/)进行实验,非常感谢!!!

3.7的版本,多环境变量,配置有变更,详情如下:

彻底搞定。详情如下:
[root@pm01 jqprd]# grep -v "#" /etc/puppet/puppet.conf
[main]
logdir = /var/log/puppet
rundir = /var/run/puppet
ssldir = $vardir/ssl
privatekeydir = $ssldir/private_keys { group = service }

hostprivkey = $privatekeydir/$certname.pem { mode = 640 }
environment_timeout = 2s
environmentpath = $confdir/environments
basemodulepath = $config/modules:/usr/share/puppet/modules

[agent]
classfile = $vardir/classes.txt
localconfig = $vardir/localconfig
server = pm01.jq.com
certname = pm01.jq.com
pluginsync = true
environment = jqprd

[master]
certname = pm01.jq.com
ssl_client_verify_header = HTTP_X_CLIENT_VERIFY
ssl_client_header = HTTP_X_CLIENT_DN
reports = foreman
external_nodes = /etc/puppet/node.rb
node_terminus = exec

jqprd下的配置文件如下:
[root@pm01 jqprd]# pwd
/etc/puppet/environments/jqprd
[root@pm01 jqprd]# cat environment.conf
modulepath =
$basemodulepath:/etc/puppet/environments/jqprd/environment/modules:/etc/puppet/environments/jqprd/application/modules

树状结构如下:
[root@pm01 environments]# tree ./jqprd/
./jqprd/
├── application
│   └── modules
│   └── motd
│   ├── files
│   │   └── etc
│   │   └── motd
│   ├── manifests
│   │   └── init.pp
│   └── templates
├── environment
│   └── modules
│   ├── facts
│   │   ├── files
│   │   │   └── facts.d
│   │   │   ├── ag01.txt
│   │   │   ├── ag02.txt
│   │   │   └── pm01.txt
│   │   ├── lib
│   │   │   └── facter
│   │   │   └── hwclock.rb
│   │   ├── manifests
│   │   │   ├── config.pp
│   │   │   ├── exec.pp
│   │   │   └── init.pp
│   │   └── templates
│   ├── puppet
│   │   ├── files
│   │   ├── manifests
│   │   │   ├── config.pp
│   │   │   ├── init.pp
│   │   │   ├── install.pp
│   │   │   ├── params.pp
│   │   │   ├── params.pp.bak
│   │   │   └── service.pp
│   │   └── templates
│   │   └── puppet.conf.erb
│   └── yum
│   ├── files
│   │   ├── etc
│   │   │   └── yum.conf
│   │   └── PM-GPG-KEY
│   │   └── RPM-GPG-KEY-CentOS-6
│   ├── manifests
│   │   ├── config.pp
│   │   ├── init.pp
│   │   ├── install.pp
│   │   └── params.pp
│   └── templates
├── environment.conf
├── hiera
│   ├── ag01.yaml
│   ├── ag02.yaml
│   ├── ag2.yaml.bak
│   ├── common.yaml
│   ├── pm01.yaml
│   └── RedHat.yaml
└── manifests
├── site.pp
└── site.pp.bak

28 directories, 31 files

puppet多环境配置(puppet自动化系列2)的更多相关文章

  1. Cucumber(1) —— 环境配置

    目录 学习资料 cucumber简介 cucumber环境配置 学习资料 1.cucumber官方学习网站 cucumber简介 1.cucumber是一种支持BBD(behavior-driven ...

  2. puppet初始化安装和配置(puppet自动化系列1)

    一.服务器规划 以下均直接yum安装最新版. 服务器操作系统为centos6.2 Puppetmaster1 10.168.32.116 puppstmaster1.jq.com Puppetmast ...

  3. 自动化运维工具之Puppet master/agent模型、站点清单和puppet多环境设定

    前文我们了解了puppe中模块的使用,回顾请参考https://www.cnblogs.com/qiuhom-1874/p/14086315.html:今天我来了解下puppet的master/age ...

  4. Puppet master nginx 扩展提升性能(puppet自动化系列4)

    puppet使用SSL(https)协议来进行通讯,默认情况下,puppet server端使用基于Ruby的WEBRick HTTP服务器.由于WEBRick HTTP服务器在处理agent端的性能 ...

  5. puppet插件fact和hiera(puppet自动化系列3)

    四.Fact插件 4.1 使用pluginsync进行发布 这种方法比较特殊,节点factpath目录里除了编写好的rb文件之外,还需要在puppet模块中引用,运行一次之后才会转换成fact.通常在 ...

  6. Puppet安装与配置简介(附视频教程)

    Puppet是一种Linux平台的集中配置管理系统,他可管理配置文件.用户.cron任务.软件包.系统服务等.puppet把这些系统实体称之为资源,puppet采用C/S星状的结构,所有的客户端和一个 ...

  7. puppet运维配置实列

    aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAABQkAAAGBCAIAAABKMKAEAAAgAElEQVR4nOydeXwU9cH/t2o9WutR+7

  8. puppet yum安装配置,简单证书维护

    Puppet学习之puppet的安装和配置 一.Puppet简介 Puppet基于ruby语言开发的自动化系统配置工具,可以C/S模式或独立运行,支持对所有UNIX及类UNIX系统的配置管理,最新版本 ...

  9. 配置puppet的主机端和客户端的自动认证

    配置puppet的主机端和客户端的自动认证 author:headsen  chen    2017-11-01  17:44:56 个人原创,转载请注明作者,出处,否则依法追究法律责任 1,先在主机 ...

随机推荐

  1. rm -rf 删除文件找回

    一个不小心rm掉文件了吧? 后悔莫及了吧! 把这段代码加入你的home目录的.bashrc或者.zshrc就可以了! 工作原理: 在你的home目录会创建一个.trash文件夹 里面会按照删除时间 年 ...

  2. html5plus (H5 WebApp)

    是什么? 它是增强版的手机浏览器引擎, 让HTML5达到原生水平, 它提供WebApp的规范. 它结合MUI(前端框架) + HBuilder(开发工具) 即可迅速实现开发一个app. 快速起步? 1 ...

  3. JVM垃圾回收时的可触及性

    可触及的 1.从根节点可以触及到这个对象可复活的 1.一旦所有引用被释放,就是可复活状态 2.因为在finalize()中可能复活该对象不可触及的 1.在finalize()后,可能会进入不可触及状态 ...

  4. linux c编程:管道

    2在前面介绍过,进程之间交换信息的唯一途径就是传送打开的文件.可以经由fork或者exec来传送.这一章将介绍新的进程共享方式 每个进程各自有不同的用户地址空间,任何一个进程的全局变量在另一个进程中都 ...

  5. TensorFlow 初级教程(三)

    TensorFlow基本操作 import os import tensorflow as tf os.environ[' # 使用TensorFlow输出Hello # 创建一个常量操作( Cons ...

  6. READ_TEXT

    [转自http://lz357502668.blog.163.com/blog/static/1649674320109119101907/]这里,定义ITAB内表来存储长文本,并放到内表ITAB_E ...

  7. ARDUINO W5100 WebClient 测试

    基础工作:W5100扩展板插在ARDUINO上.用网线把W5100和自己家的路由器连接.插上网线能看到侧面网口指示灯变亮.路由器开启DHCP服务(一般都是开启的). 1.打开官方例程里面的Ethern ...

  8. mysql 修改表名的方法:sql语句

    在使用mysql时,经常遇到表名不符合规范或标准,但是表里已经有大量的数据了,如何保留数据,只更改表名呢? 可以通过建一个相同的表结构的表,把原来的数据导入到新表中,但是这样视乎很麻烦. 能否简单使用 ...

  9. spring boot项目使用swagger-codegen生成服务间调用的jar包

    swagger-codegen的github:https://github.com/swagger-api/swagger-codegen 需要的环境:jdk > 1.7   maven > ...

  10. [算法]Rotate Array

    You may have been using Java for a while. Do you think a simple Java array question can be a challen ...