Nginx+Tomcat实现动静分离以及负载均衡

由于资源有限,本次实验在同一台虚拟机上进行,结构为
Nginx+Tomcat实现动静分离以及负载均衡_第1张图片
1. 添加组 groupadd www
2. 在www组下添加用户www: useradd -g www www
3. 修改配置文件nginx.conf:

user www www;
worker_processes 2;
events{
         worker_connections 1024; 
}
http{
    #设置默认类型为二进制流
    default_type    application/octet-stream;
    server_names_hash_bucket_size   128;
    #指定来自客户端请求头的headerbuffer大小,设置为32KB
    client_header_buffer_size   32k;
    #指定客户端请求中较大的消息头的缓存最大数量和大小,这里是4个32KB
    large_client_header_buffers 4 32k;
    #上传文件大小
    client_max_body_size 356m;
    #nginx的HttpLog模块指定,指定nginx日志的输出格式,输出格式为access
    log_format access '$remote_addr - $remote_user [$time_local] "$request" '
        '$status $body_bytes_sent "$http_referer" '
        '"$http_user_agent" "$http_x_forwarded_for"';
        #access日志存在未知
    access_log  /var/log/nginx/access.log   access;
    #开启高效模式文件传输模式,将tcp_nopush和tcp_nodelay两个指另设置为on,用于防止网络阻塞。
    sendfile    on;
    tcp_nopush  on;
    tcp_nodelay on;
    #设置客户端连接保持活动的超时时间
    keepalive_timeout   65;
    server_tokens   off;
    #客户端请求主体读取缓存
    client_body_buffer_size 512k;
    proxy_connect_timeout   5;
    proxy_send_timeout      60;
    proxy_read_timeout      5;
    proxy_buffer_size       16k;
    proxy_buffers           4 64k;
    proxy_busy_buffers_size 128k;
    proxy_temp_file_write_size 128k;
    #开启gzip
    gzip    on;
    #允许压缩的最小字节数
    gzip_min_length 1k;
    #4个单位为16k的内存作为压缩结果流缓存
    gzip_buffers 4 16k;
    #设置识别HTTP协议版本,默认是1.1
    gzip_http_version 1.1;
    #gzip压缩比,可在1~9中设置,1压缩比最小,速度最快,9压缩比最大,速度最慢,消耗CPU
    gzip_comp_level 2;
    #压缩的类型
    gzip_types text/plain application/x-javascript text/css application/xml;
    #让前端的缓存服务器混村经过的gzip压缩的页面
     gzip_vary   on;

     upstream mycluster{
              server 192.168.25.128:8080 weight=1;
              server 192.168.25.128:8081 weight=1;
     }
    server{
              listen 8088;
              server_name 192.168.25.128;
              charset    utf-8; #设置编码为utf-8;

            #location / {
            #    root   html;
            #    index  index.html index.htm;
            #}

            #location ~ .*\.(jsp|do|action)$
           location / {
                 proxy_next_upstream http_502 http_504 error timeout invalid_header;
                 proxy_pass http://mycluster;
                 # 真实的客户端IP
                 proxy_set_header   X-Real-IP        $remote_addr; 
                 # 请求头中Host信息
                 proxy_set_header   Host             $host; 
                 # 代理路由信息,此处取IP有安全隐患
                 proxy_set_header   X-Forwarded-For  $proxy_add_x_forwarded_for;
                  # 真实的用户访问协议
                 proxy_set_header   X-Forwarded-Proto $scheme;
            }
       #静态文件交给nginx处理
       location ~ .*\.(htm|html|gif|jpg|jpeg|png|bmp|swf|ioc|rar|zip|txt|flv|mid|doc|ppt|pdf|xls|mp3|wma)$
        {
              root  /usr/local/webapps;
             expires 30d;
         }
         #静态文件交给nginx处理
        location ~ .*\.(js|css)?$
        {
               root /usr/local/webapps;
               expires 1h;
        }
        error_page   500 502 503 504  /50x.html;  
        location = /50x.html {
             root   html;
         }

      }}

测试

  1. 创建测试项目,编写测试代码:
    Nginx+Tomcat实现动静分离以及负载均衡_第2张图片
  2. 修改index.jsp
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>  
<%@ page import="java.text.SimpleDateFormat"%>  
  
<html>  
  <head>  
    <title>Tomcat集群/动静分离测试title>  
  head>  
  <body>  
    <%  
        out.println("["+request.getLocalAddr()+":" +request.getLocalPort()+"]" + "
session id:"
+ session.getId()); %>
<h1>images:h1> <img src="img/nginx.png" /> body> html>

3 . 将写好的代码打成war包,分别放到两个tomcat的webapps下面。端口分别为 8080、8005、8009和8081、8006、8010。并启动tomcat。
这里写图片描述
4. 访问http://192.168.25.128:8088/test,此时页面图片不能显示。
Nginx+Tomcat实现动静分离以及负载均衡_第3张图片
Nginx+Tomcat实现动静分离以及负载均衡_第4张图片
需要在/usr/local/创建 webapps/test/img目录,并将静态图片nginx.png拷贝到这个目录下面,然后访问。
Nginx+Tomcat实现动静分离以及负载均衡_第5张图片
Nginx+Tomcat实现动静分离以及负载均衡_第6张图片

(由于配置8080和8081的权重都为1,所以两次访问,基本上两个tomcat分别访问一次)

你可能感兴趣的:(Nginx)