参考:黑马程序员 b站
Nginx分布式框架核心功能:

  • 动静分离(静态资源部署)
  • 反向代理
  • 负载均衡

1. Nginx简介

1.1 背景介绍

Nginx (“engine x”) 一个具有高性能的【HTTP】和【反向代理】的【WEB服务器】,同时也是一个【POP3/SMTP/IMAP代理服务器】。C语言编写,开源。

1.1.1 WEB服务器

WEB服务器也叫网页服务器(Web Server),主要功能是为用户提供网上信息浏览服务。

1.1.2 HTTP

HTTP是超文本传输协议的缩写,是用于从WEB服务器传输超文本到本地浏览器的传输协议,也是互联网上应用最为广泛的一种网络协议。HTTP是一个客户端和服务器端请求和应答的标准,客户端是终端用户,服务端是网站,通过使用Web浏览器、网络爬虫或者其他工具,客户端发起一个到服务器上指定端口的HTTP请求。

1.1.3 POP3/SMTP/IMAP

POP3(Post Office Protocol 3)邮局协议的第三个版本,
SMTP(Simple Mail Transfer Protocol)简单邮件传输协议,
IMAP(Internet Mail Access Protocol)交互式邮件存取协议,
(Nginx可以作为电子邮件代理服务器)

1.1.4 反向代理

  • 正向代理:Proxy 服务的是客户端 (在客户端<浏览器>配置代理服务器,通过代理服务器进行互联网访问;例:浏览器(client) —> www.abc.com(代理) —> www.google.com(server)

image.png

  • 反向代理:Proxy 服务的是服务端;(服务端隐藏)

image.png

1.2.5 负载均衡

image.png

1.2.6 动静分离

为了加快网站的解析速度,可以把动态页面和静态页面由不同的服务器来解析,加快解析速 度。降低原来单个服务器的压力。
image.png

1.2 常用服务器对比

了解网站:Netcraft公司 ;已成为全球网站数量以及服务器市场份额情况的主要参考依据
http://nginx.org/ —> about (https://news.netcraft.com/archives/2021/05/31/may-2021-web-server-survey.html
image.png

1.2.1 IIS

全称(Internet Information Services)即互联网信息服务,是由微软公司提供的基于windows系统的互联网基本服务。windows作为服务器在稳定性与其他一些性能上都不如类UNIX操作系统,因此在需要高性能Web服务器的场合下,IIS可能就会被”冷落”.

1.2.2 Tomcat

Tomcat是一个运行Servlet和JSP的Web应用软件, Tomcat技术先进、 性能稳定而且开放源代码,因此深受ava爱好者的喜爱并得到了部分软件开发商的认可,成为目前比较流行的Web应用服务器。但是Tomcat天生是一个重量级的Web服务器,对静态文件和高并发的处理比较弱。

1.2.3 Apache

Apache的发展时期很长,Apache有很多优点,如稳定、开源、跨平台等。但是它出现的时间太久了,在它兴起的年代,互联网的产业规模远远不如今天,所以它被设计成一个重量级的、不支持高并发的Web服务器。在Apache服务器上,如果有数以万计的并发HTTP请求同时访问,就会导致服务器上消耗大量内存,操作系统内核对成百上千的Apache进程做进程间切换也会消耗大量的CUP资源,并导致HTTP请求的平均响应速度降低,这些都决定了Apache不可能成为高性能的Web服务器。这也促使了Lighttpd和Nginx的出现。

1.2.4 Lighttpd

Lighttpd是德国的一个开源的Web服务器软件,它和Nginx一样,都是轻量级、高性能的Web服务器,欧美的业界开发者比较钟爱Lighttpd,而国内的公司更多的青睐Nginx,同时网上Nginx的资源要更丰富些。

1.3 Nginx优点

1.3.1 速度更快,并发更高

单次请求或者高并发请求的环境下,Nginx都会比其他Web服务器响应的速度更快。一方面在正常情况下,单次请求会得到更快的响应,另一方面,在高峰期(如有数以万计的并发请求), Nginx比其他Web服务器更快的响应请求。Nginx之所以有这么高的并发处理能力和这么好的性能原因在于Nginx采用了多进程I/O多路复用(epoll)的底层实现。

1.3.2 配置简单,扩展性强

Nginx的设计极具扩展性,它本身就是由很多模块组成,这些模块的使用可以通过配置文件的配置来添加。这些模块有官方提供的也有第三方提供的模块,如果需要完全可以开发服务自己业务特性的定制模块。

1.3.3 高可靠性

Nginx采用的是多进程模式运行,其中有一个master主进程和N多个worker进程,worker进程的数量我们可以手动设置,每个worker进程之间都是相互独立提供服务,并且master主进程可以在某一个worker进程出错时,快速去’拉起’新的worker进程提供服务。

1.3.4 热部署

现在互联网项目都要求以724小时进行服务的提供,针对于这一要求,Nginx也提供 了热部署功能,即*可以在Nginx不停止的情况下,对Nginx进行文件升级、更新配置和更换日志文件等功能。

1.3.5 成本低,BSD许可证

BSD是一个开源的许可证,世界上的开源许可证有很多,现在比较流行的有六种分别是GPL、BSD、MIT、Moilla、 Apache、 LGPL。这六种的区别是什么,我们可以通过下面一张图来解释下(对于Nginx源码):
image.png
Nginx本身是开源的,我们不仅可以免费的将Nginx应用在商业领域,而且还可以在项目中直接修改Nginx的源码来定制自己的特殊要求。这些点也都是Nginx为什么能吸引无数开发者继续为Nginx来贡献自己的智慧和青春。OpenRestry [Nginx+Lua] Tengine[淘宝]

1.4 Nginx功能特性

Nginx提供的基本功能服务从大体上归纳为”基本HTTP服务”、”高级HTTP服务”和”邮件服务”等三大类。

1.4.1 基本HTTP服务

Nginx可以提供基本HTTP服务,可以作为HTTP代理服务器和反向代理服务器,支持通过缓存加速访问,可以完成简单的负载均衡和容错,支持包过滤功能,支持SSL等。

1.4.2 高级HTTP服务

●支持基于名字和IP的虚拟主机设置
●支持HTTP/1.0中的KEEP-Alive模式和管线(PipeLined)模型连接
●自定义访问日志格式、带缓存的日志写操作以及快速日志轮转。
●提供3xx~5xx错误代码重定向功能
●支持重写(Rewrite)模块扩展
●支持重新加载配置以及在线升级时无需中断正在处理的请求
●支持网络监控
●支持FLV和MP4流媒体传输

1.4.3 邮件服务

1.5 Nginx常用功能模块

(重点掌握)

  • 静态资源部署
  • Rewrite地址重写
    • 正则表达式
  • 反向代理
  • 负载均衡
    • 轮询、加权轮询、ip_hash、url_hash、fair
  • web缓存 (缓存:提高服务器访问速度)
  • 环境部署
    • 高可用的环境
  • 用户认证模块

1.6 Nginx的核心组成

  • Nginx 二进制可执行文件
  • nginx.conf 配置文件
  • error.log 错误的日志记录
  • access.log 访问日志记录

参考: 尚硅谷 b站

2. nginx 常用命令

先进入 /nginx/sbin 目录

  1. # 先进入 /nginx/sbin 目录
  2. # 1.查看版本号
  3. ./nginx -v
  4. # 2. 停止与启动
  5. # ps -ef | grep nginx 先查看nginx
  6. ./nginx -s stop # 停止
  7. ./nginx # 启动
  8. # 3. 检查配置文件合法性 (syntax is ok: 合法)
  9. ./nginx -t
  10. # 4. 重新加载配置文件(重启)
  11. ./nginx -s reload

3. nginx 配置文件

  1. # 目录 /nginx/cong/nginx.conf
  2. # 三部分
  3. # 第一部分:全局块
  4. 进程数 等..
  5. # 第二部分:events 块
  6. 连接数 等..
  7. # 第三部分:http 块 (关键..)
  8. 包括: http 全局块、
  9. server 块(n个) (每一个 server 块就相当于一个虚拟主机)
  10. (包括: 全局 server; location(n个) )
  11. user www www;
  12. worker_processes auto; # 工作进程数; 支持的并发处理量就越大
  13. error_log /www/wwwlogs/nginx_error.log crit;
  14. pid /www/server/nginx/logs/nginx.pid;
  15. worker_rlimit_nofile 51200;
  16. stream {
  17. log_format tcp_format '$time_local|$remote_addr|$protocol|$status|$bytes_sent|$bytes_received|$session_time|$upstream_addr|$upstream_bytes_sent|$upstream_bytes_received|$upstream_connect_time';
  18. access_log /www/wwwlogs/tcp-access.log tcp_format;
  19. error_log /www/wwwlogs/tcp-error.log;
  20. include /www/server/panel/vhost/nginx/tcp/*.conf;
  21. }
  22. events
  23. {
  24. use epoll;
  25. worker_connections 51200;
  26. multi_accept on;
  27. }
  28. http
  29. {
  30. include mime.types;
  31. #include luawaf.conf;
  32. include proxy.conf;
  33. default_type application/octet-stream;
  34. server_names_hash_bucket_size 512;
  35. client_header_buffer_size 32k;
  36. large_client_header_buffers 4 32k;
  37. client_max_body_size 50m;
  38. sendfile on;
  39. tcp_nopush on;
  40. keepalive_timeout 60;
  41. tcp_nodelay on;
  42. fastcgi_connect_timeout 300;
  43. fastcgi_send_timeout 300;
  44. fastcgi_read_timeout 300;
  45. fastcgi_buffer_size 64k;
  46. fastcgi_buffers 4 64k;
  47. fastcgi_busy_buffers_size 128k;
  48. fastcgi_temp_file_write_size 256k;
  49. fastcgi_intercept_errors on;
  50. gzip on;
  51. gzip_min_length 1k;
  52. gzip_buffers 4 16k;
  53. gzip_http_version 1.1;
  54. gzip_comp_level 2;
  55. gzip_types text/plain application/javascript application/x-javascript text/javascript text/css application/xml;
  56. gzip_vary on;
  57. gzip_proxied expired no-cache no-store private auth;
  58. gzip_disable "MSIE [1-6]\.";
  59. limit_conn_zone $binary_remote_addr zone=perip:10m;
  60. limit_conn_zone $server_name zone=perserver:10m;
  61. server_tokens off;
  62. access_log off;
  63. server
  64. {
  65. listen 888;
  66. server_name phpmyadmin;
  67. index index.html index.htm index.php;
  68. root /www/server/phpmyadmin;
  69. location ~ /tmp/ {
  70. return 403;
  71. }
  72. #error_page 404 /404.html;
  73. include enable-php.conf;
  74. location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)$
  75. {
  76. expires 30d;
  77. }
  78. location ~ .*\.(js|css)?$
  79. {
  80. expires 12h;
  81. }
  82. location ~ /\.
  83. {
  84. deny all;
  85. }
  86. access_log /www/wwwlogs/access.log;
  87. }
  88. # include /www/server/panel/vhost/nginx/*.conf;
  89. include /www/server/nginx/conf/gulimall/*.conf;
  90. }

4. nginx 配置实例-反向代理

5. nginx 配置实例-负载均衡

6. nginx 配置实例-动静分离