Puppet master-agent模型搭建
Puppet master-agent模型工作过程:

基于ssl xmlrpc进行通信,端口8140/tcp
agent:默认每隔30分钟向master发送node name和facts,并请求catalog
master:验证客户端身份,查找与其相关的site mainfests,编译生成catalog,并发送给客户端
环境搭建:
OS:CentOS 7
Puppet:3.6.2
master:安装puppet,puppet-server,facter
agent:安装puppet,facter
配置过程:
配置前提:
A.master和agent的时间必须要同步
B.master和agent之间进行SSL通信,需要依赖于HOSTNAME(由DNS解析而来),故测试时需要编辑本地的hosts文件:

1.master端配置
首先以不启动守护进程方式运行一遍,看看有没有问题
# puppet master -v --no-daemonize

如图所示,没有问题就可以启动puppetmaster服务了

2.agent端配置
发送证书签署请求给master
# puppet agent --server=node1.bzy.com -v
3.master端给agent端签署证书
# puppet cert list

# puppet cert sign node2.bzy.com

4.agent端获取证书
可以等待agent端获取证书,也可以手动再次执行以下命令获取证书
# puppet agent --server=node1.bzy.com -v

5.master端定义站点清单
位置:/etc/puppet/mainfests/site.pp
#node /^node\d+\.bzy\.com/ {
# include nginx::proxy
#}
node "node2.bzy.com" {
include nginx::proxy
}
如果有多个节点,依次写入即可。
到此步,配置基本成功了,由于puppet版本较多,有些细节可能不太一致,具体请查阅官方文档
测试用的模块:nginx

init.pp配置示例:
class nginx {
package{'nginx':
ensure => installed
}
}
class nginx::webserver inherits nginx {
file{'/etc/nginx/nginx.conf':
source => 'puppet:///modules/nginx/nginx_web.conf',
ensure => file,
require => Package['nginx'],
#notify => Service['nginx']
}->
service{'nginx':
ensure => running,
hasrestart => true,
hasstatus => true,
}
}
class nginx::proxy inherits nginx {
file{'/etc/nginx/nginx.conf':
ensure => file,
content => template('nginx/nginx_proxy.conf.erb'),
require => Package['nginx'],
#notify => Service['nginx']
}->
service{'nginx':
ensure => running
}
}
附:关于报错信息
1.
Could not prepare for execution: Could not create PID file
先察看是否与权限有关。如果有权限的话,察看是否有进程已启动:
# ps -ef | grep puppet
如果有,先kill掉,或者/etc/init.d/puppet stop后,然后重新输入指令。
2.
Error: Could not retrieve catalog from remote server: Error 400 on SERVER: Could not find class yum::repos for one-663.localdomain on node one-663.localdomain
在site.pp(或其他会import到site.pp的file.pp)中import 该class所在的"module_name"。即import "xxx"
3.
# puppet filebucket restore /etc/yum.repos.d/rh.repo 1bfcad49b3ffab391d5303ba58d26b64
Error: Could not run: Error 403 on SERVER: Forbidden request: 10.10.6.197(10.10.6.197) access to /file_bucket_file/md5/1bfcad49b3ffab391d5303ba58d26b64 [find] at :103
master端puppetmaster关掉了。重启即可。
Puppet master-agent模型搭建的更多相关文章
- 自动化运维工具之Puppet master/agent模型、站点清单和puppet多环境设定
前文我们了解了puppe中模块的使用,回顾请参考https://www.cnblogs.com/qiuhom-1874/p/14086315.html:今天我来了解下puppet的master/age ...
- 部署puppet master/agent模型
自己画的一个简单的架构图 agent端每隔30分钟到master端请求与自己相关的catalog. 各节点时间要同步. 依赖DNS,各节点能通过主机名能解析. 1.同步时间 # yum install ...
- puppet master/agent
puppet master/agent 配置 安装 master: yum install puppet-server agent: yum install puppet 自动签名 puppet的ma ...
- Puppet master/agent installation on RHEL7
==================================================================================================== ...
- puppet(5)-master/agent模式
master/agent模式的工作流程 agent每隔固定时长会向master端发送nodename(自己的节点名,节点名至关重要)和 facts ,并且向服务器端请求自己的catalog. mast ...
- Puppet基于Master/Agent模式实现LNMP平台部署
前言 随着IT行业的迅猛发展,传统的运维方式靠大量人力比较吃力,运维人员面对日益增长的服务器和运维工作,不得不把很多重复的.繁琐的工作利用自动化处理.前期我们介绍了运维自动化工具ansible的简单应 ...
- Advacned Puppet: Puppet Master性能调优
本文是Advanced Puppet系列的第一篇:Puppet master性能调优,谈一谈如何优化和提高C/S架构下master端的性能. 故事情节往往惊人地类似:你是一名使用Puppet管理线上业 ...
- Configure Puppet Master with Passenger and Apache on Centos
What is Passenger? Passenger (AKA mod_rails or mod_rack) is an Apache 2.x module which lets you run ...
- WEBrick/Rack Puppet Master
Puppet's Services: The WEBrick Puppet Master Puppet master is the application that compiles configur ...
随机推荐
- 爬虫所需要的文档和自动化文本driver下载地址,以及制作词云的文档,api等
Scrapy1.7.3文档 webdriver文档 webdriver下载地址 Chrom各版本下载地址 词云1.5文档 selenium中文文档 vue数据可视化文档 element开发组件 其他好 ...
- Java核心-02 Exception和Error有什么区别?
今天我要问你的问题是,请对比 Exception 和 Error,另外,运行时异常与一般异常有什么区别? 典型回答 Exception 和 Error 都是继承了 Throwable 类,在 Java ...
- Ubuntu环境下Error: Invalid or corrupt jarfile xxx.jar
一.问题描述 Ubuntu环境下将Maven项目打包成jar包后,运行一下指令: $ java -jar my.jar 发生错误: Error: Invalid or corrupt jarfile ...
- 锋利的Jquery(Table,Checkbox)
1.Table奇数偶数行 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http: ...
- 快速沃尔什变换(FWT) 与 快速莫比乌斯变换 与 快速沃尔什变换公式推导
后面的图片将会告诉: 如何推出FWT的公式tf 如何推出FWT的逆公式utf 用的是设系数,求系数的方法! ============================================== ...
- [JZOJ4649] 【NOIP2016提高A组模拟7.17】项链
题目 描述 题目大意 给你一堆小串,每个小串都有一定的分数. 让你构造一个字符串,若子串中出现了之前的小串,就可以得到对应的分数(可以重复) 问最大分数. 思考历程 一看这题就知道是什么字符串方面的算 ...
- Windows Server 2008 R2 部署服务
Windows Server 2008 R2 部署服务 部分参考: Windows Server 2008 R2 部署服务 - 马睿的技术博客 - 51CTO技术博客http://marui.blog ...
- CreateProcess函数详解及示例
WIN32API函数CreateProcess用来创建一个新的进程和它的主线程,这个新进程运行指定的可执行文件. 函数原型: BOOL CreateProcess ( LPCTSTR lpApplic ...
- mac下安装Python的工具包pip
1. 在终端下输入 sudo easy_install pip password:输入电脑密码 Finished processing dependencies for pip 表示安装完成 boe ...
- Genymotion 的那些事
一.什么是Genymotion? Genymotion是一套完整的工具,它提供了Android虚拟环境. 支持Windows.Linux和Mac OS等操作系统. 在Android开发中可以代替安卓模 ...