一步一步学会puppet(三)--节点和模板

这篇主要介绍puppet中需要理解的2个重要概念:节点和模板;

===================================================================

1 节点

1.1 定义

1.2 详细说明

1.3 实例

2 模板

2.1 定义

2.2 详细说明

2.3 模板文件的语法

2.4 模板文件实例

2.5 使用模板文件生成实际配置文件

===================================================================

1 节点

1.1 定义

在puppet的master/agent组织结构中,节点配置就是用于指定每一个agent的配置,如可使用的类等;

1.2 详细说明

  • 在master/agent结构中,所有节点清单文件的入口文件为site.pp(在目录下/etc/puppet/manifests,需安装puppet-server程序包);
  • 建议一个节点使用一个清单文件,所有的清单文件都在site.pp中使用import包含进来;
  • 节点的定义和使用方式相似类的使用,即支持继承;

1.3 实例

# 1.定义通用目的节点
node ‘base‘ {
    include ntp
    include iptables
    include zabbix_agent
}
node ‘node1.magedu.com‘ inherits base { # 节点node1继承基础节点的类
    include nginx
}
# 2.节点名称支持使用正则表达式
node /^node[1234]\.lamp\.com$/ {
}
# 3.定义节点的配置文件规划:
/etc/puppet/manifests/
site.pp
    import "nginx/*.pp" # 导入各类应用的节点定义文件
    import "tomcat/*.pp"
    import "varnish/*.pp"
base.pp
nginx/
    node1.magedu.com.pp # 内部类继承于base
tomcat/
varnish/
# 4.使用外部的节点分类器ENC
使用yaml语法,PyYAML
ldap:

2 模板

2.1 定义

模板主要用于服务的配置文件的个性化生成,可根据变量替换进行文件填充;

2.2 详细说明

  • 模板文件一般位于模块的根目录下,如/etc/puppet/modules/nginx/templates;
  • 模板文件的后缀为.erb;

2.3 模板文件的语法

  • <%= Ruby Expression %>:替换为表达式的值,如:<%= @processorcount %>
  • <% ruby code %>:仅执行代码,不做任何替换;常用于条件判断或循环语句、设定变量以及在输出之前对数据进行处理;
  • <%# commit %>:注释;
  • <%%:输出<%;
  • %%>:输出%>;

2.4 模板文件实例

