Puppet nginx+passenger模式配置

一.简述:Puppet 运行在单台服务器上默认启动的是一个puppetmaster进程,当遇到client高并发的请求时,基于ruby的WEBRick HTTP服务便无法高效的处理请求,甚至有的client直接会报400错误。所以在单台服务器上,可以使用nginx+passenger 来做puppetßßßß多负载配置。

二.原理:使用nginx代替ruby的webrick ,并且处理对client的ssl认证进行处理和转发。后台passenger 根据client 请求量的大小,动态的启动puppetmaster进程,从而实现puppet多进程负载

三.实现步骤:

1.使用gem安装rake rack

gem install rake rack

2.安装passenger

由于线上使用的ruby和puppet版本比较新,所以如果使用默认安装的话会安装passenger-5.0版本,而最新版passenger的语法较之前有很大更新,所以,建议使用4.0.19稳定版

gem install passenger -v 4.0.19

3.安装nginx

安装方式有两种,可以自行下载nginx的源码包编译安装,编译的时候需要添加passenger的模块,也可以使用passenger 自动安装,自动选择匹配的版本。下面使用passenger自动安装

执passenger-install-nginx-module

下面的选项1是自动安装nginx,2是自定义安装(可以自定义编译的模块等等),选择1即可

选择完之后,会自动下载nginx源码包,到下面这一步,选择安装nginx的安装路径即可

nginx安装完成

4.配置nginx的主配置文件nginx.conf

添加如下参数;

passenger_root /usr/lib/ruby/gems/1.8/gems/passenger-4.0.19; #指定passenger的root目录,可以使用passenger-config –root得到

passenger_ruby /usr/bin/ruby;  #指定ruby命令的执行路径

passenger_max_pool_size 15;    #定义puppetmaster动态调用的最大进程数量

为了更好的处理请求,可以视情况修改下面参数

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;

5.增加vhosts文件puppet.node.kddi.op.xywy.com.conf,内容如下:

server {

listen           8140 ssl; #由于puppet通信使用的是ssl,所以此处必须定义ssl

server_name      puppet.node.kddi.op.xywy.com;  #puppet服务器的主机名

root         /etc/puppet/rack/public;  #nginx和passenger的协作目录

access_log       /data/logs/nginx/proxy.puppet-access.log;

error_log        /data/logs/nginx/proxy.puppet-error.log;

passenger_enabled on;    #启用passenger模式

passenger_set_cgi_param    HTTP_X_CLIENT_DN $ssl_client_s_dn; #标记client 请求时提供的dn和 VERIFY,用于传递到puppet

passenger_set_cgi_param    HTTP_X_CLIENT_VERIFY $ssl_client_verify;

#ssl 证书的相关配置

ssl_session_timeout  5m;

ssl_certificate /var/lib/puppet/ssl/certs/puppet.node.kddi.op.xywy.com.pem;

ssl_certificate_key /var/lib/puppet/ssl/private_keys/puppet.node.kddi.op.xywy.com.pem;

ssl_client_certificate  /var/lib/puppet/ssl/certs/ca.pem;

ssl_crl      /var/lib/puppet/ssl/ca/ca_crl.pem;

ssl_ciphers      SSLv2:-LOW:-EXPORT:RC4+RSA;

ssl_prefer_server_ciphers on;

ssl_verify_depth     1;

ssl_session_cache    shared:SSL:128m;

ssl_verify_client optional;

}

6.创建rack和public目录,并修改puppet的配置文件puppet.conf

mkdir -pv  /etc/puppet/rack/public

cp /usr/share/puppet/ext/rack/config.ru  /etc/puppet/rack/

chown -R puppet.puppet /etc/puppet/rack

在puppet.conf的[master]下增加下面参数

ssl_client_verify_header = HTTP_X_CLIENT_VERIFY

ssl_client_header = HTTP_X_CLIENT_DN

7.关闭puppetmaster进程,并启动nginx,开始测试

/etc/init.d/puppetmaster stop

/usr/local/xywy/nginx/sbin/nginx

可以使用passenger-status查看现在的状态

同时,nginx也记录了client的请求

