Puppet集中配置管理系统安装与配置

一、什么是puppet?

1、基于ruby语言开发的系统配置集中管理工具,跨平台

2、一个C/S架构,配置服务端和客户端

puppet依赖于ruby与facter,安装puppet3.x,需要ruby1.8.7版本及以上;facter是一个系统盘点工具,收集主机的一些资料,比如OS、IP、CPU等

3、puppet是一个C/S结构,开源软件,基于Ruby的系统配置管理工具,安装puppet3.x,需要ruby1.8.7版本及以上

4、默认情况下,客户端每隔30分钟连接一次puppet服务端

5、能管理多达40种资源,例如:file、user、cron、package、yum等,适合整个软件的生命周期管理

二、环境介绍

1、拓扑图

2、下载

操作系统RHEL6.3 x64

facter下载: https://downloads.puppetlabs.com/facter/

puppet下载: https://downloads.puppetlabs.com/puppet/

3、puppetmaster与puppetclient可以相互解析

vi /etc/hosts

192.168.0.200 puppetmaster.com

192.168.0.201 puppetclient1.com

4、puppet服务端与客户端时间同步

yum install ntp -y

service ntpd start

ntpdate pool.ntp.org #同步时间

clock -w #将时间写入硬件

chkconfig ntpd on

三、安装服务端puppet

1、安装ruby环境


1

[root@puppetmaster ~]# yum install -y ruby ruby-libs ruby-shadow

2、安装facter


1

2

3

[root@puppetmaster ~]# tar zxvf facter-1.7.3.tar.gz

[root@puppetclient1 ~]# cd facter-1.7.3

[root@puppetmaster facter-1.7.3]# ruby install.rb

3、安装配置puppet


1

2

3

4

5

6

7

[root@puppetmaster puppet-3.3.1]# useradd -s /sbin/nologin puppet

[root@puppetmaster ~]# tar zxvf puppet-3.3.1.tar.gz

[root@puppetclient1 ~]# cd puppet-3.3.1

[root@puppetclient1 puppet-3.3.1]# ruby install.rb

[root@puppetmaster puppet-3.3.1]# cp ext/redhat/puppet.conf /etc/puppet/

[root@puppetmaster puppet-3.3.1]# cp ext/redhat/server.init /etc/init.d/puppetmaster

[root@puppetmaster puppet-3.3.1]# chmod +x /etc/init.d/puppetmaster


1

2

3

[root@puppetmaster ~]# vi /etc/puppet/puppet.conf

[main]  #在main里面添加puppet服务端主机名

server = puppetmaster.com


1

2

3

[root@puppetmaster puppet-3.3.1]# chkconfig --add puppetmaster

[root@puppetmaster puppet-3.3.1]# chkconfig puppetmaster on

[root@puppetmaster puppet-3.3.1]# service puppetmaster start

四、安装客户端puppet agent

1、安装ruby环境


1

[root@puppetclient1 ~]# yum install -y ruby ruby-libs ruby-shadow

2、安装facter


1

2

3

[root@puppetclient1 ~]# tar zxvf facter-1.7.3.tar.gz

[root@puppetclient1 ~]# cd facter-1.7.3

[root@puppetclient1 facter-1.7.3]# ruby install.rb

3、安装配置puppet


1

2

3

4

5

6

[root@puppetclient1 puppet-3.3.1]# useradd -s /sbin/nologin puppet

[root@puppetclient1 ~]# tar zxvf puppet-3.3.1.tar.gz

[root@puppetclient1 puppet-3.3.1]# ruby install.rb

[root@puppetclient1 puppet-3.3.1]# cp ext/redhat/puppet.conf /etc/puppet/puppet.conf

[root@puppetclient1 puppet-3.3.1]# cp ext/redhat/client.init /etc/init.d/puppet

[root@puppetclient1 puppet-3.3.1]# chmod +x /etc/init.d/puppet


1

2

3

[root@puppetclient1 ~]# vi /etc/puppet/puppet.conf

[main]  #在main里面添加puppet服务端主机名

server = puppetmaster.com


1

2

3

4

[root@puppetclient1 puppet-3.3.1]# chkconfig --add puppet

[root@puppetclient1 puppet-3.3.1]# chkconfig puppet on

