Puppet扩展篇6-通过横向扩展puppetmaster增加架构的灵活性

零基础学习Puppet自动化配置管理系列文档

puppetmaster横向扩展将采用以下架构进行部署,也可以参考《puppet实战》第246页的内容。

puppet集群扩展架构图

主机IP地址信息机用途表

puppet集群扩展架构图

工作原理:

  • 客户端通过配置ca_server指定CA服务器,以达到独立CA服务器的目的。
  • CA服务器可以部署在多个机房。
  • Master集群可以在同一机房配置负载均衡器,也可以使用DNS解析Puppet Master域名到不同机房的多台服务器,通过DNS实现负载均衡。

1、配置前的准备工作

1.1、版本

puppet采用版本3.4.3
负载均衡器采用nginx或haproxy进行测试部署

1.2、主机名解析

/etc/hosts
192.168.10.10    kspupt-ca1
192.168.10.9     kspupt-ca2    
192.168.10.20    kspupt-ca    
192.168.10.13    kspupt-lvs1    
192.168.10.11    kspupt-m1    
192.168.10.12    kspupt-m2

1.3、时间统一(略)

2、PuppetCA认证服务器部署

PuppetCA的唯一目的就是签署和撤销证书。当PuppetCA服务不可用时,新的客户端将不能获得证书,从而会影响使用,而已签发证书的客户端缺不受影响。因此将CA进行独立队架构,这对容错性而言是非常有必要的。

2.1 安装软件包

[[email protected] ~]# groupadd -g 3000 puppet
[[email protected] ~]# useradd -u 3000 -g 3000 puppet
[[email protected] ~]# yum install puppet puppet-server -y

2.2 临时配置VIP地址

[[email protected] ~]# ip addr add 192.168.10.20/24 dev eth0

注:后期CA配置成了高可用后,将VIP地址添加到高可用资源中即可,临时先绑定在CA1上。

2.3 生成证书

使用puppet cert命令生成CA服务器与服务器域名证书。生成puppetca和puppetmaster两个域名的授权证书文件。

[[email protected] ~]# puppet  cert --generate --dns_alt_names puppetca:puppet puppetca
[[email protected] ~]# puppet  cert --generate --dns_alt_names puppetmaster:puppet puppetmaster
[[email protected] ~]# puppet  cert --list --all  验证
+ "puppetca"     (SHA256) 76:1D:C1:90:23:45:43:A2:41:4B:3B:92:32:C4:BE:31:38:61:5B:42:03:D0:22:28:53:5B:6F:5E:99:5A:B8:94 (alt names: "DNS:puppetca", "DNS:puppetca:puppet")
+ "puppetmaster" (SHA256) 0A:A2:DC:22:B8:4C:EB:31:B0:52:8F:B0:21:72:DD:EB:C7:B4:05:97:45:B3:EA:19:3A:28:69:29:04:35:0F:E7 (alt names: "DNS:puppetmaster", "DNS:puppetmaster:puppet")

2.4 配置puppet.conf,添加标签[master]

[[email protected] ~]# vim /etc/puppet/puppet.conf 
[master]
    confdir   = /etc/puppet
    certname  = puppetca
    ca        = true    #开启CA认证

2.5 启动puppetmaster,CA部署完成

[[email protected] ssl]# /etc/init.d/puppetmaster start
[[email protected] ssl]# chkconfig puppetmaster on

kspupt-ca2配置(略)

3、PuppetMaster服务器部署

PuppetMaster服务器部署可采用默认的WebRick方式,也可以采用apache+passenger或nginx+passenger方式。

3.1 WebRick方式:

3.1.1 安装软件包

[[email protected] ~]# groupadd -g 3000 puppet
[[email protected] ~]# useradd -u 3000 -g 3000 puppet
[[email protected] ~]# yum install puppet puppet-server -y

3.1.2 设置hosts文件

[[email protected] ~]# vim /etc/hosts
192.168.10.20 puppetca
192.168.10.11 puppetmaster

3.1.3 创建证书目录

