puppet工简介一
puppet简介一
puppet工作原理
puppet 是一个配置管理工具, 典型的, puppet 是一个 C/S 结构, 当然,这里的 C 可以有很多,因
此,也可以说是一个星型结构. 所有的 puppet 客户端同一个服务器端的 puppet 通讯. 每个
puppet 客户端每半小时(可以设置)连接一次服务器端, 下载最新的配置文件,并且严格按照配
置文件来配置服务器. 配置完成以后,puppet 客户端可以反馈给服务器端一个消息. 如果出错,
也会给服务器端反馈一个消息. 下图展示了一个典型的 puppet 配置的数据流动情况.
工作流程
(1)客户端puppetd向master发起认证请求,或使用带签名的证书
(2)master告诉client它是否合法
(3)客户端puppetd调用facer(),facer探测出主机的一些变量,例如主机名、内存大小、IP地址等。puppetd将这些信息通过SSL连接发送到服务器端
(4)服务端的puppet master检测客户端的主机名,然后找到manifest对应的node配置,并对该部分内容进行解析。facer送过来的信息可以作为变量处理,node牵涉到的代码才解析,其他没牵涉的代码不解析。解析分为几个阶段:首先是语法检查,如果语法错误就报错;如果语法正确,就继续解析,解析的结果生成一个“伪代码”(catalog),然后把伪代码发给客户端
(5)客户端接收到伪代码并执行
(6)客户端在执行时判断有没有file文件,如果有,则向fileserver发起请求
(7)客户端判断有没有配置report,如果已配置,则把执行结果发送给服务端
(8)服务端把客户端的执行结果写入日志,并发送给报告系统
puppet组织结构
root@server0 puppet]# tree . ├── auth.conf ├── autosign.conf ├── environments │ └── example_env │ ├── manifests │ ├── modules │ └── README.environment ├── files │ └── vsftpd.conf ├── fileserver.conf ├── manifests #节点的存储目录(puppet会首先加载site.pp)文件 │ ├── nodes │ │ ├── server4.pp │ │ └── server5.pp │ └── site.pp ├── modules #模块的配置目录 │ │ └── nginx │ ├── files │ │ ├── nginx-1.6.2.tar.gz │ │ ├── nginx.conf │ │ └── nginx-install.sh │ └── manifests #模块的主配置文件,定义类的相关信息 │ ├── config.pp │ ├── init.pp │ ├── install.pp │ ├── nginx.install │ └── service.pp └── puppet.conf puppet的主配置文件Manifests目录:/etc/puppet/manifests主要用于管理节点的信息,其中会存放了文件site.pp(站点文件),用于定义全局变量其主机的加载,而我们定义模板的时候也会在模板目录中建立目录manifests。
`[root@server0 modules]# cd nginx/
[root@server0 nginx]# ls
files manifests
[root@server0 nginx]# ls -l manifests/
total 16
-rw-r--r-- 1 root root 191 Mar 23 16:16 config.pp
-rw-r--r-- 1 root root 69 Mar 23 16:40 init.pp
-rw-r--r-- 1 root root 487 Mar 23 16:36 install.pp
-rw-r--r-- 1 root root 0 Mar 23 16:40 nginx.install
-rw-r--r-- 1 root root 297 Mar 23 16:58 service.pp
```
Manifests是用来管理模块的,目录下有几个.pp文件,puppet在读取模块之后会先读取init.pp此文件,init.pp文件可以加载其他.pp文件。
puppet工简介一的更多相关文章
- puppet(1)-简介
puppet: 开源的.新一代的集中化的配置管理工具: 目标状态 配置语言 Luke Kanies,puppet labs bootstrap --> configuration --> ...
- Puppet安装及部署
本篇博客主要介绍Puppet的安装部署,后续会更新其他相关内容 一.简介 二.环境介绍 三.安装Puppet 四.配置Puppet-dashboard 五.配置Puppet Kick 一.简介 Pup ...
- 自动化运维工具——puppet详解(一)
一.puppet 介绍 1.puppet是什么 puppet是一个IT基础设施自动化管理工具,它能够帮助系统管理员管理基础设施的整个生命周期: 供应(provisioning).配置(configur ...
- 企业级自动化运维工具---puppet详解
本文收录在Linux运维企业架构实战系列 1.认识puppet 1.1 引入 puppet是什么,咱们先不用专业的名词解释它,咱们先描述一些工作场景,看明白这些工作场景,自然会知道puppet是什么. ...
- 项目10.2-企业级自动化运维工具---puppet详解
1.认识puppet 1.1 引入 puppet是什么,咱们先不用专业的名词解释它,咱们先描述一些工作场景,看明白这些工作场景,自然会知道puppet是什么. (1)场景一: 管理员想要在100台服务 ...
- Puppet自动化管理配置
Puppet:开源系统配置和管理工具 随着虚拟化和云计算技术的兴起,计算机集群的自动化管理和配置成为了数据中心运维管理的热点.对于 IaaS.Paas.Saas 来说,随着业务需求的提升,后台计算机集 ...
- puppet5.1 安装与配置
一.Puppet概念 简介 当服务器数量达到一定的规模时,仅依靠人为完成批量部署服务器个资源的配置,运维工作将变得繁琐且容易出错,为了解决这一问题,我们应该怎么办呢?我们可以引入一批工具,这批工具可编 ...
- Puppet安装与配置简介(附视频教程)
Puppet是一种Linux平台的集中配置管理系统,他可管理配置文件.用户.cron任务.软件包.系统服务等.puppet把这些系统实体称之为资源,puppet采用C/S星状的结构,所有的客户端和一个 ...
- abp加DDD开发:低耦合、可复用、可扩展的【工单】业务模块-简介和集成
前言 很多场景[单体+模块化]比微服务更合适,开发难度低.代码可复用性强.可扩展性强.模块化开发有些难点,模块启动与卸载.模块之间的依赖和通讯.asp.net core abp为我们提供了模块化开发能 ...
随机推荐
- leetcode227 基本计算器
1先利用符号栈转化为逆波兰表达式,并添加‘,’作为一个数字的结尾: 2然后利用数字栈计算逆波兰表达式的值: class Solution { public: int calculate(string ...
- 【转载】解决jquery-1.10.2.min.map 404 Not Found错误
最近写代码遇到问题,报错说jquery-1.10.2.min.map NOT FOUND.但是我检查了几遍代码发现代码中没有问题,而且根本就没有包含甚至提到jquert-1.10.2.min.map这 ...
- IFB
本文翻译自Linux官方IFB文档 IFB(中介功能块设备)是IMQ(中介队列设备)的继任者,IMQ从来没有被集成过,IFB拥有IMQ的优点,在SMP上更加清晰明了,并且代码量缩减了非常多,旧的中介设 ...
- 代码实现:取一个整数a从右端开始的4~7位
import java.util.Scanner; //取一个整数a从右端开始的4-7位. public class Test { public static void main(String[] a ...
- sorted&filter&map
python里列表的sort和内置的sorted函数,都可以进行排序,列表的sort方法是在原有的列表上进行排序,sorted是会返回一个新的对象 persons = [ {'name': '小明', ...
- Flex TabNavigator
1.获取子项个数 TabNavigator.numChildren(int) 2.对于静态的TabNavigator的如何处理权限显示 for(var i:int=0;i <tab.numChi ...
- 【Java基础】构造方法 static 块 {}块 执行顺序
package com.test.innerclass; public class HelloB extends HelloA { public HelloB() { System.out.print ...
- 【HANA系列】SAP 【第二篇】EXCEL连接SAP HANA的方法(ODBC)
公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[HANA系列]SAP [第二篇]EXCEL连接 ...
- mysql——触发器——概念
一.触发器 触发器是由事件来出发某个动作.这些事件包括insert语句.update语句和delete语句. 当数据库系统执行这些事件时,就会激活触发器执行相应得动作. 触发器是有insert.upd ...
- python 并发编程 多线程 GIL与多线程
GIL与多线程 有了GIL的存在,同一时刻同一进程中只有一个线程被执行 多进程可以利用多核,但是开销大,而python的多线程开销小,但却无法利用多核优势 1.cpu到底是用来做计算的,还是用来做I/ ...