你信不信,五分钟快速学习Nginx

news2024/11/26 18:41:24

Nginx是什么?

Nginx 是一个高性能的HTTP和反向代理服务器。它是由俄罗斯程序员Igor Sysoev开发的,最初是为了解决俄罗斯大型的门户网站的高流量问题。

说到反向代理,那么有没有正向代理呢?
  • 正向代理:客户端非常明确要访问的服务器地址;服务器只知道请求来自哪个服务器(不知道哪个客户端);正向代理屏蔽或者隐藏了真实客户端。例如:当我们无法直接访问国外网站时,我们需要通过代理服务器(FQ)来访问,通过代理服务器去访问我们指定的网址。

  • 反向代理:多个客户端向反向代理服务器发送请求,Nginx 根据一定的规则将请求分发到不同的服务器;客户端不清楚请求将被分发到哪台服务器,反向代理隐藏了服务器的信息。

正向代理代理客户端的请求去访问目标服务器,目标服务器可能是一个反向服务器,反向代理了多台真实的服务器。

在这里插入图片描述
说到反向代理,不得不说下负载均衡,毕竟利用好反向代理,可以完美解决流量高并发的问题!

负载均衡

总说负载均衡,负载均衡是做什么用的?什么场景使用?

负载均衡是用来分配客户端请求到多个服务器的机制,常用于解决高负载和提高系统可用性的问题。

  • 负载量:客户端发送的请求数量,也是负载量。
  • 均衡规则:反向代理服务器根据一定的规则将请求分发到不同的服务器上处理。
  • 负载均衡可分为硬件负载均衡(成本较高)和软件负载均衡(成本较低)。
  • 软件负载均衡是利用现有的技术结合主机硬件实现的一种消息队列分发机制。

在这里插入图片描述

Nginx的核心要点

1、事件驱动

Nginx使用了一个高效的异步事件模型,基于I/O多路复用,特别是epoll(在Linux上)和kqueue(在BSD系统上)。这种模型允许Nginx同时处理大量的并发连接,而不会因为每个连接占用大量的内存资源。

在Nginx配置文件中,可以设置每个进程的最大连接数(worker_connections),以及如何处理并发连接:

events {
  worker_connections 1024; # 每个进程最多同时处理1024个连接
}
2、高度可扩展

Nginx能够支持同时处理成千上万个连接,这使得它非常适合大型网站和需要高并发处理能力的应用。

Nginx 可以为不同的虚拟主机设置不同的worker进程数,以增加并发处理能力:

http {
  worker_processes auto; # 根据系统CPU核心数自动设置worker进程数
}
3、轻量级

与传统的基于进程的Web服务器(如Apache)相比,Nginx在处理请求时占用的内存更少。这是因为Nginx使用事件驱动模型,每个连接只占用很小的内存空间。比如说可以设置每个worker进程的内存限制:

events {
  worker_rlimit_nofile 1024; # 每个worker进程的最大打开文件描述符数
}
4、热部署

Nginx支持热部署,即在不重启服务器的情况下更新配置和模块。要实现热部署,可以使用 nginx -s ``reload命令。在修改了Nginx配置文件后,可以通过以下命令热部署配置:

sudo nginx -s reload
5、负载均衡

Nginx内置了负载均衡功能,可以通过upstream模块在多个后端服务器之间分配客户端请求,以此提高整个服务系统的处理能力。以下是一个简单的upstream配置,它将请求轮询分配到三个后端服务器:

upstream backend {
server backend1.example.com;
server backend2.example.com;
server backend3.example.com;
}


server {
location / {
proxy_pass http://backend; # 将请求转发到upstream定义的backend组
}
}
6、高性能

Nginx在多种标准的Web性能测试中表现出色,能够快速处理静态文件、索引文件和代理请求。配置Nginx作为反向代理服务器,为大型静态文件下载服务:

location /files/ {
  alias /path/to/files/; # 设置实际文件存储路径
  expires 30d; # 设置文件过期时间为30天
}
7、安全性,Nginx支持SSL/TLS协议

Nginx支持SSL/TLS协议,可以配置为安全的Web服务器或反向代理。

