一般的java项目后台都有什么技术,比如spring MVC,shiro还有什么技术?
Java web现在流行的技术是Spring boot ,spring cloud, redis,mq, mybatis,spring security等,一般前后端分离
JAVA nginx是J***a后台开发最常用最入门的技术吗?
作为一个BAT的j***a开发工程师,可以肯定的告诉你,是的。
接下来,我们来分析,为什么Nginx对J***a后台开发如此重要。
在引入Nginx之前,平台服务通常是单点,这样就有两个缺点:
1 如果节点宕机,整体服务就不可用,从而带来了服务稳定性的隐患。
2 如果节点的qps无法承担日渐增长的用户请求量,那么在服务改进之前,就有可能因为无法承担瞬时巨大的请求而宕机,从而导致服务不可用,具体例子可以参见最初的12306网站。
这两个缺点都可以通过引入Nginx来解决。
首先,布置两个相同功能的tomcat服务器,然后在Nginx的conf文件中配置,所有的请求都指向这两个Tomcat。在两个服务器都能正常运行的情况下,此时从用户侧感受到的qps将会乘以2,这样就解决了上面的缺点2。加入某一时间,一个服务器挂掉了,Nginx会立刻感知,然后将所有请求转发给另一台还活着的Tomcat,这样,从用户侧就感受不到服务的稳定性受到了影响,等我们重新启动了Tomcat后,Nginx会再将请求转发过去,即Nginx能自动感知指向的Tomcat的上线与下线,从而解决了上面的缺点1。
随着越来越多的产品开始选择分布式架构,一个完整的服务通常由多个负责不同功能的Tomcat构成,这样做的好处是功能解耦,降低了单个功能块出问题影响全局的可能性。举例,虽然都是从支付宝入口,就算有一天蚂蚁森林服务挂了,喂小鸡的模块也不会受到影响。极端情况,单个服务器挂掉,只意味着单个模块无法运作,但是还能保证其他模块正常运作。但是我们不能让用户为了不同的子功能去记录不同的域名,就好像支付宝不可能为了蚂蚁森林和喂小鸡单独写两个app出来一样,此时,Nginx的反向代理能力就大展身手了。我们可以为不同的url path配置指向不同的服务器地址,这样对外还是一个单独的host与ip,减轻了用户的使用负担,也隐藏了我们的后台服务。
算是吧,Nginx这门技术用的很广,几乎所有的j***a web项目上都用到啦,
首先它是一个轻量级的web服务器或者反向代理服务器,它有很多的优点,比如占的内存少,而且并发处理能力强,就连百度,京东,腾讯,淘宝都在用它,Nginx的模型***用的是master和worker模型,
这样的模型很多技术都在用,像大数据中火的hadoop strom hbase等都用这种模型。一般就是只有一个master和多个worker进程同时运行,不过一般都会将master配置成高可用的,为了防止它挂掉。而master进程主要功能就是管理work进程,像发发送信号,并监控它的运行状态,而worker进程主要处理网络事件,而且这么多个worker进程的关系是平等的,
它们之间相互竞争,而Nginx对于***是***用异步非阻塞的方式来实现的。而反向代理主要是实现负载均衡,从而降低每台服务器的负荷。
nginx并不是一门技术,而是高性能的反向代理服务器,但是nginx的配置确实是一门技术活!
nginx使用C语言进行开发,可以说跟J***A没半毛钱关系,也可用在PHP服务器开发,大数据等领域!
但是因为J***A在开发web服务器中占比十分之高,而高性能的后台服务却少不了nginx的参与,所以J***A程序员不得不学习nginx原理和使用!
先来看下什么是nginx?
nginx是一种轻量级,高性能,易配置,稳定度高的反向代理服务器,只需要简单的配置就可以得到一台具有负载均衡功能的稳定服务器!
nginx有什么用?
1,反向代理:nginx的反向代理模式,能让客户端感知不到真正的服务器的存在,所有的请求都全部落在nginx服务器上,由nginx基于一定的策略进行请求转发到不同的服务器上
2,负载均衡:所有落在nginx中的请求使用配置所得的负载均衡策略进行转发到不同服务器上,负载均衡方式有:轮询,权重,ip hash等方式供用户选择。负载均衡解决了单台[_a***_]存在的性能瓶颈!
3,支持高并发:诸如tomcat这样的应用服务器不能支持大量的连接,(貌似tomcat9改进了?)在高并发环境容易崩溃,而nginx是基于epoll模型的异步非阻塞服务器,只有当连接中有io***的时候,才会通知进程进行处理,既避免了频繁创建和销毁线程的开销,又没有维持多个长连接的内存开销,所以nginx能支持十万,百万级并发!
4,静态服务器,用的不多!
01 结论
先说结论,你要研究J***a的框架解决工作问题,我推荐你学习SpringBoot和Mybatis,比较简单易学;而且如果是一个并不太复杂的应用,这俩基本上也够用了(如果前后端不分离,这种情况下其实不需要Nginx也可以;模板引擎可以使用Thymeleaf,或者在有JSP的前提下使用JSP),服务器的话推荐最常使用的Tomcat;
当然,现在流行的还是微服务,不过开发起来稍微复杂些。微服务框架常见的有SpringCloud和Dubbo,推荐使用开发难度较小的Spring Cloud。Spring cloud也不是什么新的框架,它其实是一系列工具的***,基于的还是Spring Boot。
然后再说说我理解的Nginx,Nginx仅仅是一个反向代理服务器,跟J***a本身是没有关系的,但如果你们使用前后端分离进行开发,Nginx还是很有必要使用的。它的反向代理可以解决最头疼的跨域问题,还支持高并发和负载均衡。
但Nginx的高并发只是说它本身能同时将将很多前端的请求进行处理和转发到真正的服务器(以下简称服务器),网站的性能最终还是要服务器的性能来决定。如果有必要,我习惯于在项目中使用下图所示的架构:
这个架构的思想在于,由于业务数据的大小通常小于页面静态***(js、图片等),且NodeJS在处理静态***的服务能力要强于Tomcat很多,所以***用NodeJS来作静态***服务器,使用J***a来做业务处理服务器使,然后用Nginx将静态***的请求和业务数据请求分开转发,用以获得较大程度的性能提升。
以上就是我的回答,欢迎大家在评论区讨论使用Nginx时遇到的坑。