参考:黑马程序员 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))
- 反向代理:Proxy 服务的是服务端;(服务端隐藏)
1.2.5 负载均衡
1.2.6 动静分离
为了加快网站的解析速度,可以把动态页面和静态页面由不同的服务器来解析,加快解析速
度。降低原来单个服务器的压力。
1.2 常用服务器对比
了解网站:Netcraft公司 ;已成为全球网站数量以及服务器市场份额情况的主要参考依据
http://nginx.org/ —> about (https://news.netcraft.com/archives/2021/05/31/may-2021-web-server-survey.html)
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源码):
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 访问日志记录
2. nginx 常用命令
先进入 /nginx/sbin 目录
# 先进入 /nginx/sbin 目录
# 1.查看版本号
./nginx -v
# 2. 停止与启动
# ps -ef | grep nginx 先查看nginx
./nginx -s stop # 停止
./nginx # 启动
# 3. 检查配置文件合法性 (syntax is ok: 合法)
./nginx -t
# 4. 重新加载配置文件(重启)
./nginx -s reload
3. nginx 配置文件
# 目录 /nginx/cong/nginx.conf
# 三部分
# 第一部分:全局块
进程数 等..
# 第二部分:events 块
连接数 等..
# 第三部分:http 块 (关键..)
包括: http 全局块、
server 块(n个) (每一个 server 块就相当于一个虚拟主机)
(包括: 全局 server; location(n个) )
user www www;
worker_processes auto; # 工作进程数; 支持的并发处理量就越大
error_log /www/wwwlogs/nginx_error.log crit;
pid /www/server/nginx/logs/nginx.pid;
worker_rlimit_nofile 51200;
stream {
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';
access_log /www/wwwlogs/tcp-access.log tcp_format;
error_log /www/wwwlogs/tcp-error.log;
include /www/server/panel/vhost/nginx/tcp/*.conf;
}
events
{
use epoll;
worker_connections 51200;
multi_accept on;
}
http
{
include mime.types;
#include luawaf.conf;
include proxy.conf;
default_type application/octet-stream;
server_names_hash_bucket_size 512;
client_header_buffer_size 32k;
large_client_header_buffers 4 32k;
client_max_body_size 50m;
sendfile on;
tcp_nopush on;
keepalive_timeout 60;
tcp_nodelay on;
fastcgi_connect_timeout 300;
fastcgi_send_timeout 300;
fastcgi_read_timeout 300;
fastcgi_buffer_size 64k;
fastcgi_buffers 4 64k;
fastcgi_busy_buffers_size 128k;
fastcgi_temp_file_write_size 256k;
fastcgi_intercept_errors on;
gzip on;
gzip_min_length 1k;
gzip_buffers 4 16k;
gzip_http_version 1.1;
gzip_comp_level 2;
gzip_types text/plain application/javascript application/x-javascript text/javascript text/css application/xml;
gzip_vary on;
gzip_proxied expired no-cache no-store private auth;
gzip_disable "MSIE [1-6]\.";
limit_conn_zone $binary_remote_addr zone=perip:10m;
limit_conn_zone $server_name zone=perserver:10m;
server_tokens off;
access_log off;
server
{
listen 888;
server_name phpmyadmin;
index index.html index.htm index.php;
root /www/server/phpmyadmin;
location ~ /tmp/ {
return 403;
}
#error_page 404 /404.html;
include enable-php.conf;
location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)$
{
expires 30d;
}
location ~ .*\.(js|css)?$
{
expires 12h;
}
location ~ /\.
{
deny all;
}
access_log /www/wwwlogs/access.log;
}
# include /www/server/panel/vhost/nginx/*.conf;
include /www/server/nginx/conf/gulimall/*.conf;
}