当前位置: 首页 > news >正文

nginx+tomcat动静分离、负载均衡

一、理论
nginx用于处理静态页面以及做调度器,tomcat用于处理动态页面

lvs(四层)
轮询(rr)
加权轮询(wrr)
最小连接(lc)
加权最小连接(wlc)

nginx(四层、七层)
轮询(rr)
最小连接(leastconn)
ip哈希(ip_hash)

haproxy(四层、七层)
轮询(roundrobin)
加权轮询(static-rr)
最小连接(leastconn)
源地址哈希(source)

调度器和代理服务器的区别
代理服务器:客户端的请求和服务器的应答都通过代理服务器来传输。

调度器:
    NAT  客户端的请求和服务器的应答都通过代理服务器来传输。
    DR   客户端的请求通过调度器传输,服务器直接应答给客户端,不经过调度器。
    TUN  客户端的请求通过调度器传输,服务器直接应答给客户端,不经过调度器。
 

二、实践

1、实验环境
tomcat1 192.168.10.101
tomcat2 192.168.10.102
nginx 	192.168.10.103
2、过程
[root@tomcat1 ~]# ls
anaconda-ks.cfg  apache-tomcat-9.0.8.tar.gz  jdk-8u102-linux-x64.rpm
[root@tomcat1 ~]# java -version
-bash: java: 未找到命令
[root@tomcat1 ~]# dnf -y install jdk-8u102-linux-x64.rpm 
[root@tomcat1 ~]# java -version
java version "1.8.0_102"
Java(TM) SE Runtime Environment (build 1.8.0_102-b14)
Java HotSpot(TM) 64-Bit Server VM (build 25.102-b14, mixed mode)
[root@tomcat1 ~]# tar xf apache-tomcat-9.0.8.tar.gz 
[root@tomcat1 ~]# mv apache-tomcat-9.0.8/ /usr/local/tomcat9
[root@tomcat1 ~]# /usr/local/tomcat9/bin/startup.sh
Using CATALINA_BASE:   /usr/local/tomcat9
Using CATALINA_HOME:   /usr/local/tomcat9
Using CATALINA_TMPDIR: /usr/local/tomcat9/temp
Using JRE_HOME:        /usr
Using CLASSPATH:       /usr/local/tomcat9/bin/bootstrap.jar:/usr/local/tomcat9/bin/tomcat-juli.jar
Tomcat started.
[root@tomcat1 ~]# netstat -anpt | grep 8080
tcp6       0      0 :::8080                 :::*                    LISTEN      2401/java   
[root@tomcat1 ~]# mkdir -pv /web/webapp1
mkdir: 已创建目录 '/web'
mkdir: 已创建目录 '/web/webapp1'
[root@tomcat1 ~]# cat /web/webapp1/index.jsp
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%> <html>
<head>
<title>JSP test1 page</title> </head>
<body>
<% out.println("动态页面1,http://www.ooos.com");%> </body>
<body>
<div>静态页面的图片1 </div><br><img src="logo.png">
</body></html>[root@tomcat1 ~]# vim /usr/local/tomcat9/conf/server.xml<Host name="localhost"  appBase="webapps"unpackWARs="true" autoDeploy="true">……略<Context docBase="/web/webapp1" path="" reloadable="false"></Context></Host>
[root@tomcat1 ~]# /usr/local/tomcat9/bin/shutdown.sh
[root@tomcat1 ~]# /usr/local/tomcat9/bin/startup.sh[root@tomcat2 ~]# ls
anaconda-ks.cfg  apache-tomcat-9.0.8.tar.gz  jdk-8u102-linux-x64.rpm
[root@tomcat2 ~]# java -version
-bash: java: 未找到命令
[root@tomcat2 ~]# dnf -y install jdk-8u102-linux-x64.rpm 
[root@tomcat2 ~]# java -version
java version "1.8.0_102"
Java(TM) SE Runtime Environment (build 1.8.0_102-b14)
Java HotSpot(TM) 64-Bit Server VM (build 25.102-b14, mixed mode)
[root@tomcat2 ~]# tar xf apache-tomcat-9.0.8.tar.gz 
[root@tomcat2 ~]# mv apache-tomcat-9.0.8/ /usr/local/tomcat9
[root@tomcat2 ~]# /usr/local/tomcat9/bin/startup.sh
Using CATALINA_BASE:   /usr/local/tomcat9
Using CATALINA_HOME:   /usr/local/tomcat9
Using CATALINA_TMPDIR: /usr/local/tomcat9/temp
Using JRE_HOME:        /usr
Using CLASSPATH:       /usr/local/tomcat9/bin/bootstrap.jar:/usr/local/tomcat9/bin/tomcat-juli.jar
Tomcat started.
[root@tomcat2 ~]# netstat -anpt | grep 8080
tcp6       0      0 :::8080                 :::*                    LISTEN      2401/java   
[root@tomcat2 ~]# mkdir -pv /web/webapp1
mkdir: 已创建目录 '/web'
mkdir: 已创建目录 '/web/webapp1'
[root@tomcat2 ~]# cat /web/webapp1/index.jsp
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%> <html>
<head>
<title>JSP test2 page</title> </head>
<body>
<% out.println("动态页面2,http://www.sooo.com");%> </body>
<body>
<div>静态页面的图片2 </div><br><img src="logo.png">
</body></html>[root@tomcat2 ~]# vim /usr/local/tomcat9/conf/server.xml<Host name="localhost"  appBase="webapps"unpackWARs="true" autoDeploy="true">……略<Context docBase="/web/webapp1" path="" reloadable="false"></Context></Host>
[root@tomcat2 ~]# /usr/local/tomcat9/bin/shutdown.sh
[root@tomcat2 ~]# /usr/local/tomcat9/bin/startup.sh[root@nginx ~]# dnf -y install gcc* make pcre-devel zlib-devel openssl-devel perl-ExtUtils-MakeMaker
[root@nginx ~]# useradd -M -s /sbin/nologin nginx
[root@localhost ~]# ls
anaconda-ks.cfg  logo.png  nginx-1.26.3.tar.gz
[root@localhost ~]# tar zxf nginx-1.26.3.tar.gz 
[root@localhost ~]# cd nginx-1.26.3
[root@localhost nginx-1.26.3]# ./configure --prefix=/usr/local/nginx --user=nginx --group=nginx --with-http_ssl_module --with-http_v2_module --with-pcre
[root@localhost nginx-1.26.3]# make -j$(nproc) && make install[root@localhost nginx-1.26.3]# cat /usr/local/nginx/html/index.html
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="content-type" content="text/html;charset=utf-8">
<title>静态页面</title>
<style>
body { width: 35em; margin: 0 auto;
font-family: Tahoma, Verdana, Arial, sans-serif; }
</style>
</head>
<body>
<h1>静态页面</h1>
<p>这是个静态页面</p>
</body>
</html>
[root@localhost nginx-1.26.3]# vim /usr/local/nginx/conf/nginx.conf
http {……略
upstream tomcat_server {server 192.168.10.101:8080 weight=1;server 192.168.10.102:8080 weight=1;
}server {listen       80;server_name  localhost;#charset koi8-r;#access_log  logs/host.access.log  main;location ~.*.jsp$ {proxy_set_header HOST $host;proxy_set_header X-Real-IP $remote_addr;proxy_set_header Client-IP $remote_addr;proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;proxy_pass http://tomcat_server;}注: 	~是匹配规则 用于正则url前,表示url包含正则表达式,区分大小写。.*两者组合表示匹配任意个字符串, .表示匹配除换行外任意一个字符串,*表示匹配0个或多个字符串。. 表示匹配除换行外任意一个字符串。jsp$ 表示匹配以jsp结尾的。proxy_set_header HOST $host;+ proxy_set_header表示设置请求头,HOST是变量名,$host是变量值,$host是nginx内置的函数,用于表示请求的虚拟主机。该值会封装在请求头中,用于请求tomcat中的具体虚拟主机。(该参数仅在后端服务器是tomcat时添加,因为tomcat中使用<Host></Host>标签符来表示虚拟主机,传递给tomcat时,tomcat通过该请求头就能知道客户端请求的是哪个虚拟主机,给它提供服务。如果不添加,访问网站会显示400 bad request。)proxy_set_header X-Real-IP $remote_addr; proxy_set_header表示设置请求头,X-Real-IP是变量名, $remote_addr是变量值,$remote_addr是nginx内置的函数,用于表示客户端的ip地址。 该值用于传递给tomcat使用,客户端通过代理访问tomcat,在tomcat上更改日志设置,即可在tomcat的访问日志中会显示客户端的真实IP地址。proxy_set_header Client-IP $remote_addr;  proxy_set_header表示设置请求头,Client-ip是变量名 $remote_addr是变量值,$remote_addr是nginx内置的函数,用于表示客户端的IP地址。该值会封装在请求头中,交给代理服务器使用。proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;  proxy_set_header表示设置请求头,X-Forwarded-For是变量名,$proxy_add_x_forwarded_for是变量值,$proxy_add_x_forwarded_for是nginx内置的函数,用于将客户端的ip地址传递给后端真实服务器。在多层代理中(例如,nginx01代理四层,nginx02代理七层,nginx01将请求发送给nginx02,nginx02再将请求发送给后端真实服务器)需要获取客户端的真实ip,就加上该参数即可。该参数会逐级传递客户端的真实ip。location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)$ {root /usr/local/nginx/html/img;expires 30d;}注:expires 设置缓存,30d表示缓存30天。location / {root   html;index  index.html index.htm;}
}
}[root@localhost ~]# mkdir /usr/local/nginx/html/img
[root@localhost ~]# cp logo.png /usr/local/nginx/html/img/
[root@localhost ~]# /usr/local/nginx/sbin/nginx 
[root@localhost sbin]# curl 192.168.10.103
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="content-type" content="text/html;charset=utf-8">
<title>静态页面</title>
<style>
body { width: 35em; margin: 0 auto;
font-family: Tahoma, Verdana, Arial, sans-serif; }
</style>
</head>
<body>
<h1>静态页面</h1>
<p>这是个静态页面</p>
</body>
</html>
[root@localhost sbin]# curl 192.168.10.103/index.jsp<html>
<head>
<title>JSP test1 page</title> </head>
<body>
动态页面1,http://www.ooos.com</body>
<body>
<div>静态页面的图片1 </div><br><img src="logo.png">
</body></html>[root@localhost sbin]# curl 192.168.10.103/index.jsp<html>
<head>
<title>JSP test1 page</title> </head>
<body>
动态页面2,http://www.sooo.com</body>
<body>
<div>静态页面的图片2 </div><br><img src="logo.png">
</body></html>tomcat server.xmlpattern="%{X-Real-IP}i"

