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

[经验分享] 开源自动化配置管理工具Puppet入门教程 

[复制链接]

尚未签到

发表于 2018-8-3 10:26:36 | 显示全部楼层 |阅读模式
开源自动化配置管理工具Puppet入门教程  系统管理员经常陷入一系列的重复任务中:如升级软件包、管理配置文件、系统服务、cron任务以及添加新的配置、修复错误等。这些任务通常是重复低效的,解决这类任务的第一反应是让他们自动化,于是出现了定制脚本。由于环境复杂,定制脚本和应用程序一再被重复开发,并且很难适合多种平台,灵活性和功能也很难保证,于是像Puppet这样的自动化配置管理工具便出现了。  在开源世界里,有很多配置工具可供选择,这个领域一些关键的产品有:
  Puppet(http://puppet.reductivelabs.com/):
  Ruby写成的配置管理工具,使用C/S架构,使用declarative language配置客户端。
  Cfengine(http://www.cfengine.org):
  最先发布的开源配置工具之一,1993年发布,同样是C/S架构,通常应用于教育机构。
  LCFG(http://www.lcfg.org/):
  C/S架构的配置管理工具,使用XML定义配置。
  Bcfg2
  Python编写的C/S架构的配置管理工具,使用规格书和客户机响应配置目标主机。
  本文档致力于描述使用Puppet管理你的主机、应用程序、后台程序和各种服务。
  Puppet简介:
  1. Puppet的用途
  Puppet是开源的基于Ruby的系统配置管理工具,依赖于C/S的部署架构。主要开发者是Luke Kanies,遵循GPLv2版权协议。从1997年开始Kanies参与UNIX的系统管理工作,Puppet的开发源于这些经验。因为对已有的配置工具不甚满意,从2001年到2005年间,Kanies开始在Reductive实验室从事工具的开发。很快,Reductive实验室发布了他们的旗舰产品——Puppet。
  2. Pupput的特性
  许多系统配置管理工具工作的方式非常类似,如cfengine。是什么让Puppet与众不同?
  Puppet的语法允许你创建一个单独脚本,用来在你所有的目标主机上建立一个用户。所有的目标主机会依次使用适用于本地系统的语法解释和执行这个模块。举例:如果这个配置是在Red Hat服务器上执行,建立用户使用useradd命令;如果这个配置是在FreeBSD主机上执行,使用的是adduser命令。
  Puppet另一个卓越的地方是它的灵活性。源于开源软件的天性,你可以自由的获得Puppet的源码,如果你遇到问题并且有能力的话,你可以修改或者加强Puppet的代码去适用于你的环境。另外,社区开发者和捐献者还在不断增强Puppet的功能。一个大的开发者和用户社区也致力于提供Puppet的文档和技术支持。
  Puppet也是易于扩展的。定制软件包的支持功能和特殊的系统环境配置能够快速简单的添加进Puppet的安装程序中。
  3. Puppet的工作模式
  Puppet是一个C/S架构的配置管理工具,在中央服务器上安装puppet-server软件包(被称作Puppet master)。在需要管理的目标主机上安装puppet客户端软件(被称作Puppet Client)。当客户端连接上Puppet master后,定义在Puppet master上的配置文件会被编译,然后在客户端上运行。每个客户端默认每半个小时和服务器进行一次通信,确认配置信息的更新情况。如果有新的配置信息或者配置信息已经改变,配置将会被重新编译并发布到各客户端执行。也可以在服务器上主动触发一个配置信息的更新,强制各客户端进行配置。如果客户端的配置信息被改变了,它可以从服务器获得原始配置进行校正。
  4. Puppet的未来
  最后,Puppet是一个年轻的工具,仍然处于开发和发展中。Puppet社区快速壮大,并且许多新的想法不断融入,促使开发、更新和模块每天都在呈现。
  安装配置:
  1. Puppet在RedHat/CentOS系统上安装
  Puppet是基于Ruby写成的,所以安装前要准备好Ruby环境。在中心的Server上安装puppet-server包,并运行puppetmasterd进程;在被管理机上安装puppet包,并运行puppetd进程。另外,在每台主机上配置好自己的hostname,之后每台机器要以hostname区分。
  1). 安装ruby环境:
  yum install ruby ruby-rdoc
  复制代码
  2). 安装puppet
  Server端安装:
  rpm -Uvh http://download.fedora.redhat.com/pub/epel/5/i386/epel-release-5-3.noarch.rpm
  yum install puppet-server
  chkconfig –level 2345 puppetmaster on
  复制代码
  修改hosts,添加下面行:
  Vi /etc/hosts
  172.16.228.30 puppet.sina.com.cn puppet
  172.16.228.29 web1.sina.com.cn web1
  复制代码
  客户端安装:
  rpm -Uvh http://download.fedora.redhat.com/pub/epel/5/i386/epel-release-5-3.noarch.rpm
  yum install puppet
  chkconfig –level 2345 puppet on
  复制代码
  修改hosts,添加下面行:
  Vi /etc/hosts
  172.16.228.30 puppet.sina.com.cn puppet
  172.16.228.29 web1.sina.com.cn web1
  复制代码
  3). 启动puppet
  Server端首次运行前,编辑/etc/puppet/manifests/site.pp文件,内容可以用最基本的:
  # Create “/tmp/testfile” if it doesn’t exist.
  class test_class {
  file { “/tmp/testfile”:
  ensure => present,
  mode => 644,
  owner => root,
  group => root
  }
  }

  # tell puppet on which client to run the>  node web1.sina.com.cn {
  include test_class
  }
  复制代码
  启动Server端:
  service puppetmaster start
  复制代码
  启动客户端:
  /etc/init.d/puppet once -v
  复制代码
  这时客户机会去连server,但是由于连接是在ssl上的,而Server还没有sign过客户端的cert,客户机被断开。
  到Server端执行:puppetca -list,会显示等待签名的客户端的主机名,执行:puppetca -sign <客户端主机名> 即可为其签名。
  在Server端为web1.sian.com.cn授权:
  puppetca -list
  web1.sian.com.cn
  puppetca -sign web1.sian.com.cn
  复制代码
  这时再到客户机上启动puppetd,即可看到客户在正常地连接server,并且应用Server上为客户端定制的配置策略。
  启动客户端:
  /etc/init.d/puppet once -v
  复制代码
  4). 测试:
  也可以将日志直接打印到终端上进行测试:
  Server端:puppetmasterd -d –no-daemonize -v –trace
  客户端:puppetd –test –trace –debug
  2. puppet配置文件
  主配置文件(puppet.conf):
  1). 配置文件命名空间:
  main 通用配置选项
  puppetd 客户端配置选项
  puppetmasterd 服务端配置选项
  2). main命名空间选项:
  confdir 配置文件目录,默认在/etc/puppet
  vardir 动态数据目录,默认在/var/lib/puppet
  logdir 日志目录,默认在/var/log/log
  rundir puppet PID目录,默认在/var/run/puppet
  statedir state目录,默认在$vardir/state
  statefile state文件,默认在$statedir/state.yaml
  ssldir SSL证书目录,默认在$vardir/ssl
  trace 发生错误时显示跟踪信息,默认false
  filetimeout 检测配置文件状态改变的时间周期,单位秒,默认15秒
  syslogfacility 指定syslog功能为user级,默认为daemon级
  3). puppetmasterd命名空间选项:
  user 后台进程执行的用户
  group 后台进程执行的组
  mainfestdir mainfests文件存储目录,默认为$confdir/mainfests
  mainfest mainfest站点文件的名字,默认为site.pp
  bindaddress 后台进程绑定的网卡地址接口
  masterport 后台进程执行的端口,默认为8140
  4). puppet命名空间选项:
  server puppet puppet服务器名,默认为puppet
  runinterval seconds puppet应用配置的时间间隔,默认1800秒(0.5小时)
  puppetdlockfie file puppet lock文件位置,默认$statedir/puppetdlock
  puppetport port 后台进程执行的端口,默认8139
  文件服务配置文件(fileserver.conf):
  [files]
  path /var/lib/puppet/files
  allow 121.14.1.*
  allow 60.28.228.0/24
  allow *.house.sina.com.cn
  deny *.sina.com.cn
  复制代码
  path定义文件存放路径,通过allow/deny来控制访问权限。
  3. puppet命令集
  1). puppet 用于执行用户所写独立的mainfests文件
  # puppet -l /tmp/manifest.log manifest.pp
  复制代码
  2). puppetd 运行在被管理主机上的客户端程序
  # puppetd –server puppet.leju.com
  复制代码
  3). puppetmasterd 运行在管理机上的服务器程序
  # puppetmasterd
  复制代码
  4). puppetca puppet认证程序
  # puppetca -l
  pclient.leju.com
  # puppetca -s pclient.leju.com
  复制代码
  5). puppetrun 用于连接客户端,强制运行本地配置文件
  # puppetrun -p 10 –host host1 –host host2 -t remotefile -t webserver
  复制代码
  6). filebucket 客户端用于发送文件到puppet file bucket的工具
  # filebucket -b /tmp/filebucket /my/file
  复制代码
  7). ralsh 转换配置信息到puppet配置代码
  # ralsh user luke
  user { ‘luke’:
  home => ‘/home/luke’,
  uid => ‘100′,
  ensure => ‘present’,
  comment => ‘Luke Kanies,,,’,
  gid => ‘1000′,
  shell => ‘/bin/bash’,
  groups => ['sysadmin','audio','video','puppet']
  }
  复制代码
  8). puppetdoc 打印puppet参考文档
  # puppetdoc -r type > /tmp/type_reference.rst
  # puppetdoc –outputdir /tmp/rdoc –mode rdoc /path/to/manifests
  # puppetdoc /etc/puppet/manifests/site.pp
  复制代码

运维网声明 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-545759-1-1.html 上篇帖子: Puppet笔记:介绍及基本用法 下篇帖子: 开源自动化配置管理工具Puppet安装
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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