所有请求都需要经过代理,由代理转发所有请求给提供服务的系统
正向代理
用户的目标是请求目标服务器,但是自己无法达到,所以通过代理来达到。
反向代理
用户的目标就是代理,用户并不知道后面提供服务的目标服务器
动静分离
静态资源直接映射本地文件(或者访问另一台静态资源的nginx),动态资源采用反向代理映射到相应的服务器上
1214755914400
/manager/
/manager/
6985788035
/content/
/content/
user root
http {
server {
listen 80;
server_name localhost;
location ^~ /content/ {
proxy_pass http://10.7.186.78:8082/;
}
location ^~ /manager/ {
proxy_pass http://10.7.186.79:8089/;
}
location ~ .\*\.(html|htm|gif|jpg|jpeg|bmp|png|ico|txt|js|css|mp3|mp4)$ {
root /root/static;
expires 30d;
}
}
}
22098001354455
/manager/
/manager/
379095477520
/content/
/content/
user root
http {
server {
listen 80;
server_name localhost;
Location ^~ /content/ {
proxy_pass http://10.7.186.78:8082/;
}
location ^~ /manager/ {
proxy_pass http://10.7.186.79:8089/;
}
location ~ .\*\.(html|htm|gif|jpg|jpeg|bmp|png|ico|txt|js|css|mp3|mp4)$ {
proxy_pass http://10.7.186.80/;
}
}
}
10.7.186.80配置user root
http {
server {
listen 80;
server_name localhost;
Location / {
root /root/static;
}
}
}
负载均衡(Load Balance)
物理架构
对192.168.23.144:80服务器(nginx)的同一url的请求,根据不同的策略,分发到192.168.23.144:8080或者192.168.23.144:8081服务器(tomcat)处理
代码修改
/nginx/src/main/java/com/qfedu/demo/springboot/nginx/MainController.java
发布应用
用8080端口发布应用
用8081发布应用,具体参照8080
将jar上传至linux
分别启动cmd命令行窗口连接linux服务器,以阻塞方式运行这两个程序
java -jar /root/nginxapp/nginx-8080-0.0.1-SNAPSHOT.jar
java -jar /root/nginxapp/nginx-8081-0.0.1-SNAPSHOT.jar
Nginx配置不同负载均衡策略
默认策略
配置:
http {
#配置负载均衡
upstream nginx_lb {
server localhost:8080;
server localhost:8081;
}
server {
location / {
proxy_pass http://nginx\_lb/;
}
location ~ .\*\.(html|js|css|png|jpeg|jpg|icon) {
root /root/hz1808/nginxappstatic;
index index.html;
}
}
}
测试:
现在访问如下url 30次:
http://192.168.23.144/lb
结果:
192.168.23.144:8080提供服务的次数:30 / 2
192.168.23.144:8081提供服务的次数:30 / 2
false
权重策略
在默认策略基础上配置红色部分即可:
http {
#配置负载均衡
upstream nginx_lb {
server localhost:8080 weight=10;
server localhost:8081 weight=5;
}
server {
location / {
proxy_pass http://nginx\_lb/;
}
location ~ .\*\.(html|js|css|png|jpeg|jpg|icon) {
root /root/hz1808/nginxappstatic;
index index.html;
}
}
}
false
测试:
现在访问如下url 30次:
http://192.168.23.144/lb
结果:
Tomcat1提供服务的次数:30 * 10 / (5 + 10) = 20
Tomcat2依次提供服务次数:30 * 5 / (5 + 10) = 10
iphash策略
在默认配置的基础上配置红色部分即可:
http {
#配置负载均衡
upstream nginx_lb {
ip_hash;
server localhost:8080;
server localhost:8081;
}
server {
location / {
proxy_pass http://nginx\_lb/;
}
location ~ .\*\.(html|js|css|png|jpeg|jpg|icon) {
root /root/hz1808/nginxappstatic;
index index.html;
}
}
}
false
测试:
现在访问如下url 30次:
http://192.168.23.144/lb
结果:
Tomcat1或者Tomcat2提供服务次数:30
高可用性(HA- high availablity)
保证提供的服务不间断
给大家的福利
零基础入门
对于从来没有接触过网络安全的同学,我们帮你准备了详细的学习成长路线图。可以说是最科学最系统的学习路线,大家跟着这个大的方向学习准没问题。
同时每个成长路线对应的板块都有配套的视频提供:
因篇幅有限,仅展示部分资料
网络安全面试题
绿盟护网行动
还有大家最喜欢的黑客技术
网络安全源码合集+工具包
所有资料共282G,朋友们如果有需要全套《网络安全入门+黑客进阶学习资源包》,可以扫描下方二维码领取(如遇扫码问题,可以在评论区留言领取哦)~
加入社区》https://bbs.csdn.net/forums/4304bb5a486d4c3ab8389e65ecb71ac0