Nginx 由浅入深
2020-07-14 06:01
288 查看
一、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 -s start
二、Nginx 核心配置文件解读
Nginx 核心配置文件conf/nginx.conf包含三块内容:全局块、events块、http块。
-
全局块
从配置⽂件开始到events块之间的内容,此处的配置影响nginx服务器整体的运⾏,⽐如worker进程的数量、错误⽇志的位置等
-
events块
events块主要影响nginx服务器与⽤户的⽹络连接,⽐如worker_connections 1024,标识每个workderprocess⽀持的最⼤连接数为1024
-
http块
http块是配置最频繁的部分,虚拟主机的配置,监听端⼝的配置,请求转发、反向代理、负载均衡等 ⚠️http下可配置多个server
三、Nginx应⽤场景之反向代理
-
部署tomcat 8080
-
修改nginx配置
-
nginx -s relod (重启,配置生效)
-
注意 location 语法,nginx中server/location == tomcat中的Host/Context
location [=|~|~*|^~] /uri/ { … }
在nginx配置⽂件中,location主要有这⼏种形式:
-
精确匹配 location = /lagou { }
- 匹配路径的前缀 location ^~ /lagou { }
- 不区分⼤⼩写的正则匹配 location ~* /lagou { }
- 正则匹配 location ~ /lagou { }
- 普通路径前缀匹配 location /lagou { }
优先级 :asc
四、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底层进程机制剖析
1.Nginx 启动
以daemon多进程⽅式在后台运⾏,有⼀个Master进程和多个Worker进程
- Master 进程 接收外界信号像Worker 发送信号 如 nginx -s reload
- 监控Worker,Worker异常退出,Master 自动重启新的Worker
-
处理网络请求,各Worker独立,一个请求只能在一个Worker。worker进程的个数是可以设置的,⼀般设置与机器cpu核数⼀致。
2. Nginx进程模型示意图
-
举例以 ./nginx -s reload 来说明nginx信号处理这部分
-
Master 对配置文件进行语法检测
- 配置(⽐如修改了监听端⼝,那就尝试分配新的监听端⼝)
- 配置成功则使⽤新的配置,新建worker进程
- new worker success,old worker close
- old worker 会继续运行到请求没有为止才关闭
-
worker进程处理请求
请求进来有多个Worker ,每个Worker都有可能处理请求 - Master 启动好后,会建立socket链接,然后fork出多个Worker。所以,所有Worker进程的监听描述符listenfd在新连接到来时都变得可读
- nginx 使用互斥锁保证只有一个Worker处理一个请求。拿到互斥锁的那个进程注册listenfd读事件,在读事件⾥调⽤accept接受该连接,然后解析、处理、返回客户端
nginx多进程模型好处
-
每个worker进程都是独⽴的,不需要加锁,节省开销
《lagouedu》nginx总结
相关文章推荐
- 使用linux自带的logrotate对nginx日志进行分割
- nginx初级安装配置
- 【Nginx】Http负载均衡与反向代理
- Nginx、LVS及HAProxy负载均衡软件的优缺点详解
- nginx-301重定向开始
- Nginx1.8运行Laravel5的配置
- Nginx IP访问控制,只允许指定的IP地址访问
- 【记录】Nginx添加stub_status后,启动报错
- nginx 站点80跳443配置
- CentOS6.5安装nginx及负载均衡配置
- mysql+nginx+php+memcache
- 执行nginx -s reload报错
- apache和nginx下禁止指定目录运行php
- SSL/TLS深度解析--在Nginx上配置证书链及多域名证书
- Linux 使用pid文件结束nginx
- nginx事件模型小结
- Nginx 支持 CI 框架的配置并禁止使用 ip 访问
- 启用Nginx状态监控
- nginx启动/重启/停止脚本
- CenOS Linux安装nginx