共计 2751 个字符,预计需要花费 7 分钟才能阅读完成。
一、Puppet 简介
Puppet 是一种 Linux、Unix 平台的集中配置管理系统,使用 ruby 语言,可管理配置文件、用户、cron 任务、软件包、系统服务等。Puppet 把这些系统实体称之为资源,Puppet 的设计目标是简化对这些资源的管理以及妥善处理资源间的依赖关系。
二、Puppet 工作流程
1、客户端 Puppetd 调用 facter,facter 探测出主机的一些变量,例如主机名,内存大小,ip 地址等。pupppetd 把这些信息通过 ssl 连接发送到服务器端;
2、服务器端的 Puppetmaster 检测客户端的主机名,然后找到 manifest 里面对应的 node 配置,并对该部分内容进行解析,facter 送过来的信息可以作为变量处理,node 牵涉到的代码才解析,其他没牵涉的代码不解析。解析分为几个阶段,语法检查,如果语法错误就报错。如果语法没错,就继续解析,解析的结果生成一个中间的“伪代码”,然后把伪代码发给客户端;
3、客户端接收到“伪代码”,并且执行,客户端把执行结果发送给服务器;
4、服务器端把客户端的执行结果写入日志。
三、安装准备 (已关闭防火墙和 selinux)
名称 | 系统 | ip | 主机名 |
master | CentOS 7 | 192.168.152.131 | master.domain.com |
slave | centos 7 | 192.168.152.132 | slave.domain.com |
四、安装步骤
4.1、master 服务器配置
添加 puppet 自定义仓库
[root@master ~]# rpm -ivh https://yum.puppetlabs.com/el/7/products/x86_64/puppetlabs-release-7-10.noarch.rpm
安装 puppetserver
[root@master ~]# yum install puppet-server
设置开机启动
[root@master ~]# systemctl enable puppetmaster.service
编辑 hosts 文件是两台服务器互通
[root@master ~]# vi /etc/hosts
添加如下两行
192.168.152.131 master.domain.com
192.168.152.132 slave.domain.com
[root@master ~]# vi /etc/puppet/puppet.conf
添加如下内容:
[master]
certname=master.domain.com// 服务端的名字
启动服务
[root@master ~]# systemctl start puppetmaster.service
开机启动
[root@master ~]# systemctl enbale puppetmaster.service
4.2、配置客户端
[root@slave ~]# rpm -ivh https://yum.puppetlabs.com/el/7/products/x86_64/puppetlabs-release-7-10.noarch.rpm
[root@slave ~]# yum install puppet
[root@slave ~]#vi /etc/puppet/puppet.conf
添加如下内容:
[agent]
certname = slave.domain.com
server = master.domain.com
report = true
[root@slave ~]# systemctl start puppet.service
[root@slave ~]# systemctl enable puppet.service
测试:
[root@slave ~]# puppet agent –server=master.domain.com –verbose –no-daemonize –debug
[root@master manifests]# vi site.pp
服务器上配置 site.pp
node default{
file{
“/mnt/pu”:
owner =>”lila”,
group=>”lila”,
}
}
客户端执行
[root@slave mnt]# puppet agent -t
Info: Retrieving pluginfacts
Info: Retrieving plugin
Info: Caching catalog for slave.domain.com
Info: Applying configuration version ‘1487772773’
Notice: /Stage[main]/Main/Node[default]/File[/mnt/pu]/owner: owner changed ‘root’ to ‘lila’
Notice: /Stage[main]/Main/Node[default]/File[/mnt/pu]/group: group changed ‘root’ to ‘lila’
Notice: Finished catalog run in 0.02 seconds
[root@slave mnt]# ll
total 4
-rw-rw-rw- 1 lila lila 6 Feb 22 08:08 pu
Puppet 学习系列:
Puppet 学习一:安装及简单实例应用 http://www.linuxidc.com/Linux/2013-08/88710.htm
Puppet 学习二: 简单模块配置和应用 http://www.linuxidc.com/Linux/2013-08/88711.htm
相关阅读:
有关 Puppet agent 端三种备份恢复方案探讨研究 http://www.linuxidc.com/Linux/2013-07/87885.htm
选择更安全的方式注册你的 Puppet 节点 http://www.linuxidc.com/Linux/2013-07/87884.htm
通过配置 SSH 深刻理解 Puppet 的语法及工作机制 http://www.linuxidc.com/Linux/2013-07/87882.htm
Puppet 利用 Nginx 多端口实现负载均衡 http://www.linuxidc.com/Linux/2013-02/79794.htm
CentOS(5 和 6)下 Puppet 的 C / S 模式实例 http://www.linuxidc.com/Linux/2011-12/50502.htm
自动化运维工具 Puppet 快速入门 http://www.linuxidc.com/Linux/2016-12/137893.htm
Puppet 的详细介绍 :请点这里
Puppet 的下载地址 :请点这里
本文永久更新链接地址 :http://www.linuxidc.com/Linux/2017-02/140932.htm