Nginx+Tomcat实现动静分离以及负载均衡
来源:互联网 发布:傲剑神照升级数据大全 编辑:程序博客网 时间:2024/06/03 21:12
由于资源有限,本次实验在同一台虚拟机上进行,结构为
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; } }}
测试
- 创建测试项目,编写测试代码:
- 修改index.jsp
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%> <%@ page import="java.text.SimpleDateFormat"%> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <title>Tomcat集群/动静分离测试</title> </head> <body> <% out.println("["+request.getLocalAddr()+":" +request.getLocalPort()+"]" + "<br/>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,此时页面图片不能显示。
需要在/usr/local/创建 webapps/test/img目录,并将静态图片nginx.png拷贝到这个目录下面,然后访问。
(由于配置8080和8081的权重都为1,所以两次访问,基本上两个tomcat分别访问一次)
阅读全文
0 0
- Nginx+Tomcat实现动静分离以及负载均衡
- Nginx + Tomcat 动静分离实现负载均衡
- Nginx + Tomcat 动静分离实现负载均衡
- Nginx + Tomcat 动静分离实现负载均衡
- Nginx + Tomcat 动静分离实现负载均衡
- Nginx + Tomcat 动静分离实现负载均衡
- Nginx + Tomcat 动静分离实现负载均衡
- Nginx + Tomcat 动静分离实现负载均衡
- Nginx + Tomcat 动静分离实现负载均衡
- Nginx + Tomcat 动静分离实现负载均衡
- Nginx + Tomcat 实现动静分离负载均衡
- Nginx+Tomcat 动静分离实现负载均衡
- Nginx+Tomcat 动静分离实现负载均衡
- Nginx + Tomcat 动静分离实现负载均衡
- Nginx+Tomcat 实现动静分离、负载均衡
- Nginx + Tomcat 动静分离实现负载均衡
- Nginx + Tomcat 动静分离实现负载均衡
- Nginx+tomcat 实现负载均衡和动静分离
- DP(记忆化搜索) -- poj Function Run Fun
- es6箭头函数this指向
- C++之shared_ptr总结
- java中Double类型的运算精度丢失的问题 (小数点多出99999999999999)
- opencv(五)--图像的算术运算
- Nginx+Tomcat实现动静分离以及负载均衡
- 关于 redis、memcache、mongoDB 的对比
- 一次ionic3上传图片的经历
- 项目开发步骤
- ActiveMQ简单介绍以及安装
- POJ 3617 字典序最小
- Maven学习入门
- 机器视觉资料
- 如何在XCode上禁用indexing