前言:到目前为止,我们已经搭建了很多的服务器,每一台服务器都需要执行很多的命令,给我的感觉是实验不难,原理也好理解,就是命令太麻烦。如果只管理几台服务器,命令多点也没什么,但是如果管理着成百上千台服务器,可以想象一下,工作量将是多么的庞大。所以作为一名运维工程师,就需要寻找一款能够降低工作量的工具。那么今天就给大家介绍一批工具,这批工具是“可编程”的,只需要为这批工具写上几行代码,它便会自动完成所有的工作,这批工具就是运维自动化puppet(为什么说是一批工具,因为软件不止一个)。Puppet可以针对多台服务器进行统一的操作,例如:软件分发,统一执行脚本,在服务器上写好脚本分发给客户机,客户机就会自动执行,减少了人力及误操作风险。Puppet与我们之前在windows2008R2中学习过的“组策略”非常相似,所以在windows中有的功能,在linux中都能找到这些功能的影子。

一、工作原理和案例环境

1、工作原理
Puppet的目的是让管理员只集中于要管理的目标,而忽略实现的细节。Puppet既可以在单机上使用,也可以c/s使用,在大规模使用puppet的情况下,通常使用c/s结构,在这种结构中puppet客户端只运行puppetclient,puppet服务器只运行puppetmaster。

2、工作流程
1)客户端puppet调用facter(facter是通过ssl加密收集及检测分析客户端配置信息的一个工具),facter探测出主机的一些变量,如主机名,内存大小,ip地址等。Puppet把这些信息通过ssl连接发送到服务器器端
2)服务器端的puppetmaster通过facter工具分析检测客户端的主机名,然后找到项目主配置文件mainfest里面对应的node配置,并对该部分内容进行解析。Facter发送过来的信息可以作为变量处理,node牵扯到的代码才解析,其他没牵涉的代码不解析,解析分为几个阶段,首先进行语法检查,如果语法没错,就继续解析,解析的结果生成一个中间的“伪代码”,然后把伪代码发送给客户端。
3)客户端接收到伪代码,并执行,客户端把执行的结果发送给服务器。
4)服务器把客户端的执行结果写入日志。

Puppet工作过程有以下两点值得注意:
1)为了保证安全,client和master之间是基于ssl和证书的,只有经master证书认证的client可以与master通信。
2)Puppet会让系统保持在人们所期望的某种状态并一直维持下去,例如:检测某个文件并保证其一直存在,保证ssh服务始终开启,如果文件被删除了或者ssh服务被关闭了,puppet下次执行时(默认30分钟),会重新创建该文件或者启动ssh服务。

3、案例环境

虚拟机环境

二、安装puppet的实验步骤

搭建puppetmaster
搭建puppetclient
配置测试节点
客户端主动拉取
服务器推送

1、搭建puppetmaster
1)规划服务器主机名(小规模可以修改/etc/hosts文件,服务器多的时候我们需要搭建dns服务器来实现服务通过主机名进行通信,这里就以/etc/hosts文件来实现)
Vi /etc/sysconfig/network

2)搭建NTP服务器(前面已经提到过facter使用证书与puppetmaster验证身份,所以一定要确保puppetclient与puppetmaster时间保持一致,需要单独准备一台时间服务器来提供时间同步)
搭建NTP服务器

启动ntp服务并开启iptables例外

三、应用案例

1、配置一个测试节点
节点信息:/etc/puppet/manifests/nodes
模块信息: /etc/pupppet/modules

实验目标:为了保护linux的ssh端×××破,批量修改客户端的sshd端口,将22号端口改为9922,并实现重启sshd服务的工作。

想完成以上几点,需要明确几点:
①需确定openssh软件包安装
②需确定存在ssh的配置文件
③确定sshd的服务是系统服务
创建ssh模块,模块的目录为ssh,模块下有三个文件分别是:manifests、templates、files。
manifest里面必须包含一个init.pp文件,这是该模块的的初始(入口)文件,导入一个模块的时候需要从init.pp开始执行,可以把所有的代码都写入到这个文件中,也可以分成多个.pp文件,init在去包含其他文件,定义class类名时必须是ssh,这样才能实现调动
files目录是该模块的发布目录,puppet提供了一个文件分割机制,类似rsync的模块。
templates目录包含erb模块文件、这个和file资源的templates属性有关(很少使用)
master端!

