运维自动化之puppet基础知识介绍
puppet,这是目前运维主流的运维自动化工具,大多数运维管理人员都听说过,或者在使用以及在正在考虑使用中。puppet可以配合cobbler,puppet也可以配合func 实现运维自动化,简单化,化繁杂为简单。
【puppet基础导读】
puppet,这是目前运维主流的运维自动化工具,大多数运维管理人员都听说过,或者在使用以及在正在考虑使用中。puppet可以配合cobbler,puppet也可以配合func实现运维自动化,简单化,化繁杂为简单。
1.什么是puppet
puppet是一种Linux、Unix平台的集中配置管理系统,使用ruby语言,可管理配置文件、用户、cron任务、软件包、系统服务等。puppet把这些系统实体称之为资源,puppet的设计目标是简化对这些资源的管理以及妥善处理资源间的依赖关系。
2.puppet的语法
由于puppet是由ruby写的,因此如ruby语法非常相近,关于ruby的介绍:请参阅http://ruby-lang.org
3.如何获得puppet模块
puppet实验室提供下载:http://projects.puppetlabs.com/projects/1/wiki/Downloading_Puppet
4.puppet能管理哪些资源:
puppet介绍里有写过,他能管理file(文件),user(用户),group(组),package(软件包),mount(挂载),schedule和cron(计划任务),service(服务),tidy(清理),yumrepo(yum仓库),sshkey(ssh认证)等常用资源。
5.puppet如何安装,配置。
1.Puppet在RedHat/CentOS系统上安装
1).安装ruby环境:yuminstallrubyruby-rdoc
2).安装puppet:yum-yinstallpuppetpuppet-server
6.Puppet的工作模式
Puppet是一个C/S架构的配置管理工具,在中央服务器上安装puppet-server软件包(被称作Puppetmaster)。在需要管理的目标主机上安装puppet客户端软件(被称作PuppetClient)。当客户端连接上Puppetmaster后,定义在Puppetmaster上的配置文件会被编译,然后在客户端上运行。每个客户端默认每半个小时和服务器进行一次通信,确认配置信息的更新情况。如果有新的配置信息或者配置信息已经改变,配置将会被重新编译并发布到各客户端执行。也可以在服务器上主动触发一个配置信息的更新,强制各客户端进行配置。如果客户端的配置信息被改变了,它可以从服务器获得原始配置进行校正。
7.puppet配置文件介绍
主配置文件(puppet.conf):
1).配置文件命名空间:
- main通用配置选项
- puppetd客户端配置选项
- puppetmasterd服务端配置选项
2).main命名空间选项:
- confdir配置文件目录,默认在/etc/puppet
- vardir动态数据目录,默认在/var/lib/puppet
- logdir日志目录,默认在/var/log/log
- rundirpuppetPID目录,默认在/var/run/puppet
- statedirstate目录,默认在$vardir/state
- statefilestate文件,默认在$statedir/state.yaml
- ssldirSSL证书目录,默认在$vardir/ssl
- trace发生错误时显示跟踪信息,默认false
- filetimeout检测配置文件状态改变的时间周期,单位秒,默认15秒
- syslogfacility指定syslog功能为user级,默认为daemon级
3).puppetmasterd命名空间选项:
- user后台进程执行的用户
- group后台进程执行的组
- mainfestdirmainfests文件存储目录,默认为$confdir/mainfests
- mainfestmainfest站点文件的名字,默认为site.pp
- bindaddress后台进程绑定的网卡地址接口
- masterport后台进程执行的端口,默认为8140
4).puppet命名空间选项:
- serverpuppetpuppet服务器名,默认为puppet
- runintervalsecondspuppet应用配置的时间间隔,默认1800秒(0.5小时)
- puppetdlockfiefilepuppetlock文件位置,默认$statedir/puppetdlock
- puppetportport后台进程执行的端口,默认8139
- 文件服务配置文件(fileserver.conf):
[files] path/var/lib/puppet/files allow192.168.1.* allow*.test.com deny*.example.com
path定义文件存放路径,通过allow/deny来控制访问权限。
8.puppet命令集
1).puppet用于执行用户所写独立的mainfests文件
#puppet-l/tmp/manifest.logmanifest.pp
2).puppetd运行在被管理主机上的客户端程序
#puppetd–serverpuppet
3).puppetmasterd运行在管理机上的服务器程序
#puppetmasterd
4).puppetcapuppet认证程序
#puppetca-l test1.test.com +test2.test.com #puppetca-stest1.test.com##给test1.test.com签名
5).puppetrun用于连接客户端,强制运行本地配置文件
#puppetrun-p10–hosthost1–hosthost2-tremotefile-twebserver
6).filebucket客户端用于发送文件到puppetfilebucket的工具
#filebucket-b/tmp/filebucket/my/file
7).ralsh转换配置信息到puppet配置代码
#ralshusersky
【puppet基础总结】
puppet基础知识是学习puppet的必经之路,puppet有更多,更好,更强大的功能等待着各位去发现。尤其后面如果要自定义函数,或者深入puppet的话,需要了解下ruby的基本语法。配合ruby可以使系统管理变得更轻松。
相关推荐
Puppet 运维自动化章节目录 ...9. Puppet基础知识介绍-《开源软件架构》翻译 10. puppet开源自动化配置管理平台介绍 11. puppet网址资源汇总方便查询(不断更新中) 12. puppet3.x 新特性介绍
企业自动化运维工具Puppet实战演练操作文档,供你借鉴学习。
2.运维自动化工具对比 - puppet vs cfengine - puppet vs chef 3.puppet 使用时注意事项 4.puppet 应用案例 -puppet 管理用户 -puppet nginx 管理 -puppet kick 介绍 -puppet MCollective 介绍 - puppet func...
自动化运维工具puppet--------------------------------------------------------------------
运维 puppet工具讲解,很详细 运维 puppet工具讲解,很详细
Puppet给运维带来的变革
puppet是一种Linux、Unix、windows平台的集中配置管理系统,使用自有的puppet描述语言,可管理配置文件、用户...puppet把这些系统实体称之为资源,puppet的设计目标是简化对这些资源的管理以及妥善处理资源间的依赖关系
2012华东运维技术大会的资料--运维自动化-Puppet应用与架构
XX华东运维技术大会的资料运维自动化Puppet应用与.ppt
云计算中心->Puppet运维自动化方案介绍
puppet的自动化配置的工作流程、数据流向、原理,以及配置过程,主要对自动化配置工具的介绍
XXXX华东运维技术大会的资料--运维自动化-Puppet应用与.pptx
本书针对具备Linux 基础的人群,主要介绍了缓存代理、高性能内存对象援存Memcached 、分布式文件服务、大型网站架构、自动化运维的相关知识与应用,以企业级 的实战项目案例,使读者能够掌握应用运维的工作内容。...
自动化运维之 Puppet 实战.docx
本文详细介绍了ansible puppet saltstack三款自动化运维工具的对比 本资料共包含以下附件: ansible puppet saltstack三款自动化运维工具的对比.docx
大家好,这些年来,我经历了不同形态的业务和不同规模的运维,今天我主要和大家分享我这些年来关于运维自动化的一些认识和实践,包括如下八点:自动化需要整体规划自动化的基础是标准化首先从持续交付开始DevOps的四...
puppet开源自动化配置管理平台介绍
服务器自动化运维管理方案,特别适合中小互联网企业的运维工程师。
ansible是新出现的自动化运维工具,基于Python开发,集合了众多运维工具(puppet、cfengine、chef、func、fabric)的优点,实现了批量系统配置、批量程序部署、批量运行命令等功能