运维自动化之puppet3分钟入门
运维自动化之puppet3分钟入门
几个月前曾因为项目需求而学了点puppet的一些知识,最近因为要给别人讲一下,也就借此博文来做一下回忆,当然了,这个puppet用起来还是很不错的,尤其对我这种懒人来说,如果你需要给多台机器安装同一款软件或是同几款软件,那么学习这个能让你事半功倍,接下来开始学习puppet。那么问题来了:
什么是puppet
本着外事问谷歌,内事问百度的原则,我在百度百科里找到了对其的定义:puppet是一种Linux、Unix、windows平台的集中配置管理系统,使用自有的puppet描述语言,可管理配置文件、用户、cron任务、软件包、系统服务等。puppet把这些系统实体称之为资源,puppet的设计目标是简化对这些资源的管理以及妥善处理资源间的依赖关系。puppet采用C/S星状的结构,所有的客户端和一个或几个服务器交互。每个客户端周期的(默认半个小时)向服务器发送请求,获得其最新的配置信息,保证和该配置信息同步。每个puppet客户端每半小时(可以设置)连接一次服务器端, 下载最新的配置文件,并且严格按照配置文件来配置服务器. 配置完成以后,puppet客户端可以反馈给服务器端一个消息. 如果出错,也会给服务器端反馈一个消息。
puppet工作原理
- 客户端调用factor探测主机一些变量,将信息通过ssl连接发送到服务器端。
- 服务器端检测客户端主机名,找manifest里对应的node配置,并解析生成中间代码“伪代码”发送给客户端。
- 客户端接收到“伪代码”并执行,把执行的结果发给服务器端,服务器将结果写入日志。
puppet安装
首先声明一下:我用的系统都是CentOS6.5。也就是说我的一切测试运作都是基于CentOS6.5来进行的。
在安装前需要对hostname进行修改:
[root@controller ~]# hostname 你要起的主机名 //中间有空格,即时生效
[root@controller ~]# vim /etc/sysconfig/network //更改主机名,重启生效
[root@controller ~]# vim /etc/hosts //把你要管理的机器加进去,格式 IP 主机名
接下来,就是安装了,选一台当服务器,其余的当客户端。当然,所有的都有一个库需要安装:
rpm -ivh http://yum.puppetlabs.com/puppetlabs-release-el-6.noarch.rpm
然后,服务器端执行下面的安装指令:
yum install puppet-server
客户端执行下面的安装指令:
yum install puppet
至此,安装结束,没错,就是这么简单~
不过,你难道以为现在就可以使用了?NO,当然没那么容易,接下来的一步将会至关重要,它的成败将关系到你能否使用这个自动运维的工具。
puppet的认证
首先,在客户端执行命令:
puppet agent --test
然后,认证请求会出现在服务器端,使用以下命令进行查看:
puppet cert --list
最后,执行以下命令签署认证:
puppet cert --sign hostname
PS:hostname为你自己设置的,请写上自己的hostname。
如果走到这一步你还没出错,恭喜你,你已经成功了90%。不过如果每台都需要一步一步的认证的话,是不是很麻烦,对,简直太麻烦了!那么有没有简单的方法呢?回答是肯定的,全部发送请求后统一认证:
puppet cert --sign -all
可是,还是感觉好麻烦的说,那么有没有不用签署认证的呢?答案依然是必然的。修改配置文件/etc/puppet/autosign.conf,在里面加入hostname即可,若无此文件,可自行创建,在这里,告诉大家一个小窍门:hostname可以起成*.puppet.com,这样的话在自动部署里面直接写成
*.puppet.com,很是方便,一般人我不告诉他。
puppet实战
既然部署完成了,当然要玩一下,下面就举个小例子来实战一下:
[root@controller ~]# vim /etc/puppet/manifests/site.pp
里面内容如下:
node 'agent.puppet.com' {
package {
"mysql":
ensure=>installed,
allow_virtual=>false,
source=>"http://dev.mysql.com/get/mysql-community-release-el6-5.noarch.rpm";}
}
然后在客户端执行:
puppet agent --test
即可在客户端安装mysql。
教程至此结束,若想学习更多,请移步https://puppetlabs.com/。
PS:本博客欢迎转发,但请注明博客地址及作者~
博客地址:http://www.cnblogs.com/voidy/
<。)#)))≦
运维自动化之puppet3分钟入门的更多相关文章
- 运维自动化之SALTSTACK简单入门
运维自动化之SaltStack简单入门 饱食终日而无所事事,是颓也,废也.但看昨日,费九牛二虎之力除一BUG便流连于新番之中,不知东方之既黑,实乃颓颓然而荒废矣.故今日来缀一文以忏昨日之悔. Salt ...
- Ansible运维自动化工具19个常用模块使用实例【转】
一.模块列表 1.setup 2.ping 3.file 4.copy 5.command 6.shell 7.script 8.cron 9.yum 10.service 11.group 12.u ...
- 运维自动化之salt笔记
1:saltstack的基本介绍 2:salt的安装 1:服务端1:安装2:配置文件3:运行4:注意事项2:客户端1:安装2:配置文件3:运行4:注意事项 3:salt的使用: 1:基础知识1:tar ...
- puppet运维自动化之用户管理
系统管理员离不开账户管理,账户管理,密码管理,开发机器,测试机器,线上机器,都需要创建用户,并给与相关用户的权限.你如果要创建100个,1000个账户和密码,你会不会疯掉,如何在1分钟完成百上千个账户 ...
- 运维自动化之ansible的安装与使用 转
运维自动化之ansible的安装与使用 随着服务器数量的增长,我们需要一个批量工具去提高工作效率,之前用的是puppet,ansible的简单,适用让我眼前一亮,决定写一篇ansible从安装到基本配 ...
- CentOS 下运维自动化 Shell 脚本之 expect
CentOS 下运维自动化 Shell脚本之expect 一.预备知识: 1.在 Terminal 中反斜杠,即 "" 代表转义符,或称逃脱符.("echo -e与pri ...
- Ansible 运维自动化 ( 配置管理工具 )
背景 出差背景,要搞项目的自动化部署.因为只直接对接生产分发,机器又非常多,这样以往使用的bat只能作为应急方案了,还是得考虑使用专业化的工具来做这个事情! 当下有许多的运维自动化工具( 配置管理 ) ...
- 运维自动化之系统部署 PXE(二)
PXE介绍 Preboot Excution Environment 预启动执行环境 Intel公司研发 基于Client/Server的网络模式,支持远程主机通过网络从远端服务器下载映像,并由此支持 ...
- Ansible运维自动化
Ansible运维自动化 一.Ansible-playbook的初步使用 playbook的使用,playbook可以把ansible的模块进行组合 ln -s /usr/local/python/b ...
随机推荐
- 解决ie9以及以下console未定义
页面明明已经删除了所有的console,但是ie9下依旧会报错 console未定义 只能这样解决了 window.console = window.console || (function () { ...
- pure响应式布局
<!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <m ...
- (转载)C#中的lock关键字
lock 关键字可以用来确保代码块完成运行,而不会被其他线程中断.这是通过在代码块运行期间为给定对象获取互斥锁来实现的. 先来看看执行过程,代码示例如下: 假设线程A先执行,线程B稍微慢一点.线程A执 ...
- java Vamei快速教程01
作者:Vamei 出处:http://www.cnblogs.com/vamei 欢迎转载,也请保留这段声明.谢谢! Java是完全面向对象的语言.Java通过虚拟机的运行机制,实现“跨平台”的理念. ...
- IOS NSKeyedArchiver(归档存取数据)
如果对象是NSString.NSDictionary.NSArray.NSData.NSNumber等类 型,可以直接用NSKeyedArchiver进行归档和恢复 不是所有的对象都可以直接用这种方法 ...
- C语言异常处理编程的三个境界
http://blog.csdn.net/treefish2012/article/details/17466487 这是上一次看完Herb Sutter的<Exceptional C++> ...
- 2017.12.2 用java做一个日历
1.先判断输入的日期是否为闰年 2.在判断输入的月份是否为2月 3.在获取输入的年份和月份的1月1日 的列数 4.在输出 import java.util.*; public class demo{ ...
- kubernetes-控制器Deployment和DaemonSet(八)
Pod与controllers的关系 •controllers:在集群上管理和运行容器的对象•通过label-selector相关联•Pod通过控制器实现应用的运维,如伸缩,升级等 控制器又称工作负载 ...
- 在docker镜像中加入环境变量
原文链接 前言 reference:https://vsupalov.com/docker-build-time-env-values/ 很多时候,我们需要在docker镜像中加入环境变量,本人了解的 ...
- Linux yum安装
一.安装Apache软件步骤:1.安装 yum install httpd 2.启动,关闭 重启等命令systemctl start httpd.service(启动)systemctl restar ...