Puppet nginx+passenger模式配置的更多相关文章

  1. Nginx pathinfo模式配置

    正常配置 location ~ \.php$ { fastcgi_pass ; fastcgi_index index.php; fastcgi_param SCRIPT_FILENAME $docu ...

  2. Nginx安装及配置详解

    nginx概述 nginx是一款自由的.开源的.高性能的HTTP服务器和反向代理服务器:同时也是一个IMAP.POP3.SMTP代理服务器:nginx可以作为一个HTTP服务器进行网站的发布处理,另外 ...

  3. Nginx安装及配置详解包括windows环境

    nginx概述 nginx是一款自由的.开源的.高性能的HTTP服务器和反向代理服务器:同时也是一个IMAP.POP3.SMTP代理服务器:nginx可以作为一个HTTP服务器进行网站的发布处理,另外 ...

  4. Nginx安装及配置详解【转】

    nginx概述 nginx是一款自由的.开源的.高性能的HTTP服务器和反向代理服务器:同时也是一个IMAP.POP3.SMTP代理服务器:nginx可以作为一个HTTP服务器进行网站的发布处理,另外 ...

  5. [转帖]Nginx安装及配置详解 From https://www.cnblogs.com/zhouxinfei/p/7862285.html

    Nginx安装及配置详解   nginx概述 nginx是一款自由的.开源的.高性能的HTTP服务器和反向代理服务器:同时也是一个IMAP.POP3.SMTP代理服务器:nginx可以作为一个HTTP ...

  6. nginx简介和配置gd

    转自:https://www.cnblogs.com/zhouxinfei/p/7862285.html nginx概述 nginx是一款自由的.开源的.高性能的HTTP服务器和反向代理服务器:同时也 ...

  7. puppet负载均衡之nginx+passenger

    由于3.x系列已不再支持mongrel,所以就采用nginx+passenger来做负载均衡:之前有发过nginx+mongrel,puppet version是2.7系列的,所以还是可以用的: 环境 ...

  8. nginx中error_page没有生效(nginx+passenger+rails)

    应用部署方式为 nginx + passenger + rails 当我想要用nginx来默认处理400以上状态时,发现在rails返回respose之后,nginx不会再次执行error_page( ...

  9. LVS + Keepalived + Nginx安装及配置

    1.概述 上篇文章<架构设计:负载均衡层设计方案(6)——Nginx + Keepalived构建高可用的负载层>(http://blog.csdn.net/yinwenjie/artic ...

随机推荐

  1. MFC绘图基础——上机操作步骤

    一.上机之前的介绍 软件环境:VC++6.0 目的:熟悉基本的MFC框架搭建和了解界面 二.MFC上机操作步骤 1,在Windows桌面上运行VC++6.0. 2,新建项目工程文件. 3,在MFC 应 ...

  2. 函数后面有个 const

    错误场景:类中的重载函数 编译报错: 函数后面加了 const 就好了. 非静态成员函数后面加const(加到非成员函数或静态成员后面会产生编译错误), 表示成员函数隐含传入的this指针为 cons ...

  3. php模拟post提交数据,用处很多,可用来网站的采集,登陆等等

    1. [代码][PHP]代码 <?php //以程序登陆一个论坛登录为例 function bbslogin($user_login, $password, $host, $port = &qu ...

  4. List转DataTable(反射) ; 将泛型集合类转换成DataTable ; 将集合类转换成DataTable

    public class ConvertX { #region 将集合类转换成DataTable /// <summary> /// 将集合类转换成DataTable /// </s ...

  5. swig和angular双花括号的冲突

    swig和angular都用{{name}}来作为模板中变量的取值, 那么要共用的话怎么办: {% raw %}{{ foobar }}{% endraw %} 或者 config(['$interp ...

  6. synchronized关键字的用法总结

    synchronized关键字主要有以下这3种用法: 修饰实例方法,作用于当前实例加锁,进入同步代码前要获得当前实例的锁 修饰静态方法,作用于当前类对象加锁,进入同步代码前要获得当前类对象的锁 修饰代 ...

  7. Unity3D热更新LuaFramework入门实战

    http://blog.sina.com.cn/s/blog_6788cd880102w8qy.html http://www.manew.com/thread-91845-1-1.html http ...

  8. kendo-ui下拉树形选择(DropDownTreeView)

    摘要: 最近项目中有一个特殊的需求,下拉选择部门,但是部门的层级关系要在下来框中体现出来,如下图 下面我就把实现的过程分享给大家,代码如下: dropdowntreeview.js /* * * Dr ...

  9. python单例模式控制成只初始化一次,常规型的python单例模式在新式类和经典类中的区别。

    单例模式的写法非常多,但常规型的单例模式就是这样写的,各种代码可能略有差异,但核心就是要搞清楚类属性 实例属性,就很容易写出来,原理完全一模一样. 如下: 源码: class A(object): d ...

  10. linux ss命令使用详解

    ss是Socket Statistics的缩写.顾名思义,ss命令可以用来获取socket统计信息,它可以显示和netstat类似的内容.但ss的优势在于它能够显示更多更详细的有关TCP和连接状态的信 ...