[[email protected] ~]# mkdir /var/lib/puppet/ssl/{certs,ca,private_keys} -p

3.1.4 将puppetca上生成的puppetmaster公钥、私钥和根证书复制到kspupt-m1

[[email protected] ssl]# scp -r [email protected]:/var/lib/puppet/ssl/ca/signed/puppetmaster.pem /var/lib/puppet/ssl/certs/puppetmaster.pem 
[[email protected] ssl]# scp -r [email protected]:/var/lib/puppet/ssl/ca/ca_crt.pem  /var/lib/puppet/ssl/certs/ca.pem  
[[email protected] ssl]# scp -r [email protected]:/var/lib/puppet/ssl/private_keys/puppetmaster.pem /var/lib/puppet/ssl/private_keys/puppetmaster.pem
[[email protected] gem]# scp -r [email protected]:/var/lib/puppet/ssl/ca/ca_crl.pem /var/lib/puppet/ssl/ca/ca_crl.pem

3.1.5 配置puppet.conf,添加标签[master],关闭ca

[[email protected] ~]# vim /etc/puppet/puppet.conf
[master]
    certname = puppetmaster
    ca       = false   #关闭CA认证

3.1.6 配置puppet.conf,修改标签[agent],增加server和ca_server字段

[[email protected] ~]# vim /etc/puppet/puppet.conf
[agent]
    server      = puppetmaster
    ca_server   = puppetca

3.1.7 启动puppetmaster服务,Puppetmaster部署完成

[[email protected] ~]# /etc/init.d/puppetmaster start

3.1.8 运行puppet命令进行本地证书申请

[[email protected] ~]# puppet  agent -t
Info: Creating a new SSL key for kspupt-m1
Info: csr_attributes file loading from /etc/puppet/csr_attributes.yaml
Info: Creating a new SSL certificate request for kspupt-m1
Info: Certificate Request fingerprint (SHA256): 78:A5:F2:6C:F6:EE:0C:25:0C:EF:96:B8:B4:E6:78:74:A6:AA:67:81:6B:8F:36:AC:B2:37:B5:E0:C1:F0:11:67
Exiting; no certificate found and waitforcert is disabled

3.1.9 登录puppetca进行证书签发

[[email protected] ~]# puppet  cert --sign kspupt-m1
Notice: Signed certificate request for kspupt-m1
Notice: Removing file Puppet::SSL::CertificateRequest kspupt-m1 at ‘/var/lib/puppet/ssl/ca/requests/kspupt-m1.pem‘

3.1.10 再次运行puppet命令进行测试连通性

[[email protected] ~]# puppet  agent -t
Info: Caching certificate for kspupt-m1
Info: Caching certificate_revocation_list for ca
Info: Caching certificate for kspupt-m1
Info: Retrieving pluginfacts
Info: Retrieving plugin
Info: Caching catalog for kspupt-m1
Info: Applying configuration version ‘1409296030‘
Info: Creating state file /var/lib/puppet/state/state.yaml
Notice: Finished catalog run in 0.02 seconds

3.1.11 在kspupt-ca上申请本地证书

[[email protected] ~]# vim /etc/puppet/puppet.conf
[agent]
    server    = puppetmaster
    ca_server = puppetca
[[email protected] ~]# puppet agent -t
[[email protected] ~]# puppet cert --sign kspupt-ca
[[email protected] ~]# puppet agent -t

3.2 Nginx+Passenger方式:

注:可参考 http://kisspuppet.com/2014/10/20/puppet_learning_ext4/

3.2.1、安装相关开发包

[[email protected] ~]# groupadd -g 3001 nginx
[[email protected] ~]# useradd -u 3001 -g 3001 nginx
[[email protected] ~]# yum install ruby-devel gcc make pcre-devel zlib-devel openssl-devel pam-devel curl-devel rpm-build

3.2.2、安装passenger(将gem软件包copy到本地)

[[email protected] gem]# gem install rake rack passenger --no-rdoc --no-ri

3.2.3、解压nginx、pcre源码包

