java整体项⽬架构图,太完整了!
1、什么是Nginx,谈谈个⼈都理解,项⽬中是否⽤到,为什么要⽤,有什么优点?
Nginx ,是⼀个 Web 服务器和反向代理服务器⽤于 HTTP、HTTPS、SMTP、POP3 和 IMAP 协议。
主要功能如下:
1、正向、反向代理
2、负载均衡、分流
3、虚拟主机(绑定host)
优点:
跨平台、配置简单,⾮阻塞、⾼并发连接、内存消耗⼩、成本低廉。
2、正向代理和反向代理的区别是什么?
正向代理是⼀个位于客户端和原始服务器之间的服务器,为了从原始服务器取得内容,客户端向代理发送⼀个请求并指定原始服务器,然后代理向原始服务器转交请求并将获得的内容返回给客户端。代理服务器和客户端处于同⼀个局域⽹内。
⽐如说fanqiang。我知道我要访问⾕歌,于是我就告诉代理服务器让它帮我转发。
反向代理实际运⾏⽅式是代理服务器接受⽹络上的连接请求。它将请求转发给内部⽹络上的服务器,并将从服务器上得到的结果返回给⽹络上请求连接的客户端 。代理服务器和原始服务器处于同⼀个局域⽹内。
⽐如说我要访问taobao,对我来说不知道图⽚、json、css 是不是同⼀个服务器返回回来的,但是我不关⼼,是反向代理 处理的,我不知道原始服务器。
3、Nginx如何处理HTTP请求的?
它结合多进程机制(单线程)和异步⾮阻塞⽅式。
1、多进程机制(单线程)
服务器每当收到⼀个客户端时,就有 服务器主进程 ( master process )⽣成⼀个 ⼦进程( worker process )出来和客户端建⽴连接进⾏交互,直到连接断开,该⼦进程就结束了。
2、异步⾮阻塞机制
每个⼯作进程 使⽤ 异步⾮阻塞⽅式 ,可以处理 多个客户端请求 。运⽤了epoll模型,提供了⼀个队列,排队解决。
当某个 ⼯作进程 接收到客户端的请求以后,调⽤ IO 进⾏处理,如果不能⽴即得到结果,就去 处理其他请求 (即为 ⾮阻塞 );⽽ 客户端在此期间也 ⽆需等待响应 ,可以去处理其他事情(即为 异步 )。
当 IO 返回时,就会通知此 ⼯作进程 ;该进程得到通知,暂时 挂起 当前处理的事务去 响应客户端请求 。
4、Nginx的master和worker是如何⼯作的?
这跟Nginx的多进程、单线程有关。(⼀个进程只有⼀个主线程)。
为什么要⽤单线程?
采⽤单线程来异步⾮阻塞处理请求(管理员可以配置Nginx主进程的⼯作进程的数量),不会为每个请求分配cpu和内存资源,节省了⼤量资源,同时也减少了⼤量的CPU的上下⽂切换,所以才使得Nginx⽀持更⾼的并发。
简单过程:
主程序 Master process 启动后,通过⼀个 for 循环来 接收 和 处理外部信号 ;
主进程通过 fork() 函数产⽣ worker ⼦进程 ,每个⼦进程执⾏⼀个 for循环来实现Nginx服务器对事件的接收和处理 。
详细过程:
1、Nginx 在启动后,会有⼀个 master 进程和多个相互独⽴的 worker 进程。
2、master 接收来⾃外界的信号,先建⽴好需要 listen 的 socket(listenfd) 之后,然后再 fork 出多个 worker 进程,然后向各worker进程发送信号,每个进程都有可能来处理这个连接。
3、所有 worker 进程的 listenfd 会在新连接到来时变得可读 ,为保证只有⼀个进程处理该连接,所有 worker 进程在注册 listenfd 读事件前抢占 accept_mutex ,抢到互斥锁的那个进程注册 listenfd 读事件 ,在读事件⾥调⽤ accept 接受该连接。
4、当⼀个 worker 进程在 accept 这个连接之后,就开始读取请求、解析请求、处理请求,产⽣数据后,再返回给客户端 ,最后才断开连接。
5、Nginx 常⽤命令有哪些?
启动 nginx 。
停⽌ nginx -s stop 或 nginx -s quit 。
重启 nginx -s reload 或 service nginx reload 。
重载指定配置⽂件 .nginx -c /usr/local/nginx/f 。
查看 nginx 版本 nginx -v 。
6、nginx中500、502、503、504 有什么区别?
500:java学习资源
Internal Server Error 内部服务错误,⽐如脚本错误,编程语⾔语法错误。
502:
Bad Gateway错误,⽹关错误。⽐如服务器当前连接太多,响应太慢,页⾯素材太多、带宽慢。
503:
Service Temporarily Unavailable,服务不可⽤,web服务器不能处理HTTP请求,可能是临时超载或者是服务器进⾏停机维护。
504:
Gateway timeout ⽹关超时,程序执⾏时间过长导致响应超时,例如程序需要执⾏20秒,⽽nginx最⼤响应等待时间为10秒,这样就会出现超时。
学习分享,共勉
这⾥是⼩编拿到的学习资源,其中包括“中⾼级Java开发⾯试⾼频考点题笔记300道.pdf”和“Java核⼼知识体系笔记.pdf”⽂件分享,内容丰富,囊括了JVM、锁、并发、Java反射、Spring原理、微服务、Zookeeper、数据库、数据结构等⼤量知识点。同时还有Java进阶学习的知识笔记脑图(内含⼤量学习笔记)!
资料都是免费提供的,整理不易,有需要的朋友可以转发分享下,同时可以关注我,定期分享学习资源还会更新⼀些技术分享!
整理不易,有需要的朋友转发⽀持下,感谢感谢!
Java核⼼知识体系笔记.pdf
中⾼级Java开发⾯试⾼频考点题笔记300道.pdf
架构进阶⾯试专题及架构学习笔记脑图
Java架构进阶学习视频分享
脑图**
[外链图⽚转存中…(img-XRCOEtGi-1624778690084)] Java架构进阶学习视频分享
[外链图⽚转存中…(img-5AaXtowK-1624778690085)]

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。