http://www.lqws.cn/news/88165.html

相关文章:

  • Python爬虫监控程序设计思路
  • Nginx+Tomcat 负载均衡群集
  • Nginx+Tomcat负载均衡
  • 高效图像处理:使用 Pillow 进行格式转换与优化
  • 【C++项目】负载均衡在线OJ系统-1
  • 黑马Java面试笔记之 消息中间件篇(Kafka)
  • Flink 重启后事件被重复消费的原因与解决方案
  • Kafka 的优势是什么?
  • 云原生时代 Kafka 深度实践:06原理剖析与源码解读
  • AI“实体化”革命:具身智能如何重构体育、工业与未来生活
  • 三、kafka消费的全流程
  • # [特殊字符] Unity UI 性能优化终极指南 — LayoutGroup篇
  • Kafka 和Redis 在系统架构中的位置
  • 【ISAQB大纲解读】Kafka消息总线被视为“自下而上设计”?
  • 云原生时代 Kafka 深度实践:05性能调优与场景实战
  • 打卡第35天:GPU训练以及类的Call方法
  • 使用Composer创建公共类库
  • 工厂模式与多态结合
  • Rhino插件大全下载指南:解锁犀牛潜能,提升设计效率
  • llama.cpp:纯 C/C++ 实现的大语言模型推理引擎详解一
  • Spring AOP:面向切面编程 详解代理模式
  • JavaSec | SpringAOP 链学习分析
  • 【 java 集合知识 第一篇 】
  • 网络攻防技术七:计算机木马
  • git管理
  • Linux 环境下高效视频切帧的实用指南
  • ES6 Promise 状态机
  • 在linux系统上搭建git服务器(ssh协议)
  • k8s的出现解决了java并发编程胡问题了
  • sudo docker exec -it backend bash 以交互方式(interactive)进入正在运行的 Docker 容器的命令行环境