[[email protected] gem]# tar xf pcre-8.32.tar.gz -C /usr/local/src/
[[email protected] gem]# tar xf nginx-1.4.2.tar.gz -C /usr/local/src/

3.2.4、编译并安装nginx

[[email protected] ~]# cd /usr/local/src/nginx-1.4.2/
[[email protected] nginx-1.4.2]# ./configure --user=nginx --group=nginx --prefix=/etc/nginx --with-http_stub_status_module --with-http_ssl_module --with-pcre=/usr/local/src/pcre-8.32 --add-module=`passenger-config --root`/ext/nginx
[[email protected] nginx-1.4.2]# make && make install

3.2.5、与passenger结合

[[email protected] nginx-1.4.2]# mkdir  -p /etc/puppet/rack/public
[[email protected] nginx-1.4.2]# cp /usr/share/puppet/ext/rack/config.ru  /etc/puppet/rack/
[[email protected] nginx-1.4.2]# chown -R puppet. /etc/puppet/rack/

3.2.6、复制启动脚本到

[[email protected] init.d]# cp /root/gem/nginx /etc/init.d/
[[email protected] ~]# chmod a+x /etc/init.d/nginx

3.2.7、配置nginx

[[email protected] gem]# vim /etc/nginx/conf/nginx.conf
user  nginx nginx;
worker_processes  1;
pid        /var/run/nginx.pid;
events {
    worker_connections  1024;
}
http {
    passenger_root /usr/lib/ruby/gems/1.8/gems/passenger-4.0.19;
    passenger_ruby /usr/bin/ruby;
    include       mime.types;
    default_type  application/octet-stream;
    sendfile        on;
    keepalive_timeout  65;

    server {
        listen 8140                ssl;
    server_name                puppetmaster;
    passenger_enabled          on;
    passenger_set_cgi_param    HTTP_X_CLIENT_DN $ssl_client_s_dn;
    passenger_set_cgi_param    HTTP_X_CLIENT_VERIFY $ssl_client_verify;
    proxy_buffer_size 4000k;
    proxy_buffering on;
    proxy_buffers 32 1280k;
    proxy_busy_buffers_size 17680k;
    client_max_body_size 10m;
    client_body_buffer_size 4096k;
    access_log /var/log/nginx/puppet_access.log;
    error_log /var/log/nginx/puppet_error.log;
    root /etc/puppet/rack/public;
    ssl off;
    ssl_session_timeout 5m;
    ssl_certificate /var/lib/puppet/ssl/certs/puppetmaster.pem;
    ssl_certificate_key /var/lib/puppet/ssl/private_keys/puppetmaster.pem;
    ssl_client_certificate /var/lib/puppet/ssl/certs/ca.pem;
    ssl_crl /var/lib/puppet/ssl/ca/ca_crl.pem;
    ssl_verify_client optional;
    ssl_ciphers SSLv2:-LOW:-EXPORT:RC4+RSA;
    ssl_prefer_server_ciphers on;
    ssl_verify_depth 1;
    ssl_session_cache shared:SSL:128m;
    # File sections
    location /production/file_content/files/ {
      types { }
      default_type application/x-raw;
      alias /etc/puppet/files/;
  }
 }
}

3.2.8、配置puppet.conf

[[email protected] ~]# vim /etc/puppet/puppet.conf 
[master]
    certname = puppetmaster
    ca       = false
    ssl_client_verify_header = HTTP_X_CLIENT_VERIFY
    ssl_client_header = HTTP_X_CLIENT_DN

3.2.9、启动nginx

[[email protected] gem]# mkdir /var/log/nginx/
[[email protected] nginx-1.4.2]# /etc/init.d/puppetmaster stop
[[email protected] nginx-1.4.2]# chkconfig puppetmaster off
[[email protected] nginx-1.4.2]# /etc/init.d/nginx start
[[email protected] nginx-1.4.2]# chkconfig nginx on

3.2.10、测试

在多个节点发起puppet agent -t命令动作

[[email protected] ~]# puppet  agent -t
[[email protected] ~]# puppet  agent -t
[[email protected] ~]# tailf  /var/log/nginx/puppet_access.log

