设为首页 收藏本站
查看: 1088|回复: 0

[经验分享] Puppet集中配置管理系统安装与配置

[复制链接]

尚未签到

发表于 2018-8-3 06:00:24 | 显示全部楼层 |阅读模式
  一、什么是puppet?
  1、基于ruby语言开发的系统配置集中管理工具,跨平台
  2、一个C/S架构,配置服务端和客户端
  puppet依赖于ruby与facter,安装puppet3.x,需要ruby1.8.7版本及以上;facter是一个系统盘点工具,收集主机的一些资料,比如OS、IP、CPU等
  3、puppet是一个C/S结构,开源软件,基于Ruby的系统配置管理工具,安装puppet3.x,需要ruby1.8.7版本及以上
  4、默认情况下,客户端每隔30分钟连接一次puppet服务端
  5、能管理多达40种资源,例如:file、user、cron、package、yum等,适合整个软件的生命周期管理
  二、环境介绍
  1、拓扑图
DSC0000.jpg

  2、下载
  操作系统RHEL6.3 x64
  facter下载: https://downloads.puppetlabs.com/facter/
  puppet下载: https://downloads.puppetlabs.com/puppet/
  3、puppetmaster与puppetclient可以相互解析
  vi /etc/hosts
  192.168.0.200 puppetmaster.com
  192.168.0.201 puppetclient1.com
  4、puppet服务端与客户端时间同步
  yum install ntp -y
  service ntpd start
  ntpdate pool.ntp.org #同步时间
  clock -w #将时间写入硬件
  chkconfig ntpd on
  三、安装服务端puppet
  1、安装ruby环境
[root@puppetmaster ~]# yum install -y ruby ruby-libs ruby-shadow  2、安装facter
[root@puppetmaster ~]# tar zxvf facter-1.7.3.tar.gz  
[root@puppetclient1 ~]# cd facter-1.7.3
  
[root@puppetmaster facter-1.7.3]# ruby install.rb
  3、安装配置puppet
[root@puppetmaster puppet-3.3.1]# useradd -s /sbin/nologin puppet  
[root@puppetmaster ~]# tar zxvf puppet-3.3.1.tar.gz
  
[root@puppetclient1 ~]# cd puppet-3.3.1
  
[root@puppetclient1 puppet-3.3.1]# ruby install.rb
  
[root@puppetmaster puppet-3.3.1]# cp ext/redhat/puppet.conf /etc/puppet/
  
[root@puppetmaster puppet-3.3.1]# cp ext/redhat/server.init /etc/init.d/puppetmaster
  
[root@puppetmaster puppet-3.3.1]# chmod +x /etc/init.d/puppetmaster
[root@puppetmaster ~]# vi /etc/puppet/puppet.conf  
[main]  #在main里面添加puppet服务端主机名
  
server = puppetmaster.com
[root@puppetmaster puppet-3.3.1]# chkconfig --add puppetmaster  
[root@puppetmaster puppet-3.3.1]# chkconfig puppetmaster on
  
[root@puppetmaster puppet-3.3.1]# service puppetmaster start
  四、安装客户端puppet agent
  1、安装ruby环境
[root@puppetclient1 ~]# yum install -y ruby ruby-libs ruby-shadow  2、安装facter
[root@puppetclient1 ~]# tar zxvf facter-1.7.3.tar.gz  
[root@puppetclient1 ~]# cd facter-1.7.3
  
[root@puppetclient1 facter-1.7.3]# ruby install.rb
  3、安装配置puppet
[root@puppetclient1 puppet-3.3.1]# useradd -s /sbin/nologin puppet  
[root@puppetclient1 ~]# tar zxvf puppet-3.3.1.tar.gz
  
[root@puppetclient1 puppet-3.3.1]# ruby install.rb
  
[root@puppetclient1 puppet-3.3.1]# cp ext/redhat/puppet.conf /etc/puppet/puppet.conf
  
