02、Nginx 实战:Nginx基础介绍

第一章 Nginx基础介绍

一、Nginx概述

Nginx是一个开源且高性能、可靠的Http Web服务、代理服务。它具有有很多非常优越的特性: 单机环境下参考服务器配置。 并发连接数在7000+ -8000左右。 集群模式20000+。

作为 Web 服务器:相比 Apache,Nginx 使用更少的资源,支持更多的并发连接,体现更高的效率,这点使 Nginx 尤其受到虚拟主机提供商的欢迎。能够支持高达 50,000 个并发连接数的响应。

作为负载均衡服务器:Nginx 既可以在内部直接支持 Rails 和 PHP,也可以支持作为 HTTP代理服务器 对外进行服 务。Nginx 用 C 编写, 不论是系统资源开销还是 CPU 使用效率都比 Perlbal 要好的多。

作为邮件代理服务器: Nginx 同时也是一个非常优秀的邮件代理服务器(早开发这个产品的目的之一也是作为邮件 代理服务器),Last.fm 描述了成功并且美妙的使用经验。 Nginx 安装非常的简单,配置文件 非常简洁(还能够支持perl语法),Bugs非常少的服务器: Nginx 启动特别容 易,并且几乎可以做到7*24不间断运行,即使运行数个月也不需要重新启动。你还能够在不间断服务的情况下进行 软件版本的升级。

二、Nginx发展背景

NetCraft在2018年发布的web服务器调查报告中,排名前三的依然是Microsfot、Apache和Nginx。其中Nginx每年都在不断递增。

该软件由俄罗斯人Igor Sysoev于2004年首次公开发布。

Nginx凭借其稳定性、低资源消耗、简单配置和丰富的功能,从十多年前名不见经传的Web服务器软件,发展到如今能够跟Apache匹敌的地位。

三、Nginx特点

1、高性能高并发

性能高,支持海量并发,当并发特别高的时候,nginx比其他的web服务响应速度快

2、轻量且高扩展性

功能模块多,但仅需要保留必要的模块

需要哪个模块添加哪个模块,可以兼容第三方模块

3、高可靠性

很多web服务跑一段时间后需要重启,nginx不需要

nginx支持宕机时间级别为 9999、99999

4、支持热部署

nginx可以在开机情况下进行升级和重启

5、互联网公司使用nginx

nginx技术成熟,可以做负载,安全,web,缓存

6、nginx支持epool网络模型

1)epool:当用户发起请求,直接对请求的内容进行处理

当用户发起请求,epool模型会直接进行处理,效率高效,并无连接限制。

2)select:当用户发起请求,先遍历扫描数据,然后对请求的内容进行处理

当用户发起一次请求,select模型就会进行一次遍历扫描,从而导致性能低下。

总结:

1、开源: 直接获取源代码

2、高性能: 支持海量并发

3、可靠: 服务稳定

四、其他Web服务

 #1.apache
Apache是一款非常有名的应用软件。它是世界上使用最广泛的Web服务器应用程序,在商业Web服务器市场中占有超过50%的份额。 Apache是类Unix操作系统中使用最广泛的Web服务器应用程序,但几乎可用于所有平台,如Windows,OS X,OS / 2等.Aracle这个词取自Native的名称 美国部落’阿帕奇’,以其在战争和战略制定方面的技能而闻名。
它是一个基于流程的模块化Web服务器应用程序,它通过每个同时连接创建一个新线程。 它支持许多功能; 其中许多都被编译为单独的模块并扩展其核心功能,并且可以提供从服务器端编程语言支持到身份验证机制的所有功能。 虚拟主机就是这样一种功能,它允许单个Apache Web服务器为许多不同的网站提供服务。

最早使用的web服务,难以掌握,性能不高

#2.nginx
1)Tengine:Tengine是由淘宝网发起的Web服务器项目。它在Nginx的基础上,针对大访问量网站的需求,添加了很多高级功能和特性。Tengine的性能和稳定性已经在大型的网站如淘宝网,天猫商城等得到了很好的检验。它的最终目标是打造一个高效、稳定、安全、易用的Web平台。
其详细的特性可以访问官网:https://tengine.taobao.org/