tkpupt-m2安装(略)

4 Puppet LB负载均衡器部署

4.1 puppet认证建立

4.1.1、安装软件包

[[email protected] ~]# groupadd -g 3000 puppet
[[email protected] ~]# useradd -u 3000 -g 3000 puppet
[[email protected] ~]# yum install puppet

4.1.2、编辑hosts文件

[[email protected] ~]# vim /etc/hosts
192.168.10.20 puppetca
192.168.10.11 puppetmaster
192.168.10.13 kspupt-lvs1

4.1.3、创建证书目录

[[email protected] ~]# mkdir /var/lib/puppet/ssl/{certs,ca,private_keys} -p

4.1.4、将kspupt-ca上生成的puppetmaster公钥、私钥和根证书复制到kspupt-lvs1

[[email protected] ssl]# scp -r [email protected]:/var/lib/puppet/ssl/ca/signed/puppetmaster.pem /var/lib/puppet/ssl/certs/puppetmaster.pem 
[[email protected] ssl]# scp -r [email protected]:/var/lib/puppet/ssl/ca/ca_crt.pem  /var/lib/puppet/ssl/certs/ca.pem  
[[email protected] ssl]# scp -r [email protected]:/var/lib/puppet/ssl/private_keys/puppetmaster.pem /var/lib/puppet/ssl/private_keys/puppetmaster.pem
[[email protected] ssl]# scp -r [email protected]:/var/lib/puppet/ssl/ca/ca_crl.pem /var/lib/puppet/ssl/ca/

4.1.5、配置puppet.conf,修改标签[agent],增加server和ca_server字段

[[email protected] ~]# vim /etc/puppet/puppet.conf
[agent]
    server      = puppetmaster
    ca_server   = puppetca

4.1.6、运行puppet命令进行本地证书申请

[[email protected] ~]# puppet  agent -t

4.1.7、登录kspupt-ca进行证书签发

[[email protected] ~]# puppet  cert --sign kspupt-lvs1

4.1.8、再次运行puppet命令进行测试连通性

[[email protected] ~]# puppet  agent -t
Info: Retrieving pluginfacts
Info: Retrieving plugin
Info: Caching catalog for kspupt-lvs1
Info: Applying configuration version ‘1409210667‘

4.2 安装并配置nginx负载均衡器

4.2.1、安装nginx软件

[[email protected] ~]# groupadd -g 3001 nginx
[[email protected] ~]# useradd -u 3001 -g 3001 nginx
[[email protected] ~]# yum install nginx

4.2.2、临时设置VIP地址(后面通过高可用软件代替)

[[email protected] ~]# ip addr add 192.168.10.18/24 dev eth0

4.2.3、配置nginx虚拟主机,添加upstrem

[[email protected] ~]# vim /etc/nginx/conf.d/puppetmaster.conf
upstream puppet-master {
   server 192.168.10.11:8140;
   server 192.168.10.12:8140;
}
server {
   listen         8140 ssl;
   server_name    puppetmaster;
   access_log     /var/log/nginx/puppet_access.log;
   error_log      /var/log/nginx/puppet_error.log;
   ssl_protocols SSLv3 TLSv1;
   ssl_ciphers ALL:!ADH:RC4+RSA:+HIGH:+MEDIUM:-LOW:-SSLv2:-EXP;
   proxy_set_header             X-SSL-Subject  $ssl_client_s_dn;
   proxy_set_header             X-Client-DN  $ssl_client_s_dn;
   proxy_set_header             X-Client-Verify  $ssl_client_verify;
   client_max_body_size 100m;
   client_body_buffer_size 1024k;
   proxy_buffer_size 100m;
   proxy_buffers 8 100m;
   proxy_busy_buffers_size 100m;
   proxy_temp_file_write_size 100m;
   proxy_read_timeout 500;

   ssl                     on;
   ssl_session_timeout     5m;
   ssl_certificate         /var/lib/puppet/ssl/certs/puppetmaster.pem;
   ssl_certificate_key     /var/lib/puppet/ssl/private_keys/puppetmaster.pem;
   ssl_client_certificate  /var/lib/puppet/ssl/certs/ca.pem;
   ssl_crl                 /var/lib/puppet/ssl/ca/ca_crl.pem;
   ssl_verify_client       optional;
   ssl_prefer_server_ciphers  on;
   ssl_verify_depth           1;
   ssl_session_cache          shared:SSL:128m;
   location / {
         proxy_redirect    off;
         proxy_pass        https://puppet-master;
  }
}

