puppet安装前准备

一、服务器信息

master端:10.10.10.201 master.fansik.com

slave端:10.10.10.156 slave.fansik.com

三台机器关闭selinux,清空iptables规则。

二、修改三台机器的配置文件文件

修改三台服务器的主机名(永久修改,重启后生效)

# vim /etc/sysconfig/network

master端:master.fansik.com

slave端:slave.fansik.com

# vim /etc/hosts

添加如下内容:

10.10.10.201 master.fansik.com

10.10.10.156 slave.fansik.com

三、安装ntpdate,并建立自动同步时间的任务计划

# yum -y install ntpdate

# crontab -e

*/10 * * * * ntpdate time.windows.com > /dev/null 2>&1

puppet安装及配置使用

一、puppet服务端安装

master端:10.10.10.201 master.fansik.com

安装puppet源

# rpm -ivh 'http://yum.puppetlabs.com/el/6/products/x86_64/puppetlabs-release-6-7.noarch.rpm'

安装服务端程序

# yum -y install puppet-server

启动服务

# /etc/init.d/puppetmaster start

设置开机自启动

# chkconfig puppetmaster on

查看puppet的端口

# ss -tlunp | grep puppet

可以看到puppet的默认端口号是8140

二、puppet客户端安装

slave端:10.10.10.156 slave.fansik.com

安装puppet源

# rpm -ivh 'http://yum.puppetlabs.com/el/6/products/x86_64/puppetlabs-release-6-7.noarch.rpm'

安装客户端程序

# yum -y install puppet

修改配置文件在最后加入

# vim /etc/puppet/puppet.conf

在最后加入

listen = true

server = master.fansik.com

runinterval = 30   #主动更新,每隔30s

启动服务

# /etc/init.d/puppet start

设置开机自启动

# chkconfig puppet on

三、配置认证

服务端查看客户端证书列表

# puppet cert list --all #如果签发的证书,行前会有+号

客户端上生成ssl证书

# puppet agent --test --server master.fansik.com

服务端签发指定客户端证书

# puppet cert sign slave.fansik.com

服务端可以删除指定客户端证书

puppet cert clean slave.fansik.com

删除所有证书

puppet cert clean --all

四、配置自动签发证书

服务端删除客户端证书

# puppet cert clean --all

编辑服务端配置文件在[main]标签中添加autosign = true打开自动签名功能

# vim /etc/puppet/puppet.conf

autosign = true

编辑# vim /etc/puppet/autosign.conf加入如下内容:

*.fansik.com

客户端删除ssl相关文件

# rm -rf /var/lib/puppet/ssl/*

重启服务端puppetmaster服务

重启客户端puppet服务

查看是否签名成功

# puppet cert list --all

如果客户端不重启puppet服务,也可以通过命令来自动签发

# puppet agent --test --server master.fansik.com

五、测试证书

服务端编辑配置文件

# vim /etc/puppet/manifests/site.pp添加如下内容

node default {

file{"/tmp/123.txt":

content=>"test,test";

}

}

说明:如果不配置该文件,则客户端不会同步任何数据

客户端上稍等一会(每隔30s会自动执行服务端上的任务),或者直接命令行:

# puppet agent --test --server master.fansik.com

这样在客户端的/tmp/下会有个123.txt文件,内容为test,test

六、puppet配置模块

1、定义模块管理

模块是puppet的配置单元,模块里面会包含类和资源。同步文件、远程执行命令、cron等叫做资源,都是通过模块来实现的。

服务端创建目录mkdir /etc/puppet/modules/testm这个目录名字也可作为模块名字,然后继续创建模块对应的子目录mkdir /etc/puppet/modules/testm/{files,manifests,templates}files里面存文件,可以留空,manifests里面是配置文件,templates里面是模块文件可以为空

# vim /etc/puppet/manifests/site.pp

$puppetserver='master.fansik.com'

node 'slave.fansik.com' {

include testm

}

配置完成后,在客户端执行命令:

# puppet agent --test --server=master.fansik.com

如果客户端上启动了puppet服务,不用执行这命令,它也会自动同步的。

创建配置文件vim /etc/puppet/modules/testm/manifests/init.pp

内容为:

class testm{

file{"/tmp/1.txt":

owner => "root",

group => "root",

mode => 0400,

source => "puppet://$puppetserver/modules/testm/123.txt"

}

}

说明:类名字也叫作testm,类下面定义了一个资源file,文件名字叫做/tmp/1.txt,owner,group,mode定义文件属主、属组以及权限,source定义这个文件从哪里获取。$puppetserver一会也要定义一下,这里只的是puppetserver服务器上的/etc/puppet/modules/testm/files/123.txt

七、puppet文件或目录资源

1、在/etc/puppet/modules下面创建模块的名字,比如叫apahce

2、去/etc/puppet/manifests目录下的site.pp文件中引用创建的模块

$puppetserver='master.fansik.com'

node 'slave.fansik.com' {

include apache

}

3、去编辑/etc/puppet/modules/apache/manifests目录下的init.pp文件设置同步选项

class apache {

file {"/usr/local/apache2":

owner => "root",

group => "root",

source => "puppet://$puppetserver/modules/apache/apache2",

recurse => true,

purge => true,

}

}

八、puppet远程执行命令

exec {"fansik":

unless => "test -f /tmp/fansik.txt",

path => ["/bin","/sbin","/usr/bin","/usr/sbin"],

command => "touch /tmp/fansik.txt",

}

