puppet工做原理:node
puppet的目的是让管理员只集中于要管理的目标,而忽略实现的细节。puppet既能够在单机上使用,也能够以C/S结构使用。在大规模使用puppet的状况下,一般使用C/S结果,在这种结构中puppet客户端只运行puppetclient,puppet服务器只运行puppetmaster。web
puppet工做流程:vim
1)客户端puppet调用facter(facter是经过ssl加密收集及检测分析客户端配置信息的一个工具),facter探测出主机的一些变量,如主机名,内存大小,ip地址等。Puppet把这些信息经过ssl链接发送到服务器器端安全
2)服务器端的puppetmaster经过facter工具分析检测客户端的主机名,而后找到项目主配置文件mainfest里面对应的node配置,并对该部份内容进行解析。Facter发送过来的信息能够做为变量处理,node牵扯到的代码才解析,其余没牵涉的代码不解析,解析分为几个阶段,首先进行语法检查,若是语法没错,就继续解析,解析的结果生成一个中间的“伪代码”,而后把伪代码发送给客户端。ruby
3)客户端接收到“伪代码”并执行,客户端把执行的结果发送给服务器。服务器
4)服务器把客户端的执行结果写入日志。ssh
puppet工做流程中如下两点值得注意:ide
1)为了保证安全,client和master之间是基于ssl和证书的,只有经master证书认证的client能够与master通讯。工具
2)Puppet会让系统保持在人们所指望的某种状态并一直维持下去,例如:检测某个文件并保证其一直存在,保证ssh服务始终开启,若是文件被删除了或者ssh服务被关闭了,puppet下次执行时(默认30分钟),会从新建立该文件或者启动ssh服务。加密
案例环境:
主机 |
操做系统 |
IP地址 |
主要软件 |
puppetmaster |
CentOS 6.5x86-64 |
192.168.1.10 |
ruby-rdoc-1.8.7.352-13.el6.x86_64 ruby-libs-1.8.7.352-13.el.x86_64 ruby-irb-1.8.7.352-13.el6.x86_64 ruby-1.8.7.352-13.el6.x86_64 puppet-2.7.21.tar.gz facter-1.7.1.tar.gz |
puppetclient1 |
CentOS 6.5x86-64 | 192.168.1.20 |
|
puppetclient2 |
CentOS 6.5x86-64 | 192.168.1.30 |
|
NTP Server |
CentOS 6.5x86-64 | 192.168.1.40 |
1.搭建NTP Server
(1)安装NTP
(2)修改配置文件
(3)启动服务,设置防火墙规则
2.搭建puppetmaster
(1)规划服务器主机名
小规模能够修改/etc/hosts文件,服务器多的时候咱们须要搭建dns服务器来实现服务经过主机名进行通讯,这里就以/etc/hosts文件来实现
(2)puppetmaster做为NTP客户端的配置
(3)安装ruby
必定安装一下前后顺序安装,先安装compat-readline5,也能够一并安装
安装完以后检查ruby版本
(4)建立用户
(5)安装facter
(6)安装puppet
复制配置文件
修改文件属性
建立puppet主目录
(7)puppet服务证书请求与签名
生产环境中iptables默认是所有关闭的
修改配置文件
在[main]标题下添加一下一行,配置服务器模块路径
启动puppet主程序
3.搭建puppetclient (注意:puppetclient2的配置过程与puppetclient1相似,主机名改成client2.itzhushou.cn便可,其余都同样)
(1)规划服务器主机名
vim /etc/sysconfig/network
vim /etc/hosts
(2)服务器时间同步
(3)安装ruby
安装完成后检查ruby版本
(4)建立用户
(5)安装facter
(6)安装puppet
复制配置文件
修改文件属性
(7)puppet服务证书请求与签名
生产环境中iptables默认是所有关闭的 service iptables stop
修改client文件
在[main]标题下添加如下一行,设置服务器的域名
申请与注册
client端:
分别在puppetclient1和puppetclient2上进行注册
此时能够按Ctrl+C结束,由于puppet一直在等待任务,可是已经从server查看到申请信息。
master端:
查看申请注册的客户端
将未注册的客户端进行注册
能够经过目录去查看已经注册的客户端
此时客户端已经完成证书的请求与签名。