puppet安装配置及使用
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安装配置及使用的更多相关文章
- centos6.5环境自动化运维之puppet实现nginx反向代理功能及puppet安装配置详解
puppet是一种Linux.Unix.windows平台的集中配置管理系统,使用自有的puppet描述语言,可管理配置文件.用户.cron任务.软件包.系统服务等.puppet把这些系统实体称之为资 ...
- Puppet 安装配置
环境说明: OS:CentOS 5.4 i386 puppetmaster 192.168.0.12 hostname: puppetmaster.info.com client ...
- puppet 3+Unicorn+Nginx安装配置
puppet 3+Unicorn+Nginx安装配置 2014-08-15 10:58 酒瓶不倒 酒瓶不倒的博客 字号:T | T 一键收藏,随时查看,分享好友! Unicorn 效率要比 Webri ...
- Puppet安装及部署
本篇博客主要介绍Puppet的安装部署,后续会更新其他相关内容 一.简介 二.环境介绍 三.安装Puppet 四.配置Puppet-dashboard 五.配置Puppet Kick 一.简介 Pup ...
- puppet的配置
1时间问题 agent与master端务必要保持时间的一致性,最好使用ntp服务 检查ntp服务是否安装 [root@master-elk ~]# rpm -qa|grep ntp ntpdate-. ...
- puppet 安装
yum源配置 1. wget http://ftp.kaist.ac.kr/fedora//epel/6/i386/epel-release-6-8.noarch.rpm 2. yum list | ...
- puppet的配置清单书写
puppet的配置清单书写 1使用数组,合并同类的 例如你想安装很多软件,如果分开来写的话,很麻烦,不简洁,这时我们可以使用数组来完成 以前我们这样来写 class packages{ package ...
- Saltstack 安装配置详解
下面这篇文章主要介绍另外一个运维自动化工具 Saltstack . 一.简介 Saltstack 比 Puppet 出来晚几年,是基于Python 开发的,也是基于 C/S 架构,服务端 master ...
- CentOS下puppet安装
简介 Puppet是开源的基于Ruby的系统配置管理工具,puppet是一个C/S结构, 当然,这里的C可以有很多,因此,也可以说是一个星型结构. 所有的puppet客户端同一个服务器端的puppet ...
随机推荐
- Spring学习笔记之Bean的实例化
一.bean的实例化方法有3种, 1.构造器实例化 2.静态工厂方法实例化 3.实例工厂方法实例化 二.用构造器来实例化 <bean id="ShunDao" class=& ...
- C语言之强制类型转换与指针--#define DIR *((volatile unsigned int *) 0x0022)
强制类型转换形式:(类型说明符) (表达式) 举例说明:1) int a; a = (int)1.9; 2)char *b; int *p; p = (int *) b; //将b的值强制转换为指向整 ...
- Cannot change network to bridged: There are no un-bridged host network adapters解决方法
首先,在你安装上了虚拟机后要确保你也安装了桥接的协议,这可以通过点击右键“网上邻居”,在其中可以看到有两个虚拟出来的网络一个VMnet1,另一个是VMnet8, 如下图所示. 如果没有安装,可以通过下 ...
- 常错-UIScrollView中得图片不能被拖动
经常在开发中,发现自己UIScrollView里面的图片不能被拖动 在这里做个备忘,第一种可能是contentSize没有设置,第二种可能是contentSize设置的太小了. 测试后发现,与user ...
- Git的常用命令的使用方法和解释
我们常用的git命令: add Add file contents to the index(将文件添加到暂存区) 用法: 保存某个文件到暂缓区:git add 文件名 保存当前路径的 ...
- Javascript 基础(二)
一.js运算符: +.-.*./.% %(去模 就是计算两个数的余数,通常判断是否能整除),主要用于整数. var a=90; var b=8; if(a%b==0) window.alert(&qu ...
- <转>thinkphp自动验证无效的问题
新手入门thinkphp,试用自动验证表单输入数据功能,却发现怎么都不能调用自动验证,自动验证无效,原因竟是一个小细节的疏忽,学习一定要细心啊! Action方法: IndexAction下的adds ...
- (转)HTML 5离线存储之Web SQL
原文:http://developer.51cto.com/art/201106/267357.htm HTML 5离线存储之Web SQL 2011-06-07 15:14 kkun kkun的博客 ...
- eclipse安卓模拟器窗口大小调整
引自百度经验的链接: http://jingyan.baidu.com/article/3aed632e18c7e97011809161.html
- MVC(模型-视图-控制器)的理解
在 MVC 中,模型对象表示数据(例如日历应用程序中的待办事项或绘图程序中的图形),视图对象知道如何显示模型对象所表示的数据,控制器对象充当模型和视图的媒介.在“HelloWorld”应用程序中,模型 ...