server {
  listen 443 ssl;
  ssl_certificate /path/to/fullchain.pem; # 证书路径
  ssl_certificate_key /path/to/privatekey.pem; # 私钥路径
  ssl_protocols TLSv1.2 TLSv1.3; # 支持的SSL协议
}

Nginx支持的复杂均衡调度算法

Nginx支持多种复杂的负载均衡调度算法,以适应不同的应用场景和需求。以下是几种常见的负载均衡算法的详细说明和示例:

1、weight轮询(默认)

weight轮询(Round Robin)是Nginx默认的负载均衡算法。它按顺序将请求逐一分配到不同的服务器上。通过设置服务器权重(weight)来调整不同服务器上请求的分配率。如果某一服务器宕机,Nginx会自动将该服务器从队列中剔除,请求代理会继续分配到其他健康的服务器上。

upstream backend {
  server backend1.example.com weight=3; # 设置backend1的权重为3
  server backend2.example.com; # backend2的权重为默认值1
  server backend3.example.com weight=5; # 设置backend3的权重为5
}
2、IP Hash

IP Hash算法根据客户端请求的IP地址的哈希值进行匹配,将具有相同IP哈希值的客户端分配到指定的服务器。这样可以确保同一客户端的请求始终被分配到同一台服务器,有助于保持用户的会话状态。

upstream backend {
  ip_hash; # 启用IP哈希算法
  server backend1.example.com;
  server backend2.example.com;
}
3、fair

fair 调度算法是一种根据服务器处理请求的响应时间和处理效率进行负载均衡的方法。它结合了轮询和IP哈希的优点,但Nginx默认不支持公平调度算法,需要安装额外的模块(upstream_fair)来实现。

upstream backend {
  fair; # 启用公平调度算法
  server backend1.example.com;
  server backend2.example.com;
  server backend3.example.com;
}
4、URL Hash

URL Hash 算法根据访问的URL的哈希结果分配请求。每个请求的URL会被分配到指定的服务器,这有助于提高缓存效率。但这种方法需要安装Nginx的hash软件包。

upstream backend {
  hash $request_uri; # 启用URL哈希算法
  server backend1.example.com;
  server backend2.example.com;
}
# 根据请求的URL哈希值来决定将请求发送到backend1还是backend2。

Nginx实践

Nginx 通过配置 .conf 静态文件运行(如/usr/local/nginx/conf/vhost/admin.conf)。
upstream backend_servers {
    server backend1.example.com;
    server backend2.example.com;
    server backend3.example.com;
}