4.2.4、编辑hosts文件,puppetmaster解析指向VIP

[[email protected] ~]# vim /etc/hosts
192.168.10.20 puppetca
192.168.10.18 puppetmaster
192.168.10.13 kspupt-lvs1

4.2.5、修改kspupt-ca和kspupt-m1的hosts文件puppetmaster解析

[[email protected] ~]# vim /etc/hosts
192.168.10.20 puppetca
192.168.10.18 puppetmaster
[[email protected] ~]# vim /etc/hosts
192.168.10.20 puppetca
192.168.10.18 puppetmaster

4.2.6、启动nginx服务器

[[email protected] ~]# /etc/init.d/nginx start

4.2.7、再次运行puppet命令进行测试连通性

[[email protected] ~]# puppet  agent -t
[[email protected] ~]# puppet  agent -t
[[email protected] ~]# puppet  agent -t
[[email protected] ~]# tailf  /var/log/nginx/puppet_access.log
[[email protected] ~]# tailf /var/log/nginx/puppet_access.log

kspupt-lvs2(略)

4.3 HAproxy负载均衡配置参考

[[email protected] ~]# cat /etc/haproxy/haproxy.cfg
listen admin_stats 
    bind 0.0.0.0:8080
    mode http
    stats refresh 5s
    stats enable
    stats hide-version
    stats realm Haproxy\ Statistics
    stats uri /haproxy
    stats auth admin:password
listen puppetmaster *:8140
    mode tcp
    option ssl-hello-chk
#    option tcplog
    #balance source
#    balance roundrobin
    balance source
    server kspupt-m1 kspupt-m1:8140 check inter 2000 fall 3
    server kspupt-m2 kspupt-m2:8140 check inter 2000 fall 3

返回主目录

交流方式:

微信公众号:puppet2014,可微信搜索加入,也可以扫描以下二维码进行加入

微信公众号

QQ交流群:296934942

时间: 2024-12-12 11:46:57

Puppet扩展篇6-通过横向扩展puppetmaster增加架构的灵活性的相关文章

关系型数据库横向扩展的三种方法

本文是 Oracle Coherence 3.5一书,第一章: Achieving Performance, Scalability, and Availability Objectives,第二节:Achieving scalability中,数据库横向扩展部分的读书笔记. 传统的关系型数据库很难扩展,通常是纵向扩展,但到达一定程度时只能横向扩展. 数据库的横向扩展支持三种方法,即主从复制,集群和分片(sharding). 主从复制 主从复制(Master-slave replication)

构建横向扩展文件服务器

上一篇中,主要演示了如何构建高可用SMB3.0wenjian 服务器,今天主要为大家演示如何构建横向扩展文件服务器并将Hyper-V虚拟机创建到该服务器中. 在 Windows Server 2012 中,横向扩展文件服务器设计用于提供横向扩展文件共享,该类共享可供基于文件的服务器应用程序存储连续使用.横向扩展文件共享允许从同一群集的多个节点上共享同一文件夹.例如,对于使用在 Windows Server 2012 中引入的服务器消息块 (SMB) 扩展的四节点文件服务器群集,运行 Window

.net core 3.0 Signalr - 04 使用Redis做底板来支持横向扩展

在实际的系统中,可能需要多台机器部署;然而,Signalr的连接信息是跟站点走的,举个例子 推送系统部署了A.B两个服务器,张三访问A服务器,李四访问B服务器,当张三通过A服务器向李四推送的时候,A服务器上是找不到李四的连接信息的,自然也就推送不过了,这个时候就需要有一个统一协调的玩意,signalr支持多种,Azure.Redis等,本节以Redis作为底板,介绍如何在Signalr中使用Redis作为底板来支持横向扩展. ## 引入Redis - 先引入NuGet包 Microsoft.As

