网站首页 > 技术教程 正文
Nginx是非常重要的负载均衡中间件,被广泛应用于大型网站架构,下面我就全面来详解Nginx@mikechen
本篇已收于mikechen原创超30万字《阿里架构师进阶专题合集》里面。
Nginx
Nginx是一款高性能的HTTP/和反向代理服务器,由“Igor Sysoev”开发,广泛应用于现代Web服务架构中。
Nginx以其高并发连接处理能力,和低资源消耗而闻名,有报告表明能支持高达" 50,000" 个并发连接数。
Nginx特点
nginx具有如下,几大特点:
- 高并发处理能力:采用异步、事件驱动架构,能够高效处理大量并发连接;
- 低内存消耗:与其他Web服务器相比,Nginx的内存消耗非常低,适合高流量网站。
- 高可靠性和稳定性:即使在高负载情况下,Nginx也能保持稳定运行;
- 跨平台:支持多种操作系统,包括:Linux、Windows、macOS......等OS上。
Nginx功能应用
1.反向代理
Nginx反向代理:是一种部署在客户端、与后端服务器之间的服务器。
Nginx反向代理,接收客户端请求,然后将这些请求转发给后端服务器处理,并将后端服务器的响应返回给客户端。
来看个示意图:
反向代理,不仅可以将客户端的请求分配给“多台后端服务器”,从而均衡负载,提升整体系统的处理能力、和可靠性。
而且,反向代理还隐藏后端服务器的IP地址,减少其暴露在互联网上的风险。
以及,还可以配置访问控制、和防火墙规则,过滤不良请求、和防止DDoS攻击...等安全问题。
2.负载均衡
Nginx负载均衡功能强大,可以通过“多种策略”,将客户端请求分发到多个后端服务器,从而提高应用的可用性、和响应速度。
客户端的请求,均匀地分配到多台后端服务器(应用服务器1、应用服务器2、应用服务器3...等等),可以很容易横向扩展,从而极大的提升性能。
如下图所示:
这里的分配策略,包含:
1. 轮询
轮询是默认的负载均衡策略,NGINX按顺序将请求依次分配给每个后端服务器。
upstream backend {
server backend1.example.com;
server backend2.example.com;
server backend3.example.com;
}
2.权重
通过指定每个服务器的权重,可以控制请求的分配比例,权重越高的服务器分配到的请求越多。
upstream backend {
server backend1.example.com weight=3;
server backend2.example.com weight=2;
server backend3.example.com weight=1;
}
3.最少连接
将请求分配给当前活动连接数最少的服务器,适用于请求处理时间长且差异大的场景。
upstream backend {
least_conn;
server backend1.example.com;
server backend2.example.com;
}
通过以上的“分配策略”,可以极大的扩展服务器,提升性能。
除此之外,还可以避免单台服务器过载,提升系统的处理能力、和可靠性...等问题。
3.动静分离
通过Nginx实现动静分离,可以显著提升网站的响应速度、和服务器的处理能力。
动静分离,它的主要目标是将动态内容(如Java、PHP、Python...等生成的页面),和静态内容(如HTML、CSS、JavaScript、图片等)分开处理,以提高网站的性能和可维护性。
来个示意图:
根据请求的URL路径、文件类型...等,将请求分为静态请求、和动态请求。
/var/www/
├── static/ # 静态文件目录
│ ├── css/
│ ├── js/
│ └── images/
└── dynamic/ # 动态文件目录
└── index.php
对于静态资源请求(如HTML、CSS、JavaScript、图片....等),直接由NGINX处理并返回响应。
对于动态请求,NGINX会将请求转发给后端应用服务器(如:Apache、Tomcat...),由后端处理动态内容并生成响应。
4.静态文件服务
NGINX以其优异的性能和高并发处理能力而闻名,特别适合用作静态文件的快速传输。
它能够有效地处理大量的并发连接和高流量请求,是处理静态内容很好的选择。
Nginx配置
Nginx的配置文件:通常位于“ /etc/nginx/nginx.conf”,主要分为全局块、events块、和http块三个部分。
如下图所示:
1.全局块
全局块包含:全局指令,对整个NGINX服务器的行为进行全局设置,它通常位于配置文件的开头。
user nginx;
worker_processes auto;
error_log /var/log/nginx/error.log;
- worker_processes: 指定NGINX worker进程的数量,通常使用 auto 自动设置。
- error_log: 指定NGINX的错误日志路径。
2.events块
Events 块用于配置与NGINX工作进程相关的参数,主要控制NGINX如何处理连接。
events {
worker_connections 1024;
multi_accept on;
}
- worker_connections: 每个worker进程能够同时处理的最大连接数;
- multi_accept: 是否开启多个accept_mutex互斥锁;
- use: 指定使用的事件驱动模块,如 epoll, kqueue, eventport... 等。
3.HTTP 块
HTTP 块是NGINX配置文件的核心部分,用于配置HTTP服务和相关的HTTP请求处理。
http {
include /etc/nginx/mime.types;
default_type application/octet-stream;
log_format main '$remote_addr - $remote_user [$time_local] "$request" '
'$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" "$http_x_forwarded_for"';
access_log /var/log/nginx/access.log main;
sendfile on;
tcp_nopush on;
tcp_nodelay on;
keepalive_timeout 65;
types_hash_max_size 2048;
include /etc/nginx/conf.d/*.conf;
include /etc/nginx/sites-enabled/*;
}
- include: 引入其他配置文件或配置片段;
- log_format: 定义日志格式;
- access_log: 配置访问日志的路径、和格式;
- types: 定义MIME类型,及其映射关系;
- default_type: 设置默认的MIME类型;
- gzip: 启用或配置Gzip压缩;
- server: 配置虚拟主机、或服务;
- location: 配置请求的处理规则。
Nginx配置实例
1.负载均衡
这个配置用于配置NGINX实现负载均衡,将请求分发给多个后端服务器。
如下所示:
upstream backend {
server backend1.example.com;
server backend2.example.com;
server backend3.example.com;
}
server {
listen 80;
server_name example.com;
location / {
proxy_pass http://backend;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
}
}
2.静态文件
用于提供静态文件服务,将所有请求都映射到一个指定的目录。
如下所示:
server {
listen 80;
server_name example.com;
root /var/www/html;
index index.html index.htm;
location / {
try_files $uri $uri/ =404;
}
}
3.反向代理
将所有请求代理到后端服务器,实现反向代理功能。
server {
listen 80;
server_name api.example.com;
location / {
proxy_pass http://localhost:3000;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
}
}
将所有请求通过 proxy_pass 指令代理到 http://localhost:3000,即本地运行的后端服务器。
本篇已收于mikechen原创超30万字《阿里架构师进阶专题合集》里面。
猜你喜欢
- 2024-09-10 如何配置Nginx,随系统开机启动?(nginx 自启动 windows)
- 2024-09-10 全面了解 Nginx 主要应用场景(nginx常见使用场景)
- 2024-09-10 在Windows平台上安装Nginx并设置开机自动启动服务
- 2024-09-10 vue项目部署到阿里云服务器(windows),Nginx代理
- 2024-09-10 网页服务-Nginx - 基本安装部署(nginxweb)
- 2024-09-10 5分钟入门Nginx(nginx入门到实践)
- 2024-09-10 php手把手教你做网站(二十二)windows下nginx 配置支持php
- 2024-09-10 三年前端还不会配置Nginx?刷完这篇就够了
- 2024-09-10 Nginx Linux和Windows安装教程(nginx windows和linux版本区别)
- 2024-09-10 英文nginx是什么意思(nginx是什么语言)
你 发表评论:
欢迎- 最近发表
-
- linux日志文件的管理、备份及日志服务器的搭建
- Linux下挂载windows的共享目录操作方法
- Linux系统中的备份文件命令(linux系统中的备份文件命令有哪些)
- 麒麟KYLINOS|通过不同方法设置用户访问文件及目录权限
- 「Linux笔记」系统目录结构(linux目录的结构及含义)
- linux中修改归属权chown命令和chgrp命令
- 工作日报 2021.10.27 Android-SEAndroid权限问题指南
- Windows和Linux环境下,修改Ollama的模型默认保存路径
- 如何强制用户在 Linux 上下次登录时更改密码?
- 如何删除Linux文件夹中除某些扩展名之外的所有文件?
- 标签列表
-
- 下划线是什么 (87)
- 精美网站 (58)
- qq登录界面 (90)
- nginx 命令 (82)
- nginx .http (73)
- nginx lua (70)
- nginx 重定向 (68)
- Nginx超时 (65)
- nginx 监控 (57)
- odbc (59)
- rar密码破解工具 (62)
- annotation (71)
- 红黑树 (57)
- 智力题 (62)
- php空间申请 (61)
- 按键精灵 注册码 (69)
- 软件测试报告 (59)
- ntcreatefile (64)
- 闪动文字 (56)
- guid (66)
- abap (63)
- mpeg 2 (65)
- column (63)
- dreamweaver教程 (57)
- excel行列转换 (56)
本文暂时没有评论,来添加一个吧(●'◡'●)