说明:fansik是资源的名字,unless后面的命令作为一个条件,当条件成立时,不会执行下面的命令,如果想要条件成立时,执行下面的命令,用onlyif。要注意的是,我们一定要给执行这条命令加个条件,使用unless就可以,必须满足这个条件才能执行命令,否则这个命令会一直执行下去,不太妥当。

九、puppet配置cron

cron {"fansik":

command => "/sbin/ntpdate time.windows.com",

user => "root",

minute => "*/10",

monthday => "10-15",

ensure => "absent",

}

说明:分时日月周分别对应puppet里面的minute,hour,monthday,month,weekday,ensure设置为absent为删除该任务,如果不设置改行则为建立

puppet安装配置及使用的更多相关文章

  1. centos6.5环境自动化运维之puppet实现nginx反向代理功能及puppet安装配置详解

    puppet是一种Linux.Unix.windows平台的集中配置管理系统,使用自有的puppet描述语言,可管理配置文件.用户.cron任务.软件包.系统服务等.puppet把这些系统实体称之为资 ...

  2. Puppet 安装配置

    环境说明: OS:CentOS 5.4 i386 puppetmaster    192.168.0.12    hostname: puppetmaster.info.com client      ...

  3. puppet 3+Unicorn+Nginx安装配置

    puppet 3+Unicorn+Nginx安装配置 2014-08-15 10:58 酒瓶不倒 酒瓶不倒的博客 字号:T | T 一键收藏,随时查看,分享好友! Unicorn 效率要比 Webri ...

  4. Puppet安装及部署

    本篇博客主要介绍Puppet的安装部署,后续会更新其他相关内容 一.简介 二.环境介绍 三.安装Puppet 四.配置Puppet-dashboard 五.配置Puppet Kick 一.简介 Pup ...

  5. puppet的配置

    1时间问题 agent与master端务必要保持时间的一致性,最好使用ntp服务 检查ntp服务是否安装 [root@master-elk ~]# rpm -qa|grep ntp ntpdate-. ...

  6. puppet 安装

    yum源配置 1. wget http://ftp.kaist.ac.kr/fedora//epel/6/i386/epel-release-6-8.noarch.rpm 2. yum list | ...

  7. puppet的配置清单书写

    puppet的配置清单书写 1使用数组,合并同类的 例如你想安装很多软件,如果分开来写的话,很麻烦,不简洁,这时我们可以使用数组来完成 以前我们这样来写 class packages{ package ...

  8. Saltstack 安装配置详解

    下面这篇文章主要介绍另外一个运维自动化工具 Saltstack . 一.简介 Saltstack 比 Puppet 出来晚几年,是基于Python 开发的,也是基于 C/S 架构,服务端 master ...

  9. CentOS下puppet安装

    简介 Puppet是开源的基于Ruby的系统配置管理工具,puppet是一个C/S结构, 当然,这里的C可以有很多,因此,也可以说是一个星型结构. 所有的puppet客户端同一个服务器端的puppet ...

随机推荐

  1. C++-多重继承的注意点

    1, 钻石型多重继承如果不想要底部的类有重复的变量,则需要声明为virtual继承 class File{...}; class InputFile: virtual public File{..}; ...

  2. IP数据报的格式

    1. IP数据报首部的固定部分中的各字段 ①版本:占4位,指IP协议的版本.通信双方使用的 IP协议版本必须一致.日前广泛使用的 IP协议版本号为 4 (即 IPv4). IPv6 目前还处于起步阶段 ...

  3. 【干货来了】2014年K2房地产IT分享峰会

    2014年K2房地产IT分享峰会已圆满落幕,嘉宾们纷纷出招,分享干货,现场妙语连珠不断,高潮迭起. 主题:流程驱动的地产业务管控平台 嘉宾:王寿欣(卓越地产战略与运营管理部 副总经理) 卓越地产应用K ...

  4. RPI学习--webcam_用fswebcam抓取图片

    若 ls /dev 下没有video0,可以参考http://www.cnblogs.com/skynext/p/3644873.html,更新firmware 1,安装fswebcam: sudo ...

  5. objective-c strong导致内存泄漏简单案例

    例如: @interface Test:NSObject{ id __strong obj_; } -(void) setObject:(id __strong)obj; @end @implemen ...

  6. IOS文件管理-NSFileMangager-NSdata

    Ios下的文件管理, Ios下不像windows 文件系统那样可以访问任何的文件目录,如C盘.D盘什么的.在Ios中每个应用程序只能访问当前程序的目录,也即sandbox(沙盒模型). iOS为每个应 ...

  7. PHP Array 函数

    PHP Array 简介 array 函数允许您对数组进行操作. PHP 支持单维和多维的数组.同时提供了用数据库查询结果来构造数组的函数. 安装 array 函数是 PHP 核心的组成部分.无需安装 ...

  8. 2016 - 1- 19 NSOperationQueue的简单使用

    一:NSOperationQueue的作用: 1.NSOperation可以调用start方法来执行任务,但默认是同步执行. 2.如果将NSOperation加入到NSOperationQueue中, ...

  9. cout 计算顺序问题

    cout输出流的执行顺序   下面是IBM的一道笔试题 #include <iostream> using namespace std; int fun( ) { cout << ...

  10. ACE - 代码层次及Socket封装

    原文出自http://www.cnblogs.com/binchen-china,禁止转载. ACE源码约10万行,是c++中非常大的一个网络编程代码库,包含了网络编程的边边角角.在实际使用时,并不是 ...