横向拆分(扩展) 纵向拆分(扩展)

Scale Out(也就是Scale horizontally)横向扩展,向外扩展Scale Up(也就是Scale vertically)纵向扩展,向上扩展无论是Scale Out,Scale Up,Scale In,实际上就是一种架构的概念,这些概念用在存储上可以,用在数据库上,网络上一样可以.简单比喻下Scale out和Scale up,帮助我们理解:Scale Out,比如:我们向原有的web.邮件系统添加一个新机器.Scale UP,比如:我们向原有的机器添加CPU.内存.

设计模式解密(22)- 访问者模式 - 扩展篇(分派的概念)

前言:访问者模式拆分  访问者模式基础篇 :http://www.cnblogs.com/JsonShare/p/7380772.html  访问者模式扩展篇 - 分派的概念: http://www.cnblogs.com/JsonShare/p/7381705.html 1.分派的概念 变量被声明时的类型叫做变量的静态类型(Static Type),有些人又把静态类型叫做明显类型(Apparent Type):而变量所引用的对象的真实类型又叫做变量的实际类型(Actual Type).比如:

Java 兔子问题(斐波那契数列)扩展篇

Java兔子问题(斐波那契数列)扩展篇 斐波那契数列指的是这样一个数列 0, 1, 1, 2,3, 5, 8, 13, 21, 34, 55, 89, 144, ...对于这个数列仅仅能说将兔子生产周期第为3月.假设生成周期变成4月这个数列肯定不是这种,或者说兔子还有死亡周期,在这里我是对兔子生产周期没有限定.仅仅要月份大于生产周期都能够计算出第month月份究竟能产生多少对兔子. Java兔子生殖问题 斐波那契数列又因数学家列昂纳多·斐波那契以兔子生殖为样例而引入.故又称为"兔子数列"

WinSrv2016横向扩展存储(SDS)[无共享存储]

在Windows Server 2016中引入了一个新存储功能,这个功能非常类似其他的横向扩展存储解决方案,如VMware的VSAN,可以进行存储空间的直连,使用的是存储节点的本地存储,也就是使用每一个存储节点的内部磁盘设备构建HA存储系统连接到单个的存储节点: 所有的节点是利用SMB3来直接与存储空间进行通信: 存储空间无缝集成组成Windows Server的软件定义存储功能,包括横向扩展的文件服务器,群集共享卷,存储空间和故障转移群集. 除此之外按照同样的道理也可以提供给Hyper-V虚拟

FastDFS安装扩展篇——安装PHP、Apache及Nginx的FastDFS扩展【所有fastdfs文档】

FastDFS安装扩展篇——安装PHP.Apache及Nginx的FastDFS扩展 公司项目准备用fastdfs开始我就不知道这个是什么意思的,忙活了一个星期才大致明白,然后配置加使用,所有的东西都是从不懂到懂,前提是你要勇敢的面对他.东西就是让人用的,一个星期不会用,花费一个月的时间,只要刻苦钻研,一定会战胜的! 关于linux下如何安装FastDFS请参考:http://www.icultivator.com/p/4843.html 一.安装配置FastDFS支持PHP FastDFS不是

sencha touch 扩展篇之将sencha touch打包成安装程序(下)- 使用phonegap打包安装程序

    这讲我们来讲解下如何使用phonegapa创建项目环境并通过她们将sencha touch打包成app,这里我们只讲解打包android的apk,打包ios的过程有点类似,但是需要在mac环境下,最后通过xcode导出成ipa安装程序: 一.phonegap环境搭建: phonegap从3.0开始已经不再使用手动的方式搭建项目了,而是使用command-line命令行工具来搭建项目环境,并且插件引入的机制也在3.0做了调整,采用了模块化的方式,即需要什么功能模块就通过命令行工具来安装对应