nginx二 之负载均衡搭建

nginx介绍

nginx是一个轻量级的web服务器,也是一款高性能的反向代理服务器,另外nginx使用简单,易于维护扩展。 

环境准备

centos6.5

tomcat7

nginx1.8.1

环境搭建

安装nginx依赖


下载nginx依赖包

1.gzip 模块需要 zlib 库,笔者所使用的版本: zlib-1.2.11.tar.gz( 下载: http://www.zlib.net/ ) 

2.rewrite 模块需要 pcre 库,笔者所使用的版本:  pcre-8.38.tar.gz( 下载: http://www.pcre.org/ )

3.ssl 功能需要 openssl 库,笔者所使用的版本: openssl-1.0.0o.tar.gz ( 下载: http://www.openssl.org/ )

编译安装

 安装c++编译环境:

#yum安装
yum install gcc-c++ yes

安装openssl:

#解压
tar -zxvf openssl-1.0.0o.tar.gz
#进入解压目录
cd openssl-1.0.0o
#编译安装
./config && make && make install

安装zlib:

#解压
tar -zxvf zlib-1.2.11.tar.gz
#进入解压目录
cd zlib-1.2.11
#编译安装 ./configure && make && make install

安装pcre:

#解压
tar -zxvf pcre-8.38.tar.gz
#进入解压目录
cd pcre-8.38
#编译安装
./configure && make && make install

安装nginx


下载安装包

1.nginx缓存模块需要搭配ngx_cache_purge,笔者所使用的版本:ngx_cache_purge-2.3.tar.gz(下载: http://labs.frickle.com/files/ ) 

2.nginx,笔者所使用的版本:nginx-1.8.1.tar.gz(下载: http://nginx.org/ ) 

编译安装

#解压ngx_cache_purge
tar  -zxxf ngx_cache_purge-2.3.tar.gz
#解压nginx
tar -zxvf nginx-1.8.1.tar.gz
#进入nginx解压目录
cd nginx-1.8.1
#编译ngx_cache_purge模块
./configure --add-module=../ngx_cache_purge-2.3 --prefix=/usr/local/nginx
#安装
make && make install

异常解决

安装完成后,验证nginx:

/usr/local/nginx/sbin/nginx -t

发现报错了:

 error while loading shared libraries: libpcre.so.1: cannot open shared object file: No such file or directory...

先找到libpcre.so.1所在位置,然后做个软链接就可以了:

whereis libpcre.so.1

libpcre.so: /lib64/libpcre.so.0 /usr/local/lib/libpcre.so /usr/local/lib/libpcre.so.1

ln -s /usr/local/lib/libpcre.so.1 /lib64

再次验证:

/usr/local/nginx/sbin/nginx -t

安装jdk


下载安装包

笔者所使用的版本:jdk-7u79-linux-x64.tar.gz(下载: http://www.oracle.com/technetwork/java/javase/downloads/index.html ) 

安装配置

#解压
tar -zxvf jdk-7u79-linux-x64.tar.gz
#将jdk添加到环境变量中
vim /etc/profile
#在文件最后添加
export JAVA_HOME=/home/hadoop/jdk1.7.0_79
export PATH=$PATH:$JAVA_HOME/bin
#刷新配置
source /etc/profile

安装tomcat


下载安装包

 笔者所使用的版本:tomcat7(下载: http://tomcat.apache.org/download-70.cgi ) 

安装配置

#解压
tar -zxvf apache-tomcat-7.0.64.tar.gz
#复制一个tomcat
...
#修改其中一个tomcat中的server.xml为:
<Server port="8005"shutdown="SHUTDOWN"> 改为 8006
<Connector port="8080"protocol="HTTP/1.1" 改为 8081
<Connector port="8009"protocol="AJP/1.3" 改为 8010

添加测试页面

1、新建test.jsp页面,放置tomcat1的demo项目下,内容如下:

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Tomcat1</title>
</head>
<body>
 SessionID: <%= session.getId() %>
</body>
</html>

2、test.jsp中的title为Tomcat2,以便测试区分。

启动tomcat

 1、启动tomcat1

#进入tomcat解压的bin目录
cd /home/hadoop/apache-tomcat-7.0.64_1/bin
#启动tomcat
./catalina.sh

2、启动tomcat 2

配置负载均衡


添加集群、代理

#进入nginx安装的conf目录
cd /usr/local/nginx/conf/
#打开nginx.conf文件添加以下内容:
upstream dynamic_server { 
    server 192.168.1.111:8080 weight=1 max_fails=2 fail_timeout=30s;
    server 192.168.1.111:8081 weight=1 max_fails=2 fail_timeout=30s; 
} 

location / {
    proxy_pass http://dynamic_server; 
}

完整的配置文件

#工作进程个数:多开几个可以减少io带来的影响,
#根据 lscpu查出来的cpus设置(一般为当前机器核心数的1-2倍,最大不超过8),
worker_processes 2; 


#worker_cpu_affinity需要结合worker_processes使用,一个worker_processes绑定一个CPU,
#比如两核是01,四核是0001,下面是2核绑定2个worker_processes的示例
worker_cpu_affinity 01 10;


#nginx运行日志
#error_log logs/error.log error;


events {

    #使用epoll模型提高性能
    use epoll;

    #单个进程连接数(最大连接数=连接数*进程数)
    worker_connections 65535;
}


http {

    #文件扩展名与文件类型映射表 
    include mime.types;

    #默认文件类型 
    default_type application/octet-stream;


    #开启高效文件传输模式,sendfile指令指定nginx是否调用sendfile函数来输出文件,对于普通应用设为 on,
    #如果用来进行下载等应用磁盘IO重负载应用,可设置为off,以平衡磁盘与网络I/O处理速度,降低系统的负载。
    #注意:如果图片显示不正常把这个改成off
    sendfile on;

    #长连接超时时间,单位是秒 
    keepalive_timeout 65;
    
    #gzip 是告诉nginx采用gzip压缩的形式发送数据。这将会减少我们发送的数据量。
    gzip on;
    gzip_min_length 1k; #最小1K
    gzip_buffers 16 64K;
    gzip_http_version 1.1;
    gzip_comp_level 6;
    gzip_types text/plain application/x- text/css application/xml application/;
    gzip_vary on;


    #header设置:用户真实的ip地址转发给后端服务器
    proxy_set_header Host $host;
    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    proxy_set_header X-Real-IP $remote_addr;


    #缓冲
    client_body_buffer_size 512k;
    proxy_connect_timeout 5;
    proxy_read_timeout 60;
    proxy_send_timeout 5;
    proxy_buffer_size 16k;
    proxy_buffers 4 64k;
    proxy_busy_buffers_size 128k;
    proxy_temp_file_write_size 128k;


    
    ################################################集群 ###################################################    

    #动态资源集群
    upstream dynamic_server { 

        #服务器配置 weight是权重的意思,权重越大,分配的概率越大。 
        server 192.168.1.111:8080 weight=1 max_fails=2 fail_timeout=30s;
        server 192.168.1.111:8081 weight=1 max_fails=2 fail_timeout=30s; 
    } 



    ################################################Nginx代理###################################################    
    server {

        #监听80端口,可以改成其他端口 
        listen 80;

        #nginx服务的域名,通过域名就可以访问应用
        server_name localhost;

        #反向代理:转发到后端的tomcat集群
        location / {

            proxy_pass http://dynamic_server; 
        }

        #错误提示页面
        error_page 500 502 503 504 /50x.html;
        location = /50x.html {
            root html;
        }
    }
}
View Code

启动nginx

#验证配置文件
/usr/local/nginx/sbin/nginx -t
#启动nginx
/usr/local/nginx/sbin/nginx

nginx常用命令

启动         :/usr/local/nginx/sbin/nginx
停止/重新加载:/usr/local/nginx/sbin/nginx -s stop(quit、reload)
验证配置文件 :/usr/local/nginx/sbin/nginx -t
命令帮助     :/usr/local/nginx/sbin/nginx -h

测试

开通防火墙


#编辑iptables文件
vi /etc/sysconfig/iptables
#在22端口下一行添加tomcat、nginx端口
-A INPUT -m state --state NEW -m tcp -p tcp --dport 8080 -j ACCEPT
-A INPUT -m state --state NEW -m tcp -p tcp --dport 8081 -j ACCEPT
-A INPUT -m state --state NEW -m tcp -p tcp --dport 80 -j ACCEPT
#让配置文件生效
/etc/init.d/iptables restart 

测试负载均衡


 浏览器打开两个窗口,访问测试页面, 我们可以看到nginx地址分别代理了tomcat1、tomcat2:

原文地址:https://www.cnblogs.com/dahuandan/p/6753646.html