user <%= scope.lookupvar(‘nginx::config::nx_daemon_user‘) %>;
worker_processes <%= worker_processes %>; # 表达式值替换
error_log  <%= scope.lookupvar(‘nginx::params::nx_logdir‘)%>/error.log;
pid        <%= scope.lookupvar(‘nginx::params::nx_pid‘)%>;
events {
  worker_connections <%= worker_connections %>;
  <% if scope.lookupvar(‘nginx::params::nx_multi_accept‘) == ‘on‘ %>multi_accept on;<% end %> # 执行代码块,作为条件判断依据
}
http {
  include       /etc/nginx/mime.types;
  default_type  application/octet-stream;
  access_log  <%= scope.lookupvar(‘nginx::params::nx_logdir‘)%>/access.log;
  sendfile    <%= scope.lookupvar(‘nginx::params::nx_sendfile‘)%>;
  <% if scope.lookupvar(‘nginx::params::nx_tcp_nopush‘) == ‘on‘ %>
  tcp_nopush  on;
  <% end %>
  keepalive_timeout  <%= scope.lookupvar(‘nginx::params::nx_keepalive_timeout‘)%>;
  tcp_nodelay        <%= scope.lookupvar(‘nginx::params::nx_tcp_nodelay‘)%>;
  <% if scope.lookupvar(‘nginx::params::nx_gzip‘) == ‘on‘ %>
  gzip         on;
  gzip_disable "MSIE [1-6]\.(?!.*SV1)";
  <% end %>
  include /etc/nginx/conf.d/*.conf;
}

2.5 使用模板文件生成实际配置文件

使用模板生成文件时,使用的文件属性为content,实例如下

class nginx {
    package {‘nginx‘:
    ensure => present,
    }
    file {‘nginx.conf‘:
        ensure => file,
        content => template(‘nginx/nginx.conf.erb‘), # 引用模板文件生成文件内容
        path => ‘/etc/nginx/nginx.conf‘,
        require => Package[‘nginx‘],
        mode => ‘0644‘,
    }
}

一步一步学会puppet(三)--节点和模板,布布扣,bubuko.com

时间: 2024-10-17 12:39:14

一步一步学会puppet(三)--节点和模板的相关文章

一步一步学会puppet(四)--master/agent模型

这篇博文主要介绍puppet在实际生产环境下的master/agent模型的使用: =================================================================== 1 原理介绍 1.1 原理图 1.2 详细说明 2 配置实例 2.0 准备 2.1 master配置 2.2 agent配置 2.3 master签署证书 2.4 agent一次完整的同步案例 ===========================================

一步一步学会puppet(一)

简介 puppet是一种Linux.Unix.windows平台的集中配置管理系统: 使用自有的puppet描述语言,可管理配置文件.用户.cron任务.软件包.系统服务等,puppet把这些系统实体称之为资源: puppet的设计目标是简化对这些资源的管理以及妥善处理资源间的依赖关系 puppet的基础架构 puppet是集中式的配置管理工具,通过自有配置语言对节点进行目标状态定义,并能够基于网络实现目标状态的维护: puppet的工作模型 puppet通过声明性.基于模块的方法进行IT自动化

一步一步学会puppet(五)--配置文件和常用命令详解

这篇博文主要解析了puppet的配置文件和常用命令,以备以后查阅: =================================================================== 1 配置文件 1.1 组织结构 2 常用命令 2.1 常用命令 2.2 各类命令详解 2.3 帮助类命令 =================================================================== 1 配置文件 1.1 组织结构 配置文件位于/etc/

一步一步学会puppet(二)--模块和类

上一篇主要介绍了puppet的基本工作原理和资源的相关初步使用: 这一篇主要介绍puppet中很重要的2个概念:模块和类: =================================================================== 1 模块 1.1 需求 1.2 定义 1.3 详细说明 1.4 模块的目录组织结构 1.5 模块管理 2 类 2.1 定义 2.2 详细说明 2.3 类的分类 2.4 类的声明 2.5 实例 ========================

一步一步跟我学DeviceOne开发 - 仿微信应用(一,二,三)

这是一个系列的文档,长期目标是利用DeviceOne开发一些目前使用广泛的优质手机应用,我们会最大化的实现这些应用的每一个功能和细节,不只停留在简单的UI模仿和Demo阶段,而是一个基本可以使用的实际App. 在实现的过程中,会有很多困难,还会发现有一些功能目前缺乏组件支持而无法实现,也会碰见各种移动开发中都会碰到的常见技术问题.一步一步的操作和问题的解决可以让开发者直观的了解通过DeviceOne如何开发一个实际App,也可以了解移动开发本身的很多技术细节,可以让App开发者少走很多弯路. 这

一步一步学习数据结构(三)栈的顺序存储结构实现代码

//栈这种逻辑结构的实现与一般线性表的实现类似,有两种存储方式:顺序存储和链式存储 //先学习顺序存储 //1. #include<stdio.h> #include<stdlib.h> #define null NULL #define SIZE 100 typedef int dataType ; typedef struct { dataType data[SIZE]; int top; }cStack,*cStackPointer; //初始化栈空间 void initSt

一步一步造个IoC轮子(三):构造基本的IoC容器

一步一步造个Ioc轮子目录 一步一步造个IoC轮子(一):Ioc是什么 一步一步造个IoC轮子(二):详解泛型工厂 一步一步造个IoC轮子(三):构造基本的IoC容器 定义容器 首先,我们来画个大饼,定义好构造函数,注册函数及获取函数这几个最基本的使用方法 /// <summary> /// IoC容器 /// </summary> public class Container { /// <summary> /// 构造函数 /// </summary>

一步一步搭建开发框架(三)基类基接口

1,AdoNetDal和EfDal都实现IDal这个接口,公共的方法写到接口中,接口中的代码! 1 namespace PCITC.OA.IDal 2 { 3 public interface IUserInforDal 4 { 5 UserInfor Add(UserInfor userInfor); 6 7 bool Update(UserInfor userInfor); 8 9 bool Delete(UserInfor userInfor); 10 11 int Delete(para

如何一步一步删除(linux &amp; UNIX)环境下 oracle 11g 集群节点

 Deleting a Cluster Node on Linux and UNIX Systems 1.确定要删除的节点,是否active,pinned $ olsnodes -s -t 如果 pinned ,则crsctl unpin css  -n <nodename>  unpinned 相应的节点 2.禁用相应集群节点的应用资源,进程 先停掉 em: emctl stop dbconsole 以root 用户运行 在要删除节点的 $Grid_home/crs/install 路径