设为首页 收藏本站
查看: 931|回复: 0

[经验分享] Puppet系列之四:Puppet利用Nginx多端口实现负载均衡

[复制链接]

尚未签到

发表于 2018-8-2 12:59:31 | 显示全部楼层 |阅读模式
  1 概述
  当代理服务器数量增加时,单台puppetmaster压力增大,会出现解析缓慢,甚至出现“time out”之类报错的错误。Nginx工作于网络的七层之上,可以作为负载均衡服务器。利用Load Balancing可以优化上述出现的问题。
  2 服务器环境及软件版本
  server version:CentOS6.5 i386
  Ruby:ruby-1.8.7.352-13.el6.i686
  Puppet: puppet-2.7.23
  Nginx: nginx-1.4.4
  
  3 安装Mongrel
  
  通过指定mongrel类型来使用puppet多端口配置
  yum install -y rubygem-mongrel
  4 配置puppetmaster
  vim /etc/sysconfig/puppetmaster,添加以下两行,分别代表多端口、mongrel类型
  PUPPETMASTER_PORTS=(8141 8142 8143 8144 8145 )
  PUPPETMASTER_EXTRA_OPTS="--servertype=mongrel --ssl_client_header=HTTP_X_SSL_SUBJECT"
  
  5 安装Nginx服务
  安装之前请确保系统已经安装pcre-devel正则库,然后再编译安装Nginx,需要添加SSL模块参数支持,Nginx的安装过程如下所示:
  yum -y install pcre-devel
  cd $hd
  wget http://nginx.org/download/nginx-1.4.4.tar.gz
  tar zxvf nginx-1.4.4.tar.gz
  cd nginx-1.4.4
  ./configure --prefix=/usr/local/nginx --with-http_ssl_module
  make && make install
  添加www用户组及用户:
  groupadd www
  useradd -g www www
  6 配置Nginx
  vim /usr/local/nginx/conf/nginx.conf:
  user www;
  worker_processes 8;
  events{
  worker_connections 65535;
  }
  http{
  include      mime.types;
  default_type application/octet-stream;
  #定义puppet客户端访问puppet-server端日志格式  
  log_format main  '$remote_addr - $remote_user [$time_local] "$request"$request_length $request_time $time_local'
  '$status$body_bytes_sent $bytes_sent $connection $msec "$http_referer"'      '"$http_user_agent""$http_x_forwarded_for" upstream_response_time$upstream_addr $upstream_status ';
  access_log /usr/local/nginx/logs/access.log  main;
  sendfile       on;
  tcp_nopush    on;
  keepalive_timeout 65;
  upstreampuppetmaster {
  server127.0.0.1:8141;
  server127.0.0.1:8142;
  server127.0.0.1:8143;
  server127.0.0.1:8144;
  server127.0.0.1:8145;
  }
  server{
  listen      8140;
  root /etc/puppet;
  ssl on;
  ssl_session_timeout 5m;
  #如下为puppemaster服务器端证书地址
  ssl_certificate /var/lib/puppet/ssl/certs/rango.fugue.com.pem;
  ssl_certificate_key /var/lib/puppet/ssl/private_keys/rango.fugue.com.pem;
  ssl_client_certificate /var/lib/puppet/ssl/ca/ca_crt.pem;
  ssl_crl /var/lib/puppet/ssl/ca/ca_crl.pem;
  ssl_verify_client optional;
  #File sections
  location /production/file_content/files/ {
  types{ }
  default_type application/x-raw;
  #定义puppet推送路径别名
  alias /etc/puppet/files/;
  }
  #Modules files sections
  location ~ /production/file_content/modules/.+/ {
  root /etc/puppet/modules;
  types{ }
  default_type application/x-raw;
  rewrite ^/production/file_content/modules/(.+)/(.+)$ /$1/files/$2 break; }
  location/ {
  ##设置跳转到puppetmaster负载均衡
  proxy_pass http://puppetmaster;
  proxy_redirect off;
  proxy_set_header Host $host;
  proxy_set_header X-Real-IP $remote_addr;
  proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
  proxy_set_header X-Client-Verify $ssl_client_verify;
  proxy_set_header X-SSL-Subject $ssl_client_s_dn;
  proxy_set_header X-SSL-Issuer $ssl_client_i_dn;
  proxy_buffer_size 10m;
  proxy_buffers 1024 10m;
  proxy_busy_buffers_size 10m;
  proxy_temp_file_write_size 10m;
  proxy_read_timeout 120;
  }
  }
  }
  7 启动Nginx及puppet-server
  7.1 首先关闭puppetmaster进程:/etc/init.d/puppetmaster stop
  7.2 启动Nginx
  /usr/local/nginx/sbin/nginx
  nginx占用puppetmaster默认的8140端口后,用如下命令来检查8140端口是否被nginx接管:
  lsof-i:8140
  此命令显示结果表明8140被nginx进程接管:

  COMMAND  PID USER   FD   TYPE  DEVICE>  nginx  12433 root    6u  IPv4 1309402      0t0  TCP *:8140 (LISTEN)
  nginx  12434  www    6u  IPv4 1309402      0t0  TCP *:8140 (LISTEN)
  nginx  12435  www    6u  IPv4 1309402      0t0  TCP *:8140 (LISTEN)
  nginx  12436  www    6u  IPv4 1309402      0t0  TCP *:8140 (LISTEN)
  nginx  12437  www    6u  IPv4 1309402      0t0  TCP *:8140 (LISTEN)
  nginx  12438  www    6u  IPv4 1309402      0t0  TCP *:8140 (LISTEN)
  nginx  12439  www    6u  IPv4 1309402      0t0  TCP *:8140 (LISTEN)
  nginx  12440  www    6u  IPv4 1309402      0t0  TCP *:8140 (LISTEN)
  nginx  12441  www    6u  IPv4 1309402      0t0  TCP *:8140 (LISTEN)
  7.3 启动puppetmaster
  /etc/init.d/puppetmaster start
  Starting puppetmaster:
  Port:8141                                                 [  OK  ]
  Port:8142                                                 [  OK  ]
  Port:8143                                                 [  OK  ]
  Port:8144                                                 [  OK  ]
  Port:8145                                                 [  OK  ]
  8 总结
  本文旨在讲述通过基于网络七层的软件负载均衡技术Nginx,结合puppet的多端口设置来构建puppet的load balancing网络,达到优化puppet吞吐,缓解解析压力的目的。后续文章将着力于puppet report相关的内容。
  ——RangoChen

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-545390-1-1.html 上篇帖子: Puppet系列之三:Puppet结合SVN实现版本的集中化备份与恢复 下篇帖子: Puppet系列之五:Puppet报告系统Dashboard安装与配置
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表