[root@puppetclient1 puppet-3.3.1]# service puppet start

[root@puppetclient1 puppet-3.3.1]# netstat -tupln | grep 8140

五、配置签名证书

1、客户端创建证书注册请求


1

2

3

4

5

6

[root@puppetclient1 ~]# puppet agent --test

Info: Creating a new SSL key for puppetclient1.com

Info: Caching certificate for ca

Info: Creating a new SSL certificate request for puppetclient1.com

Info: Certificate Request fingerprint (SHA256): 7E:10:48:3F:3C:D4:13:BA:BF:66:ED:86:52:92:19:05:1E:D2:3A:CD:06:67:27:80:60:D6:54:66:0E:33:F7:C7

Exiting; no certificate found and waitforcert is disabled

2、服务端查看证书注册请求


1

2

3

[root@puppetmaster ~]# puppet cert list  #加--all查看所有

  "puppetclient1.com"     (SHA256) 7E:10:48:3F:3C:D4:13:BA:BF:66:ED:86:52:92:19:05:1E:D2:3A:CD:06:67:27:80:60:D6:54:66:0E:33:F7:C7

  "puppetclient1.com.com" (SHA256) 46:B6:95:A6:1B:6A:FD:83:E4:1C:72:D4:5C:3C:B5:EF:3D:F7:43:2C:09:CF:00:B8:44:18:E4:3E:B3:DC:6F:FD

3、服务端受理客户端证书注册请求


1

2

3

[root@puppetmaster ~]# puppet cert sign puppetclient1.com  #主机名改为--all,是受理所有

Notice: Signed certificate request for puppetclient1.com

Notice: Removing file Puppet::SSL::CertificateRequest puppetclient1.com at '/var/lib/puppet/ssl/ca/requests/puppetclient1.com.pem'

4、客户端确认是否证书注册成功


1

[root@puppetclient1 ~]# puppet agent --test

如果出现以下报错,则在客户端puppet.conf配置文件[main]里面添加pluginsync=false,再重启!


1

Error: /File[/var/lib/puppet/lib]: Could not evaluate: Could not retrieve information from environment production source(s) puppet://puppetmaster.com/plugins

5、想清除证书使用


1

[root@puppetmaster ~]# puppet cert clean puppetclient1.com

六、简单测试

1、服务端编写配置


1

2

3

4

5

6

7

8

[root@puppetmaster ~]# vi /etc/puppet/manifests/site.pp #修改后立即,无需重启

node 'puppetclient1.com' {      #指定某台,也可以不写为所有

file "/tmp/test.txt":

            content=> "hello,puppet test\n";

            #source=> "puppet://$puppetserver/files/httpd.conf"

            #也可以这样分发一个配置文件

    }

}

注:file是一个资源管理关键字,用来管理文件的,还有package软件包管理,service管理系统服务,exec执行shell命令,/tmp/test.txt是创建文件名字,content定义文件内容

2、客户端默认30分钟与服务端同步配置文件,所以我们手动执行,也可以修改puppet.conf更改默认时间,添加runinterval=600,设置为10分钟同步一次


1

2

3

[root@puppetclient1 ~]# puppet agent --test

[root@puppetclient1 ~]# ls /tmp/

test.txt

至此,Puppet系统安装配置完成!

时间: 2024-08-30 21:43:01

Puppet集中配置管理系统安装与配置的相关文章

debian系统安装console-setup配置时进度不动

最近使用带有firmware的debian netinst安装一台服务器时,安装进度到99%配置console-setup时进程停滞了,没有当机,只是进度不动,几个小时都不带动的,一直在: configuring console-setup... CTRL+ALT+4查看安装日志,也没有错误提示,只是在等待. 重启进入rescue安装模式,在instaler环境下执行 # dpkg --configure -a console-setup配置界面选择# american,安装时就是因为这里自动配

Linux操作系统安装图文配置教程详细版_Linux

