1. 首页

Nginx 由浅入深,不能自拔

一、Nginx基础

  • Nginx 到底是什么?

    Nginx是⼀个⾼性能的HTTP和反向代理web服务器,核⼼特点是占有内存少,并发能⼒强

  • Nginx ⼜能做什么事情(应⽤场景)


- Http服务器(Web服务器)性能⾮常⾼,⾮常注重效率,能够经受⾼负载的考验。 复制代码

⽀持50000个并发连接数,不仅如此,CPU和内存的占⽤也⾮常的低,10000个没有活动的连接才占⽤2.5M的内存。


- 反向代理服务器 (浏览器发送请求到Nginx,由Nginx反向代理选择原始服务器得到结果,最终再返回给客户端浏览器 Nginx + Tomcat) - 正向代理 (国内访问 google) - 负载均衡服务器 (由Nginx反向代理多台Tomcat,这样⼀个寻找确定的过程就叫做负载均衡) - 动静分离(静态资源由Nginx 直接处理,动态Servlet 请求代理到Tomcat) 复制代码
  • Nginx 特点
    • 跨平台
    • 配置简单
    • 高并发,性能好,稳定,宕机率低
  • Nginx主要命令
    • (nginx 安装目录执行)./nginx
    • nginx -s stop
    • nginx -s reload (重新加载nginx.conf配置⽂件,Master 节点不重启)

二、Nginx 核心配置文件解读

Nginx 核心配置文件conf/nginx.conf包含三块内容:全局块、events块、http块。

Js中文网 – 前端进阶资源教程 www.javascriptC.com,typescript 中文文档
一个帮助开发者成长的社区,你想要的,在这里都能找到

  • 全局块

    从配置⽂件开始到events块之间的内容,此处的配置影响nginx服务器整体的运⾏,⽐如worker进程的数量、错误⽇志的位置等 Nginx 由浅入深,不能自拔

  • events块

    events块主要影响nginx服务器与⽤户的⽹络连接,⽐如worker_connections 1024,标识每个workderprocess⽀持的最⼤连接数为1024 Nginx 由浅入深,不能自拔

  • http块 http块是配置最频繁的部分,虚拟主机的配置,监听端⼝的配置,请求转发、反向代理、负载均衡等 ⚠️http下可配置多个server Nginx 由浅入深,不能自拔 Nginx 由浅入深,不能自拔

三、Nginx应⽤场景之反向代理

  • 部署tomcat 8080

  • 修改nginx配置 Nginx 由浅入深,不能自拔

  • nginx -s relod (重启,配置生效)

  • 注意 location 语法,nginx中server/location == tomcat中的Host/Context


location [=|~|~*|^~] /uri/ { … } 复制代码
在nginx配置⽂件中,location主要有这⼏种形式:

1.  精确匹配 location = /lagou { }

2.  匹配路径的前缀 location ^~ /lagou { }

3.  不区分⼤⼩写的正则匹配 location ~\* /lagou { }

4.  正则匹配 location ~ /lagou { }

5.  普通路径前缀匹配 location /lagou { }

    优先级 :asc

四、Nginx应⽤场景之负载均衡

Nginx 由浅入深,不能自拔

1. Nginx负载均衡策略

  • 轮询 (默认策略)

upstream lagouServer{ server 111.229.248.243:8080; server 111.229.248.243:8082; } location /abc { proxy_pass http://lagouServer/; } 复制代码
  • weight 权重

upstream lagouServer{ server 111.229.248.243:8080 weight=1; server 111.229.248.243:8082 weight=2; } 复制代码
  • ip_hash 按 ip 走,每一个客户端会打进同一个服务

upstream lagouServer{ ip_hash; server 111.229.248.243:8080; server 111.229.248.243:8082; } 复制代码

五、Nginx应⽤场景之动静分离

Nginx 由浅入深,不能自拔

Nginx 由浅入深,不能自拔

六、 Nginx底层进程机制剖析

1.Nginx 启动

以daemon多进程⽅式在后台运⾏,有⼀个Master进程和多个Worker进程

  • Master 进程
    • 接收外界信号像Worker 发送信号 如 nginx -s reload
    • 监控Worker,Worker异常退出,Master 自动重启新的Worker
  • Worker 进程
    • 处理网络请求,各Worker独立,一个请求只能在一个Worker。worker进程的个数是可以设置的,⼀般设置与机器cpu核数⼀致。

2. Nginx进程模型示意图

Nginx 由浅入深,不能自拔

  • 举例以 ./nginx -s reload 来说明nginx信号处理这部分
    1. Master 对配置文件进行语法检测
    2. 配置(⽐如修改了监听端⼝,那就尝试分配新的监听端⼝)
    3. 配置成功则使⽤新的配置,新建worker进程
    4. new worker success,old worker close
    5. old worker 会继续运行到请求没有为止才关闭
  • worker进程处理请求
    • 请求进来有多个Worker ,每个Worker都有可能处理请求
    • Master 启动好后,会建立socket链接,然后fork出多个Worker。所以,所有Worker进程的监听描述符listenfd在新连接到来时都变得可读
    • nginx 使用互斥锁保证只有一个Worker处理一个请求。拿到互斥锁的那个进程注册listenfd读事件,在读事件⾥调⽤accept接受该连接,然后解析、处理、返回客户端
  • nginx多进程模型好处
    • 每个worker进程都是独⽴的,不需要加锁,节省开销
    • 每个worker进程都是独⽴的,互不影响,⼀个异常结束,其他的照样能提供服务
    • 多进程模型为reload热部署机制提供了⽀撑

《lagouedu》nginx总结
作者:190coder
链接:https://juejin.im/post/6844904198480347149

看完两件小事

如果你觉得这篇文章对你挺有启发,我想请你帮我两个小忙:

  1. 关注我们的 GitHub 博客,让我们成为长期关系
  2. 把这篇文章分享给你的朋友 / 交流群,让更多的人看到,一起进步,一起成长!
  3. 关注公众号 「画漫画的程序员」,公众号后台回复「资源」 免费领取我精心整理的前端进阶资源教程

JS中文网是中国领先的新一代开发者社区和专业的技术媒体,一个帮助开发者成长的社区,目前已经覆盖和服务了超过 300 万开发者,你每天都可以在这里找到技术世界的头条内容。欢迎热爱技术的你一起加入交流与学习,JS中文网的使命是帮助开发者用代码改变世界

本文著作权归作者所有,如若转载,请注明出处

转载请注明:文章转载自「 Js中文网 · 前端进阶资源教程 」https://www.javascriptc.com

标题:Nginx 由浅入深,不能自拔

链接:https://www.javascriptc.com/4173.html

« LeetCode 027. 移除元素
大佬教你VS Code Disco»
Flutter 中文教程资源

相关推荐

QR code