自动化部署工具PUPPET介绍

简介:

一、Puppet概述

Puppet是开源的基于Ruby的系统配置管理工具,基于C/S的部署架构。是一个为实现数据中心自动化管理而设计的配置管理软件,它使用跨平台语言规范,管理配置文件、用户、软件包、系统服务等。客户端默认每隔半小时会和服务器通信一次,确认是否有更新。当然也可以配置主动触发来强制客户端更新。这样就把日常的系统管理任务代码化了,代码化的好处是可以分享,保存,避免重复劳动,也可以快速恢复以及快速的大规模部署服务器。

 

二、Puppet构架

puppet的服务器端保存着所有的对客户端服务器的配置代码,在puppet里面叫做manifest. 客户端下载manifest之后,可以根据manifest对服务器进行配置,例如软件包管理,用户管理和文件管理等等。Puppet架构如下:

三、应用场景

统一安装、配置管理软件

统一配置系统优化参数

定期检测服务是否运行

快速替换集群时设备的角色

四、Puppet工作原理

 

流程简述如下:

1、客户端puppetd向master发起认证请求。

2、Puppet Master告诉client是合法的。

3、客户端puppetd开始调用facter,facter可以探测出主机的一些变量,例如主机名,内存大小,IP地址等。pupppetd 把这些信息通过ssl连接发送到服务器端。

4、服务器端的puppet Master 检测客户端的主机名,然后找到manifest里面对应的node配置, 并对该部分内容进行解析,解析分为几个阶段,语法检查,如果语法错误就报错。如果语法没错,就继续解析,解析的结果会生成一个中间的“伪代码”(catalog),然后把伪代码发给客户端。

5、客户端接收到“伪代码”,并且执行。

6、客户端在执行时判断有没有file文件,如果有就向Fileserver发起请求。

7、客户端继续判断有没有配置Report。如果配置,就把执行结果发送给服务器。

8、服务器端把客户端的执行结果写入日志。并可以发送给报告系统(DashBoard)

五、Puppet组织结构

Puppet的目录结构描述如下:

|-- puppet.conf            # 主配置配置文件 

 |-- fileserver.conf         #文件服务器配置文件 

 |-- auth.conf             #认证配置文件  (只允许域内认证)

 |-- autosign.conf          #自动验证配置文件 

 |-- tagmail.conf          # 邮件配置文件(将错误信息发送) 

 |-- manifests       # 文件存储目录(puppet会先读取该目录的.pp文件<site.pp>) 

 |-- nodes 

 | |  | puppetclient.pp   #puppet解析主配置文件所有的模块和节点都在此文件里include

 | |-- site.pp              # 定义puppet相关的变量和默认配置

 | |-- modules.pp        # 加载class类模块文件(include nginx)

 |--  modules          # 定义模块

 | --nginx             # 以nginx为例 

 |           |--  file

 |           |--  manifests

 |           |     |-- init.pp       #类的定义,类名必须与模块名相同

 |           |--- templates    # 模块配置目录,可以被模块的manifests引用 

 |           |     |-- nginx.erb #erb模板

六、Puppet Dashboard

Puppet Dashboard可以为Puppet环境添加一个图形用户界面(GUI)。Puppet Dashboard可以显示主机上Puppet的运行结果,并且可以提供一个节点分类工具来配置主机。

可以从https://downloads.puppetlabs.com/dashboard/下载puppet-dashboard,安装后的截图如下:

七、Puppet LoadBlancer

当需要部署的服务器越来越多(超过1000台)时,Puppet Master解析工作将非常繁重,同时文件分发也将成为瓶颈,再加上很多的Client需要做CA认证,单台Puppet将无法满足需求,此时就需要对Puppet做LoadBlancer,建议采用的方式是通过Nginx做负载分配,典型的Puppet集群架构如下:

构架说明:

1、 nginx监听port 8140端口,将除文件下发之外的请求,代理转发给下面的三个puppet Master任意一个,实现负载均衡。

2、 每个puppet Master运行在18140端口,提供配置管理。

3、 CA认证系统从puppet Master独立出来,也运行在18140端口,用两台服务器做HA,实现高可用。
















本文转自南非蚂蚁51CTO博客,原文链接:http://blog.51cto.com/ixdba/1149055 ,如需转载请自行联系原作者