随着嵌入式的发展,Linux的知识是必须的一部分,下面就让我们进行Linux系统的安装过程演示: 一. Linux的安装 在此博客中以红旗(Red Flag)Asianux Workstation 3为例进行描述,其他版本的Linux与此相似.1.1 安装方式      根据Linux系统在计算机中的存在方式,将Linux的安装分为单系统.多系统和虚拟机.      1.单系统安装.指在计算机中仅安装Linux系统,无其它操作系统.   2.多系统安装.指在同一台计算机中,除了安装Linux系统

关于所需的配置管理中的配置基线

配置基线分配 在客户端计算机可以评估其与 Configuration Manager 中的配置基线的符合性之前,必须通过计算机集合向其分配配置基线. 分配包含下列属性: ● 配置基线本身 ● 哪个集合是符合性评估的目标,以及它是否包括任何定义的子集合 ● 最初使用默认符合性评估计划进行配置.但是可以针对每个分配进行更改的符合性评估计划. 配置基线分配是配置基线的可选属性.可以通过定义多个配置基线分配,将一个配置基线分配到多个集合. 从属配置基线 其中一个配置基线规则要包括另一个配置基线.此嵌套功

Vista系统安装IIS7配置ASP运行环境

台式机装上 Vista 之后就没怎么好好利用过,基本上就拿来当下载专用机器了,就连emule的上传基本以兆每秒计了 虽然 Vista 很漂亮,速度上感觉也比 XP 要快,但是习惯了 XP,用起 Vista 来感觉不是一般的晕 就连最基本的添加删除程序我都得网上搜索才找到 -_____,当然习惯了也就这么回事了 头几天的时候在 Vista 下看电影,结果发现 KMplayer 播放 rmvb 没声音.又去搜索,发现好多人好多说法,试用了其中一个不行,我就懒得弄了.后来无敌的小春同学闲着无聊把它收拾

GlusterFS集群系统安装与配置方法详解(1/2)

GlusterFS是一个开源的分布式文件系统,于2011年被红帽收购.它具有高扩展性.高性能.高可用性.可横向扩展的弹性特点,无元数据服务器设计使glusterfs没有单点故障隐患,详细介绍请查看官网:www.gluster.org . 部署环境:OS: CentOS release 6.5 (Final) x64 Server: c1:192.168.242.132 c2:192.168.242.133 c3:192.168.242.134 c4:192.168.242.135 hosts:

Ubuntu系统安装之后配置与软件安装

给root用户设置密码 ubuntu安装成功以后,su命令是不能够使用的.主要是因为你还没有给root用户设置密码,你可以在终端中输入以下命令给root用户设置密码(Ctrl+Alt+T调出终端):     sudo passwd root 安装相关的解码器 ubuntu安装完成之后,可能音乐播放器,视频播放器等都不能正常工作.主要是因为系统内缺少相关的解码器,你可以通过以下命令来安装解码器:     sudo apt-get install ubuntu-restricted-extras 安

puppet 配置 3.1 管理 sysct.conf

辅助模块 https://github.com/duritong/puppet-sysctl 下载方法 利用上面网站, 通过连接 clone or download 利用 download zip 按钮进行下载 把下载的 zip 文件直接解压到服务器端 /etc/puppet/modules/sysctl/ 目录下 文件结构 如下 [root@terry-test-uq2pu ~]# ls /etc/puppet/modules/sysctl/ Gemfile lib manifests Mod

puppet 配置 3.2 管理 hosts

作用 利用 puppet 对客户端 /etc/hosts 文件进行管理 辅助模块 https://forge.puppet.com/chrekh/hosts 下载方法 点击网页中 download latest tar.gz 直接下载 把下载的文件 解压至 puppet server 中 /etc/puppet/modules/hosts 目录中 文件结构 参考 [root@terry-test-uq2pu hosts]# pwd /etc/puppet/modules/hosts [root@

puppet 配置 3.4 文件管理与自定义模块

作用 利用 puppet 对文件, 配置文件等进行管理 常见管理办法 1. 新增文件并定义文件中内容 2. 修改已经存在的文件中的配置 3. 通过模板管理方式进行配置文件定义 模块 这里介绍 puppet 自带的 file 模块及第三方模块 stdlib stdlib 模块下载地址 使用方法 下载 stdlib.tar.gz 软件包并解压至 /etc/puppet/modules/stdlib 文件结构 [root@terry-test-uq2pu ~]# ls /etc/puppet/modu