2)OpenResty:OpenResty 是一个基于 Nginx 与 Lua 的高性能 Web 平台,其内部集成了大量精良的 Lua 库、第三方模块以及大多数的依赖项。用于方便地搭建能够处理超高并发、扩展性极高的动态 Web 应用、Web 服务和动态网关。

OpenResty 通过汇聚各种设计精良的 Nginx 模块(主要由 OpenResty 团队自主开发),从而将 Nginx 有效地变成一个强大的通用 Web 应用平台。这样,Web 开发人员和系统工程师可以使用 Lua 脚本语言调动 Nginx 支持的各种 C 以及 Lua 模块,快速构造出足以胜任 10K 乃至 1000K 以上单机并发连接的高性能 Web 应用系统。

OpenResty 的目标是让你的Web服务直接跑在 Nginx 服务内部,充分利用 Nginx 的非阻塞 I/O 模型,不仅仅对 HTTP 客户端请求,甚至于对远程后端诸如 MySQL、PostgreSQL、Memcached 以及 Redis 等都进行一致的高性能响应。

#3.lighttpd
消耗的内存和cpu较低

#4.IIS
windows的web服务

#5.GWS
Google web server

#6.BWS
baidu web server

五、Nginx应用场景

 Nginx是一个异步框架的Web服务器,可以用作反向代理服务、负载均衡、API服务、静态资源服务和HTTP缓存服务。

六、Nginx的版本介绍

 Nginx目前分为开源版本和商业版本(Nginx Plus)

#1.开源版:nginx.org
#2.商业版:nginx.com

官方文档:https://www.nginx.com/products/nginx/#compare-versions

两个版本区别还是很大的,具体如下:
Feature OSS Nginx Plus
Load balancer - -
HTTP/TCP/UDP support Y Y
Layer 7 request routing Y Y
Active health checks N Y
Session persistence N Y
DNS service‑discovery integration N Y
Content cache - -
Static/Dynamic content caching Y Y
Cache‑purging API N Y
Web server/Reverse proxy - -
Origin server for static content Y Y
Reverse proxy: HTTP, FastCGI, memcached, SCGI, uwsgi Y Y
HTTP/2 gateway Y Y
gRPC proxy Y Y
HTTP/2 server push Y Y
Security controls - -
HTTP Basic Authentication Y Y
HTTP authentication subrequests Y Y
IP address‑based access control lists Y Y
Rate limiting Y Y
Dual‑stack RSA/ECC SSL/TLS offload Y Y
TLS 1.3 support Y Y
JWT authentication N Y
OpenID Connect SSO N Y
NGINX Web Application Firewall (additional cost) N Y
Monitoring - -
AppDynamics, Datadog, Dynatrace plug‑ins Y Y
Extended status with 90 additional metrics N Y
High availability (HA) - -
Active‑active and active‑passive modes N Y
Configuration synchronization N Y
State sharing: Sticky‑Learn session persistence, rate limiting, key‑value stores N Y
Programmability - -
NGINX JavaScript module Y Y
NGINX Plus API for dynamic reconfiguration N Y
Key‑value store N Y
Dynamic reconfiguration without process reloads N Y
Streaming media - -
Live streaming: RTMP, HLS, DASH Y Y
VOD: Flash (flv), MP4 Y Y
Adaptive bitrate VOD: HLS, HDS N Y
MP4 bandwidth controls N Y
Third party ecosystem - -
Kubernetes Ingress controller Y Y
OpenShift Router Y Y
Dynamic modules repository N Y

七、Nginx的版本策略

 在Nginx中,有两个分支,分别为mainline和stable:

Mainline相当于开发分支,更新比较频繁,包含一些新功能或者bug修复,版本号的第二个数字如果是奇数,则是Mainline版本,如1.17.1
Stable分支是稳定版本,除非有重大的bug,否则在它生命周期内不会更新,版本号的第二个数字如果是偶数,就是Stable版本,如:1.16.0

最新版本可访问nginx官网地址:http://nginx.org/en/download.html

 Nginx官网提供的一幅图来说明版本之间的关系: