安装

以在Ubuntu server 14.04.2 TLS 为例:

  • 设置机器名。 编辑/etc/host以修改主机名,因为puppet是基于证书的,证书中包含主机名;

  • 更新包源。

    1. echo -e "deb http://apt.puppetlabs.com/ lucid main\ndeb-src http://apt.puppetlabs.com/ lucid main">>/etc/apt/sources.list.d/puppet.list
  • 对安装源进行一个检验。
    更新失败时才需要执行该命令
    1. apt-key adv --keyserver keyserver.ubuntu.com --recv XXXXXXXX
  • 系统更新 和安装
    1. apt-get update && apt-get dist-upgrade
  • 在控制节点上安装puppetmaster:
    1. apt-get install puppetmaster
  • 在客户端安装puppet:
    1. apt-get install puppet
  • puppet会监听8140端口,如果puppetmaster开启了防火墙需要做以下配置
    1. iptables -A INPUT -p tcp --dport 8140-j ACCEPT
  • 执行命令验证:

    1. netstat -lntup

    root@master:/home/andy# netstat -lntup
    Active Internet connections (only servers)
    Proto Recv-Q Send-Q Local Address Foreign Address State PID/Program name
    tcp 0 0 0.0.0.0:8140 0.0.0.0: LISTEN 27918/ruby
    tcp 0 0 0.0.0.0:22 0.0.0.0:
    LISTEN 21070/sshd
    tcp6 0 0 :::8080 ::: LISTEN 1286/java
    tcp6 0 0 :::22 :::
    LISTEN 21070/sshd
    tcp6 0 0 127.0.0.1:8005 :::* LISTEN 1286/java

  • 验证

  1. 在master上创建一个file资源
  2. 客户端发起验证:
    puppet agent --server xxxx(master) --test
  3. 服务器完成验证:
    puppet cert --list
    pupper cert sign xxx(client)
  4. 再次在客户端发起验证就可以看见验证成功了。

经验总结:

  • Ubuntu 下安装很简单,不需要预先安装ruby等,系统更新后直接安装puppet;
  • 安装完后是不存在site.pp 文件的,需要创建:/etc/puppet/manifests/site.pp,作为站点的主模块配置文件。
    一般的site.pp 很简单,引入Nodes节点下客户端文件即可
    1. import"nodes/*.pp"
  • 关于“模块”
    /etc/puppet/manifests的文件结构:
    1. |-- nodes
    2. |`-- client.pp
    3. `-- site.pp

    client.pp 说明客户节点client需要执行哪些模块。内容是:

    1. node 'client'
    2. {
    3. include stdlib
    4. include sysup
    5. }

    上面说明节点“client”将会执行stdlib 和 sysup 这两个模块(或者称之为功能)。
    上面说的模块,就是你需要puppet做的事情,比如拷贝文件,修改文件,安装package,执行命令等。
    每件“事情”就是一个单独的“模块”。

  • 怎么定义“模块”?
    首先来看文件结构:/etc/puppet/modules
    1. .
    2. |-- ntp
    3. ||-- files
    4. ||-- manifests
    5. ||`-- init.pp
    6. | `-- templates
    7. |-- sim
    8. ||-- files
    9. ||`-- simf.sh
    10. | `-- manifests
    11. |`-- init.pp

    目录/etc/puppet/modules有很多子目录,每个子目录就是你要需要puppet做的一件事情,比如你要安装ntp, 那么你就需要创建一个ntp文件夹,该文件夹下又需要包含manifests(必须),files, templates这三个文件夹。
    在manifests文件夹下,新建一个名叫 init.pp 的文件(必须),这里将详细描述做这件事情的经过。比如 ntp 下的 init.pp:

    1. class ntp
    2. {
    3. package{
    4. "ntp":
    5. ensure=>installed,
    6. }
    7. }

    注意:类名必须和模块名称一致!!!

  • 怎样让puppet 修改node上的文件呢?
    一般的资源 file 只能用来创建,其content属性的内容将会 覆盖 已有文件的内容。
    解决办法是给puppet安装stdlib。
    1. puppet module install puppetlabs-stdlib

    然后使用 stdlib 中的 file_line 资源。 例如:

    1. file_line{"newline":
    2. path=>"/etc/apt/sources.list.d/cloudarchive-kilo.list",
    3. line=>"add a new line",
    4. }

    具体可以参考:stdlib

  • 错误Could not request certificate: SSL_connect returned=1
    1. Error:Couldnot request certificate: SSL_connect returned=1 errno=0 state=SSLv3 read server certificate B: certificate verify failed:[certificate signature failure for/CN=master]

    出现这样的问题只能重新签发证书了,但是在master上删除证书后需要重启puppet才能生效!!
    也要注意主从机器之间时间是否同步的问题。

  • 怎样自动签发证书
    当客户节点增多时,每个节点向主节点申请证书似乎很愚蠢。
    可以设置master自动签发所有的证书,我们只需要在/etc/puppet 目录下创建 autosign.conf 文件并添加下面内容。(不需要修改 /etc/puppet/puppet.conf文件,因为默认的autosign.conf 文件的位置没有修改)
    1. *.example.com

    这样就会对所有来自 example.com 的机器的请求都自动签发证书,见参考

  • 创建user后无法登陆
    使用user资源添加用户时,属性password不是明文,需要用工具grub-md5-crypt 来生成。
    但需要安装 grub, 生成的password用单引号包裹:
    1. user{"andy":
    2. ensure=>"present",
    3. uid=>666,
    4. gid=>666,
    5. password=>'$1$PzftN$XANlscGctdGF3VjXH3k9q0',
    6. home=>"/home/andy",
    7. shell=>"/bin/bash",
    8. managehome=>true,
    9. }
  • 如何主动更新
    节点每次更新都要运行 puppet agent --test, 但是如果上百上千台nodes怎么办?
    可以采用puppet kick 这种 master主动推送更新并让node执行的方法。例如:
    1. puppet kick -p 10 client1 client2 client3

    设置很简单:

    1. 在客户节点的puppet.conf中的[agent]段中添加 listen = trueserver = MASTER_NAME; 2. 设置节点的防火墙准许在端口8139上接入;3.在节点的auth.conf的开头加入以下代码:
    1. # Allow puppet kick access
    2. path /run
    3. method save
    4. auth any
    5. allow workstation.example.com

    上面代码的意思是准许主机(workstation.example.com)去触发一个puppet执行。当然你也可以用allow *准许任何主机触发puppet的执行。
    关于主动更新,或者可以用 MCollective Puppet Agent。如何使用,需要更多的研究和实践。

puppet overview的更多相关文章

  1. [原] KVM 虚拟化原理探究(1)— overview

    KVM 虚拟化原理探究- overview 标签(空格分隔): KVM 写在前面的话 本文不介绍kvm和qemu的基本安装操作,希望读者具有一定的KVM实践经验.同时希望借此系列博客,能够对KVM底层 ...

  2. Activity之概览屏幕(Overview Screen)

    概览屏幕 概览屏幕(也称为最新动态屏幕.最近任务列表或最近使用的应用)是一个系统级别 UI,其中列出了最近访问过的 Activity 和任务. 用户可以浏览该列表并选择要恢复的任务,也可以通过滑动清除 ...

  3. Puppet自动化部署-安装及配置(3)

    本文介绍Puppet Master及Agent相关的安装及配置. 一. 官网下载Puppet安装YUM源 [root@puppet-master ~]# rpm -ivh https://yum.pu ...

  4. Puppet自动化运维-资源介绍篇(4)

    1.什么是资源? 资源是Puppet最基础的元素,每个资源的定义都具有标题,类型,以及一系列的属性. 资源定义有如下的特性:   (1) Puppet使用title在编译时区分每个资源,使用命名变量在 ...

  5. Puppet自动化部署-前期环境准备(2)

    在安装Puppet环境之前需要配置好机器的基本配置,如规范网络地址IP.hostname,certname认证名称,ntp时间同步等配置完毕,完善的搭建自动化环境. 1.环境介绍 此处实现部署的环境是 ...

  6. Puppet自动化运维-C/S架构概念(1)

    1.Puppet工作模式 (1)采用C/S架构(即是server<=>client) (2)Master 会对自己形成自签名CA中心,对Agent端进行证书颁发,验证通过才允许Agent( ...

  7. Atitit.自然语言处理--摘要算法---圣经章节旧约39卷概览bible overview v2 qa1.docx

    Atitit.自然语言处理--摘要算法---圣经章节旧约39卷概览bible overview v2 qa1.docx 1. 摘要算法的大概流程2 2. 旧约圣经 (39卷)2 2.1. 与古兰经的对 ...

  8. Overview of OpenCascade Library

    Overview of OpenCascade Library eryar@163.com 摘要Abstract:对OpenCascade库的功能及其实现做简要介绍. 关键字Key Words:Ope ...

  9. Puppet简易入门

    一.查看官方提供的下载源 https://docs.puppet.com/guides/puppetlabs_package_repositories.html 二. 选择对应系统的下载源 因为本机是 ...

随机推荐

  1. CSS预处理语言-less 的使用

    Less 是一门 CSS 预处理语言,它扩展了 CSS 语言,增加了变量.Mixin.函数等特性,使 CSS 更易维护和扩展. Less 可以运行在 Node 或浏览器端. Less的编译处理 作为一 ...

  2. 洛谷 P4114 Qtree1

    Qtree系列都跟树有着莫大的联系,这道题当然也不例外 我是题面 读完题,我们大概就知道了,这道题非常简单,可以说是模板题.树剖+线段树轻松解决 直接看代码吧 #include<algorith ...

  3. Golang基础(一)

    1. 变量声明与赋值 // var.go package main import "fmt" var a string var b bool var c string = &quo ...

  4. [BZOJ1588][HNOI2002]营业额统计 无旋Treap

    [HNOI2002]营业额统计 时间限制: 5 Sec  内存限制: 162 MB 题目描述 营业额统计 Tiger最近被公司升任为营业部经理,他上任后接受公司交给的第一项任务便是统计并分析公司成立以 ...

  5. The meterprter basic commonds

    Using Meterpeter commands Since the Meterpreter provides awhole new environment, we will cover some ...

  6. Codeforces 582C. Superior Periodic Subarrays(数学+计数)

    首先可以把 i mod n=j mod n的看成是同一类,i mod s=j mod s的也看成是同一类,也就是i mod gcd(s,n)的是同一类,很好理解,但是不会数学证明...大概可以想成数轴 ...

  7. php 性能优化之opcache - 让你的php性能提升 50%

    性能提升原理:减少文件解析的时间. 我们都知道,程序要运行,得有一个编译或者解析的过程,编译或解析之后的代码才是机器可以运行的. 而 php 是一种解析性语言,在使用php来处理http请求的时候,每 ...

  8. javascript基本介绍

    javascript是一种广泛用于客户端web开发的脚本语言,常采用来给html网页添加动态功能,比如响应客户的各种操作. 脚本语言是什么? (1).脚本语言往往不能独立运行,它和html/jsp/p ...

  9. 《提升c++性能的编程技术》读书笔记

    http://note.youdao.com/noteshare?id=9ab0eda264c85b774021426867e18eae

  10. 简单去除exe自校验方式

    简单去除exe自校验方式 一.      自校验定义: 这些程序会检查自己有没有被修改,如果发现被修改的话,便会离开或进行其它动作.基本的校检方法包括 checksum, 检查大小, 检查跳转代码,等 ...