1、七层负载均衡:
根据url 调度不同的集群 url.yangdan.com
10.0.0.5
10.0.0.7 /pass
10.0.0.8 /user
[root@web01 conf.d]
server {
listen 80;
server_name url.yangdan.com;
root /code;
location / {
index index.html;
}
}
[root@lb01 conf.d]
upstream user {
server 172.16.1.8;
}
upstream pass {
server 172.16.1.7;
}
server {
listen 80;
server_name url.yangdan.com;
location / {
proxy_pass http://user;
include proxy_params;
}
location /user {
proxy_pass http://user;
include proxy_params;
}
location /pass {
proxy_pass http://pass;
include proxy_params;
}
}
[root@lb01 conf.d]
PS: 在使用proxy_pass反向代理时,最后结尾添加/和不添加/有什么区别?
1.不添加 /
用户如果请求: http://url.yangdan.com/user
会被代理至后端: http://url.yangdan.com/user
1.添加 /
用户如果请求: http://url.yangdan.com/user
会被代理至后端: http://url.yangdan.com/
根据设备调度不同的集群 ( 浏览器 ) ( 手机 )
10.0.0.5
10.0.0.7 pc
10.0.0.8 phone
[root@web01 conf.d]
server {
listen 80;
server_name agent.yangdan.com;
root /code;
location / {
index index.html;
}
}
2.代理的配置
[root@lb01 conf.d]
upstream pc {
server 172.16.1.7:80;
}
upstream phone {
server 172.16.1.8:80;
}
server {
listen 80;
server_name agent.yangdan.com;
location / {
proxy_pass http://pc;
include proxy_params;
default_type text/html;
charset utf-8;
if ( $http_user_agent ~* "android|iphone|iPad" ) {
proxy_pass http://phone;
}
if ( $http_user_agent ~* "MSIE" ) {
return 200 '<a href="http://download.xuliangwei.com/gitlab-ce-8.3.4-ce.0.el7.x86_64.rpm" target="_blank">点击下载正版浏览器google.exe</a>';
}
}
}
2、四层负载均衡
四层是基于转发方式:
登录 passport.jd.com
注册 reg.jd.com
商品详情 pro.jd.com
nginx 7层 web01 MySQL
nginx 4层 + web02 NFS
nginx 7层 web03 Redis
10.0.0.6
10.0.0.4
stream模块实现,但stream不能出现在http层
--with-stream
-with-stream_ssl_module
-with-stream_realip_module
stream {
upstream backend {
hash $remote_addr consistent;
server backend1.example.com:12345 weight=5;
server 127.0.0.1:12345 max_fails=3 fail_timeout=30s;
server unix:/tmp/backend3;
}
server {
listen 12345;
proxy_connect_timeout 1s;
proxy_timeout 3s;
proxy_pass backend;
}
}
[root@lb-4 nginx]
include /etc/nginx/conf.c/*.conf;
[root@lb-4 ~]
[root@lb-4 nginx]
[root@lb-4 ~]
stream {
upstream blog {
server 172.16.1.5:80;
server 172.16.1.6:80;
}
server {
listen 80;
proxy_pass blog;
proxy_timeout 3s;
proxy_connect_timeout 3s;
}
}
3、基于端口的转发:
需求: 用户连接10.0.0.4的6666端口,其实连接的是172.16.1.7的22/TCP端口
需求: 用户连接10.0.0.4的5555端口,其实连接的是172.16.1.51的3306/TCP端口
[root@lb-4 conf.c]# cat blog.yangdan.com.conf
stream {
upstream ssh {
server 172.16.1.7:22;
}
upstream mysql {
server 172.16.1.51:3306;
}
server {
listen 6666;
proxy_pass ssh;
}
server {
listen 5555;
proxy_pass mysql;
}
}
4、四层负载均衡怎么记录日志 必须在stream层,不能出现在http层?
log_format proxy '$remote_addr - [$time_local] $status $protocol'
' "$upstream_addr" "$upstream_bytes_sent" "$upstream_connect_time"' ;
access_log /var/log/nginx/tcp.log proxy;
#配置阿里云四层负载均衡 实现端口转发
公网666转到内网的22
公网80 转到内网的多台7层负载均衡的80 ?
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· .NET周刊【3月第1期 2025-03-02】
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器