server  {
    listen 80;  # 服务端口号
    client_max_body_size 100m;  # body请求数据大小
    index index.html;  # 项目地址
    root  /user/project/admin;  # 项目根目录地址
    # 路由配置
    location ~ /* {
        proxy_pass  http://127.0.0.1:3001;  # 代理服务地址 proxy_pass http://backend_servers;
        proxy_redirect     off; 
        proxy_set_header   Host             $host;
        proxy_set_header   X-Real-IP        $remote_addr;
        proxy_set_header   X-Forwarded-For  $proxy_add_x_forwarded_for;


        proxy_next_upstream error timeout invalid_header http_500 http_502 http_503 http_504;
        proxy_max_temp_file_size 0;
        proxy_connect_timeout      90;
        proxy_send_timeout         90;
        proxy_read_timeout         90;
        proxy_buffer_size          4k;
        proxy_buffers              4 32k;
        proxy_busy_buffers_size    64k;
        proxy_temp_file_write_size 64k;
    }
    location ~ .*.(gif|jpg|jpeg|png|swf)$ {
        expires      1d;
    }
    location ~ .*.(js|css)?$ {
        expires      24h;
    }
    location ~ /.well-known {
        allow all;
    }
    location ~ /. {
        deny all;
    }
    access_log  /user/logs/admin.log; # 记录日志
}

配置详情如下:

server:定义一个虚拟主机的配置块,一个 HTTP 中可以配置多个 server。

listen 80:设置服务端监听的端口号为 80。

client_max_body_size 100m:设置请求中允许的最大 body 大小为 100 MB。

index index.html:设置项目地址的默认文件为 index.html。

root /user/project/admin:指定项目根目录的路径。

location /:配置请求路径为 / 的 location 块。

  • proxy_pass http://127.0.0.1:3001:将请求代理到地址的后端服务器。
  • proxy_redirect off:关闭代理重定向。
  • proxy_set_header:设置代理请求头。
  • proxy_next_upstream:定义当后端服务器返回错误时,Nginx 将如何处理请求。
  • proxy_max_temp_file_size:设置允许的最大临时文件大小。
  • proxy_connect_timeout、proxy_send_timeout、proxy_read_timeout:定义代理连接、发送和读取超时时间。
  • proxy_buffer_size、proxy_buffers、proxy_busy_buffers_size:设置代理缓冲区的大小。
  • proxy_temp_file_write_size:设置代理临时文件的写入大小。

location ~ .*.(gif|jpg|jpeg|png|swf)$:配置请求以 .gif、.jpg、.jpeg、.png 或 .swf 结尾的文件的 location 块。

  • expires 1d:设置这些文件的过期时间为 1 天。

location ~ .*.(js|css)?$:配置请求以 .js 或 .css 结尾的文件的 location 块。

  • expires 24h:设置这些文件的过期时间为 24 小时。

location ~ /.well-known:配置请求以 /.well-known 开头的路径的 location 块。

  • allow all:允许所有请求访问该路径。

location ~ /. :配置以 . 开头的路径的 location 块。

  • deny all:禁止所有请求访问该路径。

access_log /user/logs/admin.log:指定记录日志的路径为 /user/logs/admin.log。

Nginx 配置的实战案例通常涉及多种场景,包括但不限于静态资源服务、反向代理、负载均衡、HTTPS 配置、安全防护等。以下是一些常见的 Nginx 配置实战案例:

静态资源服务
server {
    listen 80;
    server_name example.com;
    location / {
        root /path/to/your/static/files;
        index index.html index.htm;
    }
    location ~* \.(jpg|png|gif|jpeg)$ {
        expires 30d;
        add_header Cache-Control "public";
    }
}

在这个案例中,Nginx 配置为服务静态文件,如 HTML、CSS、JavaScript 和图片等。通过设置 root 指令,指定了静态文件的根目录。同时,对于图片文件,通过 expires 指令设置了缓存时间为 30 天,减少了服务器的负载和用户等待时间。

反向代理
server {
    listen 80;
    server_name api.example.com;
    location / {
        proxy_pass http://backend;
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    }
}

这个案例展示了如何配置 Nginx 作为反向代理服务器。当客户端请求 api.example.com 时,Nginx 会将请求转发到后端服务器集群。通过设置 proxy_set_header,可以修改客户端请求的头部信息,确保后端服务器能够正确处理请求。

负载均衡
http {
    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;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        }
    }
}

在这个负载均衡的案例中,Nginx 将请求分发给多个后端服务器。通过 upstream 指令定义了一个服务器组,然后在 location 块中使用 proxy_pass 指令将请求代理到这个服务器组。Nginx 支持多种负载均衡策略,如轮询(默认)、IP 哈希等。

HTTPS 配置
server {
    listen 443 ssl;
    server_name example.com;
    ssl_certificate /path/to/your/fullchain.pem;
    ssl_certificate_key /path/to/your/private.key;
    ssl_protocols TLSv1.2 TLSv1.3;
    ssl_ciphers 'ECDHE-ECDSA-AES128-GCM-SHA256:ECDHE-RSA-AES128-GCM-SHA256:ECDHE-ECDSA-AES256-GCM-SHA384:ECDHE-RSA-AES256-GCM-SHA384:DHE-RSA-AES128-GCM-SHA256:DHE-RSA-AES256-GCM-SHA384';
    ssl_prefer_server_ciphers on;
    location / {
        root /path/to/your/https/static/files;
        index index.html index.htm;
    }
}

这个案例展示了如何配置 Nginx 以支持 HTTPS。通过指定 SSL 证书和私钥的路径,以及设置 SSL 协议和加密套件,可以确保数据传输的安全。同时,建议使用 HTTP/2 协议以提升性能。

安全防护
server {
    listen 80;
    server_name example.com;
    location / {
        # ... 省略其他配置
        # 防止 SQL 注入等攻击
        rewrite ^/(.*)$ /index.php?param=$1 break;
        # 限制请求方法,只允许 GET 和 POST
        if ($request_method !~ ^(GET|POST)$ ) {
            return 444;
        }
        # 防止跨站请求伪造
        add_header X-Frame-Options "SAMEORIGIN";
        add_header X-Content-Type-Options "nosniff";
        add_header X-XSS-Protection "1; mode=block";
    }
}

在这个安全防护的案例中,Nginx 配置了多种安全增强措施。通过 rewrite 指令,可以防止一些常见的 Web 攻击,如 SQL 注入。通过限制请求方法,可以减少服务器被恶意利用的风险。同时,添加了一些 HTTP 头部来增强浏览器安全,如防止点击劫持、MIME 类型嗅探和跨站脚本攻击(XSS)。
这些案例仅是 Nginx 配置的冰山一角。N

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1604247.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

二叉树的中序遍历 - LeetCode 热题 36

大家好!我是曾续缘😃 今天是《LeetCode 热题 100》系列 发车第 36 天 二叉树第 1 题 ❤️点赞 👍 收藏 ⭐再看,养成习惯 二叉树的中序遍历 给定一个二叉树的根节点 root ,返回 它的 中序 遍历 。 示例 1: 输…

考研数学|《1800》《660》《880》如何选择和搭配?(附资料分享)

直接说结论:基础不好先做1800、强化之前660,强化可选880/1000题。 首先,传统习题册存在的一个问题是题量较大,但难度波动较大。《汤家凤1800》和《张宇1000》题量庞大,但有些题目难度不够平衡,有些过于简单…

图神经网络推荐系统

链接(何向南教授):https://hexiangnan.github.io/papers/wsdm22-tutorial-proposal.pdf 摘要: 近年来,图神经网络(graph neural network, GNN)以其强大的结构化数据处理能力和对高阶信息的挖掘能力,成为许…

全格式播放器哪个好?分享好用的播放器

全格式播放器哪个好?在数字化时代,全格式播放器的重要性日益凸显。它们凭借强大的兼容性和高效的解码能力,让我们能够轻松应对各种音视频格式的播放需求。无论是观看高清电影、欣赏高品质音乐,还是处理工作中的多媒体文件&#xf…

idea中停止运行Vue

在里面敲入Ctrlc 输入y确定即可。

【Proteus】51单片机对直流电机的控制

直流电机:输出或输入为直流电能的旋转电机。能实现直流电能和机械能互相转换的电机。把它作电动机运行时是直流电动机,电能转换为机械能;作发电机运行时是直流发电机,机 械能转换为电能。 直流电机的控制: 1、方向控制…

中国隧道空间分布

中国隧道空间分布数据,包含2020年全国大部分地区16000余条隧道分布点位数据,数据包括市名称、区县名称、隧道名称和隧道经纬度。数据包含shp和EXCEl两种格式,部分隧道空间位置有偏移。 欢迎大家关注、收藏和留言,如果您想要什么数…

文化=知识+素质!电动车限制多!——早读(逆天打工人爬取热门微信文章解读)

你是一个有文化的人! 引言Python 代码第一篇 洞见 一个人有没有文化,就看这五点第二篇 人民日报 来啦 新闻早班车要闻社会政策 结尾 知耻近乎勇 文化教会我们自省 以羞耻心为镜 照见自我 不断向善向上。 引言 绝了 昨天晚上早早上床 10点左右就睡眠模…

【刷题笔记】第八天

文章目录 [928. 尽量减少恶意软件的传播 II](https://leetcode.cn/problems/minimize-malware-spread-ii/)方法1:dfs方法2:并查集 [GCD and LCM](https://vjudge.net.cn/problem/Aizu-0005)[Missing Bigram](https://vjudge.net.cn/problem/CodeForces-1…

三步教你怎么把icloud照片恢复至iphone!

“我手机里面照片被优化后,然后不小心把所有被优化的模糊照片从手机中删除了,但是iCloud还有,我应该怎样把iCloud的照片重新放回手机?谢谢。” 在使用iPhone时,iCloud照片库是一个非常方便的功能,它允许你在…

【SVG】从零开始绘制条形图

效果图 定义背景色和坐标轴颜色 :root {--cord-color: #2be7ca; }body {background-color: #000;}画坐标轴 画X轴 <!-- 坐标轴 --> <g id"cordinate"><!-- x轴 --><line x1"50" y1"600" x2"900" y2"600&q…

博弈论和sg函数

Nim游戏 题目链接&#xff1a;Nim游戏 先说结论&#xff1a;假设n堆石子&#xff0c;石子数分别为a1,a2,a3.....&#xff0c;则当a1^a2^a3^...^an0时先手必败&#xff0c;否则先手必胜。 因为所表示的二进制位必定是成对出现的&#xff0c;根据性质 1 ^ 1 0 &#xff0c;0 …

MyBatis 源码分析 - 缓存原理

MyBatis 源码分析 - 缓存原理 1.简介 在 Web 应用中&#xff0c;缓存是必不可少的组件。通常我们都会用 Redis 或 memcached 等缓存中间件&#xff0c;拦截大量奔向数据库的请求&#xff0c;减轻数据库压力。作为一个重要的组件&#xff0c;MyBatis 自然也在内部提供了相应的…

量子密钥分发系统的设计与实现(二):光路子系统初步讨论

通过上一篇文章&#xff0c;我们对量子密钥分发系统的基本架构、硬件结构以及密钥分发流程进行了初步的总体介绍&#xff0c;从本文开始&#xff0c;我们就基于系统顶层的架构设计&#xff0c;开始从模块到器件&#xff0c;从硬件到软件开始详细讨论QKD系统的设计与实现。本文主…

【转】这些年背过的面试题——网络和操作系统基础篇

转自&#xff1a;阿里巴巴技术质量 阿里云开发者 阿里妹导读 本文是技术人面试系列网络和操作系统基础篇&#xff0c;面试中关于网络和操作系统基础都需要了解哪些内容&#xff1f;一文带你详细了解&#xff0c;欢迎收藏&#xff01; 网络基础 TCP三次握手 三次握手过程&…

陇剑杯 ios 流量分析 CTF writeup

陇剑杯 ios 流量分析 链接&#xff1a;https://pan.baidu.com/s/1KSSXOVNPC5hu_Mf60uKM2A?pwdhaek 提取码&#xff1a;haek目录结构 LearnCTF ├───LogAnalize │ ├───linux简单日志分析 │ │ linux-log_2.zip │ │ │ ├───misc日志分析 │ │…

华为云服务镜像手动更换

操作步骤&#xff1a; 1、进入华为云首页点击云容器引擎CCE&#xff1b; 2、选择你所要更换镜像的环境【这里以dev环境演示】&#xff1b; 3、点击dev环境后选择顶部的命名空间&#xff0c;点击【工作负载】中右侧栏的【升级】按钮&#xff1b; 4、点【更换镜像】选择你在test…

压缩感知的概述梳理(1)

参考文献 An efficient visually meaningful image compression and encryption scheme based on compressive sensing and dynamic LSB embedding 基本内容 基本关系梳理 压缩感知核心元素 信号 x 长度&#xff1a;N动态稀疏或可用变换表示&#xff1a;x &#x1d74d;s …

一篇文章带你快速认识区块链(必看)

引言 区块链技术&#xff0c;这一划时代的分布式账本技术&#xff0c;正在全球范围内掀起一场深度的信任与协作模式变革。区块链如同一部由多方共同维护的公开而又安全的大账本&#xff0c;每一笔交易都被打包成一个区块&#xff0c;通过高级密码学手段确保传输和访问安全&…

React中redux、react-redux、@reduxjs/toolkit状态管理库的使用方式

效果 下载依赖 npm install redux react-redux reduxjs/toolkit --save在src目录下创建文件 创建index.ts文件 import { configureStore } from reduxjs/toolkit import userSlice from ./userReducerconst store configureStore({reducer: {user: userSlice.reducer} }) //…