相关文章
|
4月前
|
运维 Prometheus 监控
3 年部署经验总结:用自动化工具轻松管理 300+ 服务器开源软件
三年前接手公司IT部门时,我满怀信心,却发现部署效率低下。尽管使用了GitLab、Jenkins、Zabbix等100+开源工具,部署仍耗时费力。文档厚重如百科,却难解实际困境。一次凌晨三点的加班让我下定决心改变现状。偶然看到一篇国外博客,介绍了自动化部署的高效方式,我深受启发。
226 0
|
3月前
|
机器学习/深度学习 人工智能 测试技术
EdgeMark:嵌入式人工智能工具的自动化与基准测试系统——论文阅读
EdgeMark是一个面向嵌入式AI的自动化部署与基准测试系统,支持TensorFlow Lite Micro、Edge Impulse等主流工具,通过模块化架构实现模型生成、优化、转换与部署全流程自动化,并提供跨平台性能对比,助力开发者在资源受限设备上高效选择与部署AI模型。
406 9
EdgeMark:嵌入式人工智能工具的自动化与基准测试系统——论文阅读
|
2月前
|
人工智能 搜索推荐 UED
一个牛逼的国产AI自动化工具,开源了 !
AiPy是国产开源AI工具,结合大语言模型与Python,支持本地部署。用户只需用自然语言描述需求,即可自动生成并执行代码,轻松实现数据分析、清洗、可视化等任务,零基础也能玩转编程,被誉为程序员的智能助手。
|
3月前
|
Java 测试技术 API
自动化测试工具集成及实践
自动化测试用例的覆盖度及关键点最佳实践、自动化测试工具、集成方法、自动化脚本编写等(兼容多语言(Java、Python、Go、C++、C#等)、多框架(Spring、React、Vue等))
195 6
|
4月前
|
人工智能 数据可视化 数据挖掘
团队日报不用愁!自动化生成工具亲测:任务进度实时同步
本文深入分析了传统手动日报在数据孤岛、格式混乱和时效性差三大痛点,并探讨了自动化日报带来的效率提升、决策优化等四大核心价值。通过对板栗看板、SmartBrief、n8n 等六款主流工具的功能、适用场景及实战效果进行测评,为企业提供科学的选型建议与实施路径。
团队日报不用愁!自动化生成工具亲测:任务进度实时同步
|
2月前
|
人工智能 缓存 自然语言处理
86_自动化提示:AutoPrompt工具
在当今人工智能领域,提示工程(Prompt Engineering)已成为释放大语言模型(LLM)潜能的关键技术。随着LLM规模和能力的不断增长,如何设计高效、精确的提示词成为研究和应用的焦点。然而,传统的手工提示工程面临着巨大挑战
|
4月前
|
人工智能 供应链 数据可视化
工作流梳理工具实战教程:手把手教你绘制第一张自动化流程图
本文剖析了团队因流程混乱导致重复劳动和效率低下的问题,提出通过工作流梳理提升协作效率的解决方案。总结了流程梳理的六大核心需求,并深度测评了6款主流工具,国内有板栗看板那,国外有kiss flow结合团队规模与需求提供选型建议,助力企业高效落地流程优化。
|
3月前
|
安全 搜索推荐 机器人
风险规则引擎-RPA 作为自动化依赖业务决策流程的强大工具
机器人流程自动化(RPA)是一种通过软件“机器人”自动执行重复性任务的技术,能大幅提升工作效率。它适用于财务、电商等领域的标准化流程,如账单处理和退货管理。然而,RPA在复杂决策场景中存在局限,需结合决策模型(DMN)和业务规则管理系统(BRMS)实现流程与决策的协同自动化,从而增强灵活性与业务价值。
|
4月前
|
数据采集 运维 监控
|
数据采集 人工智能 机器人
RPA与爬虫:自动化工具的本质差异与选择指南
本文深入解析RPA与爬虫的本质差异,帮助企业根据业务需求明智选型。RPA侧重内部流程自动化,爬虫专注外部数据采集。内容涵盖技术原理、应用场景、优劣势对比及主流RPA工具介绍,助力把握自动化趋势,提升效率。
1160 0

推荐镜像

更多