转载于:https://blog.51cto.com/982439641/2093090

Puppet部署与应用相关推荐

  1. Puppet 部署tomcat

     Puppet 部署tomcat Tomcat运行需要java环境,所以需要同时安装tomcat和java, 相对应的puppet也需要编写两个模块 tomcat 和java(puppet一般以模块的 ...

  2. 自动化puppet部署

    puppet系统部署: 1.1.测试环境: server_master: centos7.8 server_slave: centos7.8 软件环境: puppet:3.8.7 1.2.Puppet ...

  3. puppet部署mysql_puppet之mysql批量安装案例

    上次简单介绍了利用puppet批量安装java的案例,这次来说说puppet自动化安装mysql.前提是配置好了puppet的服务端和客户端,puppet安装配置参考blog http://space ...

  4. puppet企业架构部署

    一直在准备上puppet,这两天看了下puppet文档,模拟了下生产环境下puppet部署方案:测试机器: server: 192.168.3.68 clinet: 192.168.3.67命令规则: ...

  5. Puppet安装部署篇(一)

    Puppet的安装部署,后续使用下面三台机器演示,为了演示效果主机名也采用idc+用途来表示. 192.168.30.134  puppet  Puppet Server端 192.168.30.13 ...

  6. puppet java_Puppet 部署tomcat

    Puppet部署tomcat Tomcat运行需要java环境,所以需要同时安装tomcat和java, 相对应的puppet也需要编写两个模块 tomcat 和java(puppet一般以模块的形式 ...

  7. Openstack部署工具

    Openstack发展很猛,很多朋友都很认同,2013年,会很好的解决OpenStack部署的问题,让安装,配置变得更加简单易用. 很多公司都投入人力去做这个,新浪也计划做一个Openstack的is ...

  8. Puppet基础篇7-编写第一个完整测试模块puppet

    Puppet基础篇7-编写第一个完整测试模块puppet 零基础学习Puppet自动化配置管理系列文档 将Puppet部署到生产中第一个要编写的模块就是puppet本身,虽然puppet可以运行其它所 ...

  9. puppet ssh模块

    转载:http://blog.51cto.com/ywzhou/1577502 作用:通过SSH模块管理客户端的ssh远程服务,并用key认证方式替代密码认证方式,提高安全性: 本例分两阶段,首先是s ...

最新文章

  1. 基于Xcode安装CocoaPods报错
  2. selenium+python中,框架中,怎么返回上一个菜单
  3. ubuntu19.10安装thrift
  4. css 一些 常用布局
  5. SSH框架之Spring4专题3:Spring与AOP
  6. 转载:linux驱动层到应用层的重要接口sys文件系统---/sys目录详解
  7. 《马克思主义哲学原理》考点知识串讲-自考
  8. oracle库sql根据拼音查汉字,根据拼音首字母模糊查询数据库中文字段
  9. java与数据库连接odbc_详解java数据库连接之JDBC-ODBC桥连方式
  10. chrome 如何官网下载谷歌浏览器离线安装包
  11. 使用python显示图像在windows图片查看器中一直显示加载中就是打不开的解决途径
  12. no valid sudoers sources found, quitting ubuntu 16.04 devstack
  13. HCIA STP的端口状态与BPDU
  14. Android 音视频开发(二):使用 AudioRecord 采集音频PCM并保存到文件(学习笔记)
  15. Glib基础——版本信息
  16. Excel PivotTable 使用心得手顺分享(三)
  17. 《腾云-云计算和大数据时代网络技术揭秘》的收获与分享
  18. 2021-2027全球与中国GPU服务器市场现状及未来发展趋势
  19. 远行星号 java_不纠结刷种子了,duzahk.java里面直接加了点东西。
  20. Zookeeper学习提纲:助你一臂之力

热门文章

  1. CentOS7 图形界面中文乱码
  2. VMware Workstation提示和Device/Credential Guard 不兼容
  3. 2022年MathorCup数学建模C题自动泊车问题解题全过程文档加程序
  4. mesh路由器哪个品牌好(无线mesh组网推荐路由器)
  5. 【数据挖掘】pandas使用手册
  6. Firefox上 SourceForge 的代理服务器
  7. 【七-2】终身学习 Life Long Learning - catasrophic forgetting
  8. Linux下Hive-1.2.2安装
  9. easyx图形库----贴图
  10. 在autodl中的linux中,安装libjpeg-turbo