其实现在估计很少人会用80端口部署服务了,起码都是443端HTTPS服务了,因为HTTPS相对更安全。
但是这不影响这个问题的解答,下面我以个人的一些看法说明下。
我们都知道你只买了一台公网服务器,默认80端口是HTTP服务,443端口是HTTPS服务。
而现在很多时候,微信、网站搜索引擎,默认都是用这些端口进行正常处理,当你有多个服务要对外开放,你如果A服务已经占用了80端口,那么B服务就不可以再占用80端口。
而你采用Nginx服务直接占用80或者443端口,那么我们根据Nginx的规则配置,就可以设置如下规则:
访问url路径/api 走A服务,访问url路径/admin 走B服务。
熟悉Nginx性能的程序员,都知道Nginx的性能之高,这里就不展开说。
因为有些编程语言框架,比如Flask,本身处理web请求就性能不高,通过Nginx可以提前处理web请求,而Flask就可以更多关注业务本身的逻辑。
当你的web服务后台可以多实例部署,这时候你说的web服务直接运行80端口,那就不能支持多台实例。
而通过nginx,就可以指向两台甚至多台实例的后端服务,而且可以设置策略进行负载请求。
比如负载后端两个web服务,A机器性能配置强,那么我们就可以分配更多的请求到A机器。
B机器性能一般,那么我们就可以减少请求到这台机器。
因为有了Nginx服务器在前面进行处理请求,用户根本不知道后端是用什么语言进行处理,减少后端暴露的几率。
不过由于使用Nginx的人很多,Nginx的漏洞也是备受关注,所以要及时关注Nginx的漏洞和最新稳定版本升级。
这里提供一个检测Nginx稳定版本的视频解说:https://www.ixigua.com/6832886164081345038/ ,有兴趣的可以看看。
使用Nginx服务可以占用低的内存消耗,同时能支持高并发连接,何乐而不为。
如果觉得回答能解决到一些问题,可以关注@testerzhang,我会不定期发布一些相关技术文章和视频。
当然是可以的,但是反向代理可以带来许多优点:
1)解耦:一个复杂的应用通常由许多不同的模块和不同的切面构成,比如安全切面,包括认证和加密,通常被不同的模块共享。
2)负载:由解耦带来的好处还可以体现在实现应用内负载均衡。反向代理不仅仅可以实现整体负载均衡,还可以实现模块甚至API级的负载均衡,并进一步实现分布式部署。
3)高可用:由负载均衡和分布式部署还可以为应用进一步带来热备、轮询、自动scale up/down,热部署……等等高可用特性。
4)安全:安全的另一个话题是防入侵,反向代理可以为抵御DDOS等攻击提供单一的配置策略。同时反向代理还可以有效防御来自内部的漏洞,应用服务器通常难以避免bug,当漏洞被利用入侵后,黑客通常会开启后门,但是后门协议通常无法被反向代理。
总之方向代理为应用架构设计、开发、部署、安全等多方面带来好处。