有Tomcat,为什么还要Nginx?(有tomcat为什么还用nginx)
off999 2025-02-04 15:29 28 浏览 0 评论
只用Tomcat,不用Nginx搭建Web服务,行不行?我曾经提出的愚蠢问题,今天详细给自己解释下,为什么必须用Nginx!
不用Nginx,只用Tomcat的Http请求流程
浏览器处理一个Http请求时,会首先通过DNS服务器找到域名关联的IP地址,然后请求到对应的IP地址。以阿里云域名管理服务为例,一个域名可以最多绑定三个IP地址,这三个IP地址需要是公网IP地址,所以首先需要在三个公网Ip服务器上部署Tomcat实例。
此时我将面临的麻烦如下
- 由于DNS域名管理绑定的IP地址有限,最多三个,你如果想要扩容4台Tomcat,是不支持的。无法满足扩容的诉求
- 如果你有10个服务,对应10套Tomcat集群,就需要10 * 3台公网Ip服务器。成本还是蛮高的。
- 10个服务需要对应10个域名,分别映射到对应的Tomcat集群
- 10个域名我花不起这个钱啊!(其实可以用二级域名配置DNS映射)
- 公网服务器作为接入层需要有防火墙等安全管控措施,30台公网服务器,网络安全运维,我搞不定。
- 公网IP地址需要额外从移动联通运营商或云厂商购买,30个公网IP价格并不便宜。
- 前后端分离的情况,Tomcat无法作为静态文件服务器,只能用Nginx或Apache
以上几个问题属于成本、安全、服务扩容等方面。
如果Tomcat服务发布怎么办
Tomcat在服务发布期间是不可用的,在发布期间Http请求打到发布的服务器,就会失败。由于DNS 最多配置3台服务器,也就是发布期间是 1/3 的失败率。 我会被老板枪毙,用加特林
DNS不能自动摘掉故障的IP地址吗?
不能,DNS只是负责解析域名对应的IP地址,他并不知道对应的服务器状态,更不会知道服务器上Tomcat的状态如何。DNS只是解析IP,并没有转发Http请求,所以压根不知道哪台服务器故障率高。更无法自动摘掉IP地址。
我能手动下掉故障的IP地址吗?
这个我能,但是还是会有大量请求失败。以阿里云为例,配置域名映射时,我可以下掉对应的IP地址,但需要指定域名映射的缓存时间,默认10分钟。换句话说,就算你在上线前,摘掉了对应的IP,依然要等10分钟,所有的客户端才会拿到最新的DNS解析地址。
那么把TTL缓存时间改小,可以吗? 可以的,但是改小了,就意味更多的请求被迫从DNS服务器拿最新的映射,整体请求耗时增加,用户体验下降!被老板发现,会骂我。
节点突然挂掉怎么办?
虽然可以在DNS管理后台手动下掉IP地址,但是节点突然宕机、Tomcat Crash等因素导致的突然故障,我是来不及下掉对应IP地址的,我只能打电话告诉老板,“线上服务崩了,你等我10分钟改点东西”。
如果这时候有个软件能 对Tomcat集群健康检查和故障重试,那就太好了。
恰好,这是 Nginx 的长处!
Nginx可以健康检查和故障重试
而Tomcat没有。
例如有两台Tomcat节点,在Nginx配置故障重试策略
upstream test {
server 127.0.0.1:8001 fail_timeout=60s max_fails=2; # Server A
server 127.0.0.1:8002 fail_timeout=60s max_fails=2; # Server B
}当A节点出现 connect refused时(端口关闭或服务器挂了),说明服务不可用,可能是服务发布,也可能是服务器挂了。此时nginx会把失败的请求自动转发到B节点。 假设第二个请求 请求到A还是失败,正好累计2个失败了,那么Nginx会自动把A节点剔除存活列表 60 秒,然后继续把请求2 转发到B节点进行处理。60秒后,再次尝试转发请求到A节点…… 循环往复,直至A节点活过来……
而这一过程客户端是感知不到失败的。因为两次请求都二次转发到B节点成功处理了。客户端并不会感知到A节点的处理失败,这就是Nginx 反向代理的好处。即客户端不用直连服务端,加了个中间商,服务端的个别节点宕机或发布,对客户端都毫无影响。
而Tomcat只是Java Web容器,并不能做这些事情。
10个服务,10个Tomcat集群,就要10个域名,30个公网IP吗?
以阿里云为例,域名管理后台是可以配置二级域名映射,所以一个公网域名拆分为10个二级域名就可以了。
所以只用Tomcat,不用Nginx。需要1个公网域名,10个二级域名,30台服务器、30个公网IP。
当我和老板提出这些的时候,他跟我说:“你XX疯了,要不滚蛋、要不想想别的办法。老子没钱,你看我脑袋值几个钱,拿去换公网IP吧”。
DNS映射到Tomcat的IP地址,必须要公网,成本实在hold不住。心里苦啊,要是能有一个软件,能帮我把一个域名分别映射到30个内网IP就好了。
恰好 Nginx可以!
Nginx 虚拟主机和反向代理
例如把多个二级域名映射到不同的文件目录,例如
- bbs.abc.com,映射到 html/bbs
- blog.abc.com 映射到 html/blog
http {
include mime.types;
default_type application/octet-stream;
sendfile on;
keepalive_timeout 65;
server {
listen 80;
server_name www.abc.com;
location / {
root html/www;
index index.html index.htm;
}
}
server {
listen 80;
server_name bbs.abc.com;
location / {
root html/bbs;
index index.html index.htm;
}
}
server {
listen 80;
server_name blog.abc.com;
location / {
root html/blog;
index index.html index.htm;
}
}
}例如把不同的二级域名或者URL路径 映射到不同的 Tomcat集群
- 分别定义 serverGroup1、serverGroup2 两个Tomcat集群
- 分别把路径group1、group1 反向代理到serverGroup1、serverGroup2
upstream serverGroup1 { # 定义负载均衡设备的ip和状态
server 192.168.225.100:8080 ; # 默认权重值为一
server 192.168.225.101:8082 weight=2; # 值越高,负载的权重越高
server 192.168.225.102:8083 ;
server 192.168.225.103:8084 backup; # 当其他非backup状态的server 不能正常工作时,才请求该server,简称热备
}
upstream serverGroup2 { # 定义负载均衡设备的ip和状态
server 192.168.225.110:8080 ; # 默认权重值为一
server 192.168.225.111:8080 weight=2; # 值越高,负载的权重越高
server 192.168.225.112:8080 ;
server 192.168.225.113:8080 backup; # 当其他非backup状态的server 不能正常工作时,才请求该server,简称热备
}
server { # 设定虚拟主机配置
listen 80; # 监听的端口
server_name picture.itdragon.com; # 监听的地址,多个域名用空格隔开
location /group1 { # 默认请求 ,后面 "/group1" 表示开启反向代理,也可以是正则表达式
root html; # 监听地址的默认网站根目录位置
proxy_pass http://serverGroup1; # 代理转发
index index.html index.htm; # 欢迎页面
deny 127.0.0.1; # 拒绝的ip
allow 192.168.225.133; # 允许的ip
}
location /group2 { # 默认请求 ,后面 "/group2" 表示开启反向代理,也可以是正则表达式
root html; # 监听地址的默认网站根目录位置
proxy_pass http://serverGroup2; # 代理转发
index index.html index.htm; # 欢迎页面
deny 127.0.0.1; # 拒绝的ip
allow 192.168.225.133; # 允许的ip
}
error_page 500 502 503 504 /50x.html;# 定义错误提示页面
location = /50x.html { # 配置错误提示页面
root html;
}
}经过以上的教训,我再也不会犯这么愚蠢的错误了,我需要Tomcat,也需要Nginx。
当然如果钱足够多、资源无限丰富,公网IP、公网服务器、域名无限…… 服务发布,网站崩溃,无动于衷,可以不用Nginx。
相关推荐
- 查找iphone官网入口(查找iphone官网入口的详细指南)
-
查找我的苹果官网入口:http://www.apple.com.cn/并点击页面右上角的技术支持选项。2.选择您要查询的设备比如说您要查询iPhone的话就选择iPhone3.在iPhone的技术支持...
-
- nba比赛直播(nba比赛直播免费观看直播jrs)
-
NBA比赛直播可以在多个渠道观看,包括电视、网络直播和手机应用等。在电视方面,国内的CCTV-5和湖南卫视等频道都有播出NBA比赛的节目;在网络直播方面,腾讯体育、优酷体育、爱奇艺体育等平台都有提供NBA比赛的直播服务;在手机应用方面,NB...
-
2026-01-21 14:03 off999
- 电脑版ps免费安装包(电脑免费安装photoshop)
-
1.在搜索引擎中输入adobe并点击搜索。2.点击adobe官网。3.点击支持并点击下载与安装。4.点击开始免费试用并点击下载。5.打开文件夹并点击打开进行安装即可。6.根据以上步骤即可下载安装ps。...
- cad制图手机版免费(手机cad制图软件中文免费2020年)
-
手机上看CAD图纸的软件有很多,应用商店一搜一大堆,有几个我觉得不错的,CAD迷你看图最早之前用过,安装包小,确实迷你,看一般小的图纸还可以,大了就不太好用,经常会卡。CAD快速看图,软件就像名字一样...
- 七龙珠游戏格斗手机版(七龙珠游戏格斗手机版破解版)
-
龙珠的卡带对打游戏一共有3个;FC的一个:天下第一武道会GBA两个:对决,舞空斗剧补充;SFC游戏超武斗传.已经知道了.....游戏平台为PS2(虽然wii也有点可能...)....里面龙珠系列的游...
- ocr文字识别(ocr文字识别软件)
-
从广义上说,OCR文字识别也算是人工智能技术,随处可见的人脸识别、OCR识别、指纹识别和虹膜识别技术等人工智能,错落应用在各大领域之中,促进当代企业服务向智能化、自动化转型。云脉OCR开发者平台开放人...
- 手机微信网页版登录(微博官网网页版入口)
-
手机微信网页登陆的入口:1、电脑浏览器地址输入wx点qq点com,回车进入微信网页版登录页;2、手机打开登录自己微信,打开扫一扫功能,扫描网页版上的二维码;3、然后手机点击确定,即可成功登录微信网页版...
- qq影音播放器官方下载(qq影音播放器2018 免费版)
-
因为放到手机内存里面只是个压缩文件,所以本身的播放器是用不了的,只能qq音乐才可以用--,用视频下载软件来下载吧,视频下载软件可以直接下载到MP4格式的文件。qlv格式是没有转换器可以转换格式的。你...
- 一张照片生成3d模型软件(一张照片生成3d模型软件然后把它做出来)
-
DAZStudio是一款功能强大且非常专业的三维人物动画制作软件,通过该软件用户可以快速创建3D人物模型,可选用虚拟人物、动物、道具、环节等道具模型进行创作设计,该软件内置多种方法的三维模型编辑...
- cctv1电视直播(cctv1电视直播今天)
-
想要在手机上看央视CCTV-1的在线直播,你可以按照以下步骤进行:打开你手机上的浏览器。在浏览器中搜索“央视官网”。在搜索结果中找到并点击“央视官网”的链接。进入央视官网后,找到并点击“看直播”选项。...
- 一个人拿枪打丧尸单机2d(一个人拿枪打丧尸单机破解版大全)
-
僵尸之林,拇指玩gameloft下载器里有,可以联网,可以单机我力荐你死亡扳机1或2,虽然是单机,好玩NOVA3近地联盟先遣队、我的世界、AR机甲战士在背包里应该是有虚拟键盘的,打开后有两个开关,一个...
- 360抢票(360抢票王六代)
-
要使用360抢票王来抢票,您可以按照以下步骤操作:1.打开手机应用商店(如应用宝、appstore、360手机助手等),搜索并下载安装360抢票王应用。2.安装完成后,打开应用并进行登录或注册。...
- autocad2007入门教程(cad2007初级入门教程)
-
1、复制或剪切文字符号时,先将十字光标单击操作对象,待其变成虚线状态时,按快捷键ctrl+C或ctrl+X,然后按快捷键ctrl+V,即可实现复制或剪切。若要退出复制或剪切,按e...
- 360浏览器网页版入口网址(360浏览器网址大全)
-
360浏览器在线网页的入口是www.360.com右击“360浏览器”,然后选择“打开”。在“电脑端360浏览器”的页面右上角当中选择“打开菜单”。在随后出现的功能选项当中,选择“帮助”。然后我们就可...
- 青禾影视(青禾影视丝袜诱惑小说)
-
青禾影视传媒师资力量雄厚,信誉良好,是一家靠谱的传媒公司。杭州青禾影视传媒有限公司成立于2018年7月12号,是内地长三角省会城市,杭州多元化少儿艺术影视平台。青禾影视传媒集少儿综艺电视节目,真人秀节...
欢迎 你 发表评论:
- 一周热门
- 最近发表
- 标签列表
-
- python计时 (73)
- python安装路径 (56)
- python类型转换 (93)
- python进度条 (67)
- python吧 (67)
- python的for循环 (65)
- python格式化字符串 (61)
- python静态方法 (57)
- python列表切片 (59)
- python面向对象编程 (60)
- python 代码加密 (65)
- python串口编程 (77)
- python封装 (57)
- python写入txt (66)
- python读取文件夹下所有文件 (59)
- python操作mysql数据库 (66)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python多态 (60)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)
