CentOS 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 学习一:安装及简单实例应用

Puppet学习二:简单模块配置和应用

相关阅读:

有关Puppet agent端三种备份恢复方案探讨研究
选择更安全的方式注册你的Puppet节点
通过配置SSH深刻理解Puppet的语法及工作机制
Puppet利用Nginx多端口实现负载均衡
CentOS(5和6)下Puppet的C/S模式实例
自动化运维工具Puppet 快速入门 

Puppet 的详细介绍请点这里
Puppet 的下载地址请点这里

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/738fbf6d28326b1531a60f4e013345af.html