[root@puppetclient1 puppet-3.3.1]# cp ext/redhat/client.init /etc/init.d/puppet
  
[root@puppetclient1 puppet-3.3.1]# chmod +x /etc/init.d/puppet
[root@puppetclient1 ~]# vi /etc/puppet/puppet.conf  
[main]  #在main里面添加puppet服务端主机名
  
server = puppetmaster.com
[root@puppetclient1 puppet-3.3.1]# chkconfig --add puppet  
[root@puppetclient1 puppet-3.3.1]# chkconfig puppet on
  
[root@puppetclient1 puppet-3.3.1]# service puppet start
  
[root@puppetclient1 puppet-3.3.1]# netstat -tupln | grep 8140
  五、配置签名证书
  1、客户端创建证书注册请求
[root@puppetclient1 ~]# puppet agent --test  
Info: Creating a new SSL key for puppetclient1.com
  
Info: Caching certificate for ca
  
Info: Creating a new SSL certificate request for puppetclient1.com
  
Info: Certificate Request fingerprint (SHA256): 7E:10:48:3F:3C:D4:13:BA:BF:66:ED:86:52:92:19:05:1E:D2:3A:CD:06:67:27:80:60:D6:54:66:0E:33:F7:C7
  
Exiting; no certificate found and waitforcert is disabled
  2、服务端查看证书注册请求
[root@puppetmaster ~]# puppet cert list  #加--all查看所有  
  "puppetclient1.com"     (SHA256) 7E:10:48:3F:3C:D4:13:BA:BF:66:ED:86:52:92:19:05:1E:D2:3A:CD:06:67:27:80:60:D6:54:66:0E:33:F7:C7
  
  "puppetclient1.com.com" (SHA256) 46:B6:95:A6:1B:6A:FD:83:E4:1C:72:D4:5C:3C:B5:EF:3D:F7:43:2C:09:CF:00:B8:44:18:E4:3E:B3:DC:6F:FD
  3、服务端受理客户端证书注册请求
[root@puppetmaster ~]# puppet cert sign puppetclient1.com  #主机名改为--all,是受理所有  
Notice: Signed certificate request for puppetclient1.com
  
Notice: Removing file Puppet::SSL::CertificateRequest puppetclient1.com at '/var/lib/puppet/ssl/ca/requests/puppetclient1.com.pem'
  4、客户端确认是否证书注册成功
[root@puppetclient1 ~]# puppet agent --test  如果出现以下报错,则在客户端puppet.conf配置文件[main]里面添加pluginsync=false,再重启!
Error: /File[/var/lib/puppet/lib]: Could not evaluate: Could not retrieve information from environment production source(s) puppet://puppetmaster.com/plugins  5、想清除证书使用
[root@puppetmaster ~]# puppet cert clean puppetclient1.com  六、简单测试
  1、服务端编写配置
  
  
  
  
  
[root@puppetmaster ~]# vi /etc/puppet/manifests/site.pp #修改后立即,无需重启  
node 'puppetclient1.com' {      #指定某台,也可以不写为所有
  
file { "/tmp/test.txt":
  
            content=> "hello,puppet test\n";
  
            #source=> "puppet://$puppetserver/files/httpd.conf"
  
            #也可以这样分发一个配置文件
  
    }
  
}
  注:file是一个资源管理关键字,用来管理文件的,还有package软件包管理,service管理系统服务,exec执行shell命令,/tmp/test.txt是创建文件名字,content定义文件内容
  2、客户端默认30分钟与服务端同步配置文件,所以我们手动执行,也可以修改puppet.conf更改默认时间,添加runinterval=600,设置为10分钟同步一次
[root@puppetclient1 ~]# puppet agent --test  
[root@puppetclient1 ~]# ls /tmp/
  
test.txt
  至此,Puppet系统安装配置完成!

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-545523-1-1.html 上篇帖子: 通过MCollective更加安全地实现puppet的推送更新功能 下篇帖子: MCollective结合自定义facter对puppet节点进行分类触发操作
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表