nginx代理服务器的搭建

来源:互联网 发布:知乎怎么看匿名回答 编辑:程序博客网 时间:2024/06/01 17:08

nginx代理服务器的搭建

标签(空格分隔): nginx


一、什么是nginx?

        【百度百科】Nginx ("engine x") 是一个高性能的HTTP和反向代理服务器,也是一个IMAP/POP3/SMTP服务器。Nginx是由    IgorSysoev为俄罗斯访问量第二的Rambler.ru站点开发的,第一个公开版本0.1.0发布于2004年10月4日。其将源代码以类BSD许    可证的形式发布,因它的稳定性、丰富的功能集、示例配置文件和低系统资源的消耗而闻名。2011年6月1日,nginx 1.0.4发布。    特点:        1、nginx做为HTTP服务器,有以下几项基本特性:        2、处理静态文件,索引文件以及自动索引;打开文件描述符缓冲.        3、无缓存的反向代理加速,简单的负载均衡和容错.        4、FastCGI,简单的负载均衡和容错.        5、模块化的结构。包括gzipping,byteranges,chunkedresponses,以及SSI-filter等filter。如果由FastCGI或其它代理服务器处理单页中存在的多个SSI,则这项处理可以并行运行,而不需要相互等待。        6、支持SSL 和 TLSSNI.        7、Nginx专为性能优化而开发,性能是其最重要的考量,实现上非常注重效率。它支持内核Poll模型,能经受高负载的考验,有报告表明能支持高达 50,000个并发连接数。

二、nginx搭建

  1. 安装依赖(在线安装)

    gcc         [root@mo ~]# yum install gccpcre-devel      [root@mo ~]# yum install pcre-developenssl-devel   [root@mo ~]# yum install openssl-develzlib-devel      [root@mo ~]# yum install zlib-devel
  2. 下载nginx

    使用nginx和第三方分布式插件nginx-sticky-module,两者的版本号必须相同。使用版本:nginx-1.11.1.tar.gz /nginx-sticky-module-1.1.tar.gz
  3. 解压nginx、nginx-module

    [root@mo ~]# tar -zxf nginx-1.11.1.tar.gz[root@mo ~]# tar -zxf nginx-sticky-module-1.1.tar.gz
  4. 修改nginx‐sƟcky‐module中的c文件

    a.修改ngx_http_sticky_misc.c将281行代码:    digest->len = ngx_sock_ntop(in, digest->data, len, 1);修改为:    digest->len = ngx_sock_ntop(in,sizeof(struct sockaddr_in),digest->data, len, 1);b.修改ngx_http_sticky_module.c    1. 在文件开头添加【】内内容        【#include <nginx.h>】        #include <ngx_config.h>        ....    2.修改333行修改为【】内内容        iphp->rrp.current = iphp->selected_peer;        【               #if defined(nginx_version) && nginx_version >= 1009000            iphp->rrp.current = peer;            #else            iphp->rrp.current = iphp->selected_peer;            #endif        】
  5. 编译nignx

    注:/root/nginx-sticky-module-1.1为nginx-module的解压路径[root@mo ~]# ./configure --add-module=/root/nginx-sticky-module-1.1[root@mo ~]# make[root@mo ~]# make install说明:如果使用nginx-1.0.6.tar.gz是不需要做任何改动了,添加nginx-sticky是为了优化nginx的ip_hash负载均衡算法的负载不够均衡问题
  6. nignx相关命令

    nginx启动           [root@mo nginx]# ./sbin/nginx查看nignx进程       [root@mo nginx]# ps -ax |grep nginx强制关闭nignx       [root@mo nginx]# ./sbin/nginx -s stop优雅关闭nignx       [root@mo nginx]# ./sbin/nginx -s quit重新加载配置文件    [root@mo nginx]# ./sbin/nginx -s reload检查配置文件是否有错    [root@mo nginx]# ./sbin/nginx -t注:优雅关闭指定的是nginx会在响应完最后一个请求后关闭nginx

    启动在nginx可以在浏览器敲http://IP 如: http://192.168.95.128 显示如下图则成功

这里写图片描述

  1. 配置集群案例

    upstream 192.168.95.128 {    server 192.168.0.117:8081 weight=1;    server 192.168.0.117:8082 weight=2;    #开启cookies的黏着    sticky;    #sticky|least_conn| ip_hash;}location / {        proxy_pass http://192.168.95.128;}注:sticky | least_conn | ip_hash;三种负载均衡策略。sticky为插件支持upstream 的 192.168.95.128和proxy_pass中的192.168.95.128必须相同而且最好为IP地址

本示例可以结合上篇示例进行综合测试。

0 0
原创粉丝点击