0

0

nginx能用来做什么

PHPz

PHPz

发布时间:2023-05-16 20:20:38

|

1133人浏览过

|

来源于亿速云

转载

    location的匹配规则

    1. = 表示精确匹配。只有请求的url路径与后面的字符串完全相等时,才会命中。

    2. ^~ 表示如果该符号后面的字符是最佳匹配,采用该规则,不再进行后续的查找。

    3. ~ 表示该规则是使用正则定义的,区分大小写。

    4. ~* 表示该规则是使用正则定义的,不区分大小写。

    注意的是,nginx的匹配优先顺序按照上面的顺序进行优先匹配,而且注意的是一旦某一个匹配命中直接退出,不再进行往下的匹配

    剩下的普通匹配会按照最长匹配长度优先级来匹配,就是谁匹配的越多就用谁。

    server {
        server_name website.com;
        location /document {
            return 701;
        }
        location ~* ^/docume.*$ {
            return 702;
        }
        location ~* ^/document$ {
            return 703;
        }
    
    }
    curl -I  website.com:8080/document 702
    # 匹配702 因为正则的优先级更高,而且正则是一旦匹配到就直接退出 所以不会再匹配703
    server {
        server_name website.com;
        location ~* ^/docume.*$ {
            return 701;
        }
    
        location ^~ /doc {
            return 702;
        }
        location ~* ^/document$ {
            return 703;
        }
    }
    curl http://website.com/document
    HTTP/1.1 702
    # 匹配702 因为 ^~精确匹配的优先级比正则高 也是匹配到之后支持退出
    server {
        server_name website.com;
        location /doc {
            return 702;
        }
        location /docu {
            return 701;
        }
    }
    # 701 前缀匹配匹配是按照最长匹配,跟顺序无关

    history模式、跨域、缓存、反向代理

    # html设置history模式
    location / {
        index index.html index.htm;
        proxy_set_header Host $host;
        # history模式最重要就是这里
        try_files $uri $uri/ /index.html;
        # index.html文件不可以设置强缓存 设置协商缓存即可
        add_header Cache-Control 'no-cache, must-revalidate, proxy-revalidate, max-age=0';
    }
    
    # 接口反向代理
    location ^~ /api/ {
        # 跨域处理 设置头部域名
        add_header Access-Control-Allow-Origin *;
        # 跨域处理 设置头部方法
        add_header Access-Control-Allow-Methods 'GET,POST,DELETE,OPTIONS,HEAD';
        # 改写路径
        rewrite ^/api/(.*)$ /$1 break;
        # 反向代理
        proxy_pass http://static_env;
        proxy_set_header Host $http_host;
    }
    
    location ~* \.(?:css(\.map)?|js(\.map)?|gif|svg|jfif|ico|cur|heic|webp|tiff?|mp3|m4a|aac|ogg|midi?|wav|mp4|mov|webm|mpe?g|avi|ogv|flv|wmv)$ {
        # 静态资源设置七天强缓存
        expires 7d;
        access_log off;
    }

    以目录去区分多个history单文件

    因为不可能每一个项目开启一个域名,仅仅指向通过增加路径来划分多个网站,比如:

    1. www.taobao.com/tmall/login访问天猫的登录页面

    2. www.taobao.com/alipay/login访问支付宝的登录页面

    server {
        listen 80;
        server_name taobao.com;
        index index.html index.htm;
        # 通过正则来匹配捕获 [tmall|alipay]中间的这个路径
        location ~ ^/([^\/]+)/(.*)$ {
            try_files $uri $uri/ /$1/dist/index.html =404;
        }
    }

    负载均衡

    基于upstream做负载均衡,中间会涉及一些相关的策略比如ip_hash、weight

    upstream backserver{ 
        # 哈希算法,自动定位到该服务器 保证唯一ip定位到同一部机器 用于解决session登录态的问题
        ip_hash; 
        server 127.0.0.1:9090 down; (down 表示单前的server暂时不参与负载) 
        server 127.0.0.1:8080 weight=2; (weight 默认为1.weight越大,负载的权重就越大) 
        server 127.0.0.1:6060; 
        server 127.0.0.1:7070 backup; (其它所有的非backup机器down或者忙的时候,请求backup机器) 
    }

    灰度部署

    如何根据headers头部来进行灰度,下面的例子是用cookie来设置

    如何获取头部值在nginx中可以通过$http_xxx来获取变量

    upstream stable {
        server xxx max_fails=1 fail_timeout=60;
        server xxx max_fails=1 fail_timeout=60;
     }
    upstream canara {
       server xxx max_fails=1 fail_timeout=60;
    }
    
    server {
        listen 80;
        server_name  xxx;
        # 设置默认
        set $group "stable";
    
        # 根据cookie头部设置接入的服务
        if ($http_cookie ~* "tts_version_id=canara"){
            set $group canara;
        }
        if ($http_cookie ~* "tts_version_id=stable"){
            set $group stable;
        }
        location / {
            proxy_pass http://$group;
            proxy_set_header   Host             $host;
            proxy_set_header   X-Real-IP        $remote_addr;
            proxy_set_header   X-Forwarded-For $proxy_add_x_forwarded_for;
            index  index.html index.htm;
        }
    }

    优雅降级

    常用于ssr的node服务挂了返回500错误码然后降级到csr的cos桶或者nginx中

    优雅降级主要用error_page参数来进行降级指向备用地址。

    upstream ssr {
        server xxx max_fails=1 fail_timeout=60;
        server xxx max_fails=1 fail_timeout=60;
     }
    upstream csr {
        server xxx max_fails=1 fail_timeout=60;
        server xxx max_fails=1 fail_timeout=60;
    }
    
    location ^~ /ssr/ {
        proxy_pass http://ssr;
        # 开启自定义错误捕获 如果这里不设置为on的话 会走向nginx处理的默认错误页面
        proxy_intercept_errors on;
        # 捕获500系列错误 如果500错误的话降级为下面的csr渲染
        error_page 500 501 502 503 504 = @csr_location
    
        # error_page 500 501 502 503 504 = 200 @csr_location
        # 注意这上面的区别 等号前面没有200 表示 最终返回的状态码已 @csr_location为准 加了200的话表示不管@csr_location返回啥都返回200状态码
    }
    
    location @csr_location {
        # 这时候地址还是带着/ssr/的要去除
        rewrite ^/ssr/(.*)$ /$1 break;
        proxy_pass http://csr;
        rewrite_log on;
    }

    webp根据浏览器自动降级为png

    这套方案不像常见的由nginx把png转为webp的方案,而是先经由图床系统(node服务)上传两份图片:

    1. 一份是原图png

    2. 一份是png压缩为webp的图片(使用的是imagemin-webp)

    接着,使用nginx检测请求头中是否支持webp格式,若支持则返回webp图片,否则返回原图。在这过程中还进行了错误拦截,以便在COS桶中缺失WebP图像且浏览器支持WebP的情况下,能够降级为PNG格式

    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"'
      '"$proxy_host" "$upstream_addr"';
    
      access_log  /var/log/nginx/access.log  main;
    
      sendfile        on;
      keepalive_timeout  65;
    
      # 开启gzip
      gzip on;
      gzip_vary on;
      gzip_proxied any;
      gzip_comp_level 6;
      gzip_types text/plain text/css text/xml application/json application/javascript application/rss+xml application/atom+xml image/svg+xml;
    
      # 负载均衡 这里可以是多个cos桶地址即可
      upstream static_env {
        server xxx;
        server xxx;
      }
    
      # map 设置变量映射 第一个变量指的是要通过映射的key值 Accpet 第二个值的是变量别名
      map $http_accept $webp_suffix {
        # 默认为 空字符串
        default   "";
        # 正则匹配如果Accep含有webp字段 设置为.webp值
        "~*webp"  ".webp";
      }
      server {
    
        listen 8888;
        absolute_redirect off;    #取消绝对路径的重定向
        #网站主页路径。此路径仅供参考,具体请您按照实际目录操作。
        root /usr/share/nginx/html;
    
        location / {
          index index.html index.htm;
          proxy_set_header Host $host;
          try_files $uri $uri/ /index.html;
          add_header Cache-Control 'no-cache, max-age=0';
        }
    
        # favicon.ico
        location = /favicon.ico {
          log_not_found off;
          access_log off;
        }
    
        # robots.txt
        location = /robots.txt {
          log_not_found off;
          access_log off;
        }
    
        # 
        location ~* \.(png|jpe?g)$ {
          # Pass WebP support header to backend
          # 如果header头部中支持webp
          if ($webp_suffix ~* webp) {
            # 先尝试找是否有webp格式图片
            rewrite ^/(.*)\.(png|jpe?g)$ /$1.webp break;
            # 找不到的话 这里捕获404错误 返回原始错误 注意这里的=号 代表最终返回的是@static_img的状态吗
            error_page 404 = @static_img;
          }
          proxy_intercept_errors on;
          add_header Vary Accept;
          proxy_pass http://static_env;
          proxy_set_header Host $http_host;
          expires 7d;
          access_log off;
        }
    
        location @static_img {
          #set $complete $schema $server_addr $request_uri;
          rewrite ^/.+$ $request_uri break;
          proxy_pass http://static_env;
          proxy_set_header Host $http_host;
          expires 7d;
        }
    
    
        # assets, media
        location ~* \.(?:css(\.map)?|js(\.map)?|gif|svg|jfif|ico|cur|heic|webp|tiff?|mp3|m4a|aac|ogg|midi?|wav|mp4|mov|webm|mpe?g|avi|ogv|flv|wmv)$ {
          proxy_pass http://static_env;
          proxy_set_header Host $http_host;
          expires 7d;
          access_log off;
        }
    
    
        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
          root   /usr/share/nginx/html;
        }
      }
    }

    为什么要用nginx,nginx有什么特点?

    nginx的特点:

    • 核心特点:高并发请求的同时保持高效的服务

      手机在线人工冲值
      手机在线人工冲值

      说明:我不知道这个系统还能用到什么地方!他的运作方式是这样的,客户在其他地方比如掏宝购买了 你得卡,然后在你的网站进行冲值,你得有人登陆并看着后台,如果有人冲值,就会刷出记录,手工冲值完毕后,你得点击 [冲值完毕],客户的页面 就会返回 冲值信息!安装:上传所有文件,倒入(sql.txt)mysql数据库,使用myphpadminphplib 777phplib/sys.php 777phplib

      下载
    • 热部署

    • 低内存消耗

    • 处理响应请求很快

    • 具有很高的可靠性

    同时,nginx也可以实现高效的反向代理、负载均衡。

    前端可以用nginx做些什么?

    • 搭建静态资源服务器

    • 反向代理分发后端服务(可以和nodejs搭配实现前后端分离)和跨域问题

    • 根据User Agent来重定向站点

    • 开发环境或测试环境切换(切换host)

    • url重写,使用rewrie规则本地映射

    • 资源内容篡改

    • 获取cookie做分流

    • 资源合并

    • gzip压缩

    • 压缩图片

    • sourceMap调试

    热门AI工具

    更多
    DeepSeek
    DeepSeek

    幻方量化公司旗下的开源大模型平台

    豆包大模型
    豆包大模型

    字节跳动自主研发的一系列大型语言模型

    通义千问
    通义千问

    阿里巴巴推出的全能AI助手

    腾讯元宝
    腾讯元宝

    腾讯混元平台推出的AI助手

    文心一言
    文心一言

    文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

    讯飞写作
    讯飞写作

    基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

    即梦AI
    即梦AI

    一站式AI创作平台,免费AI图片和视频生成。

    ChatGPT
    ChatGPT

    最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

    相关专题

    更多
    C# ASP.NET Core微服务架构与API网关实践
    C# ASP.NET Core微服务架构与API网关实践

    本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

    0

    2026.03.11

    Go高并发任务调度与Goroutine池化实践
    Go高并发任务调度与Goroutine池化实践

    本专题围绕 Go 语言在高并发任务处理场景中的实践展开,系统讲解 Goroutine 调度模型、Channel 通信机制以及并发控制策略。内容包括任务队列设计、Goroutine 池化管理、资源限制控制以及并发任务的性能优化方法。通过实际案例演示,帮助开发者构建稳定高效的 Go 并发任务处理系统,提高系统在高负载环境下的处理能力与稳定性。

    22

    2026.03.10

    Kotlin Android模块化架构与组件化开发实践
    Kotlin Android模块化架构与组件化开发实践

    本专题围绕 Kotlin 在 Android 应用开发中的架构实践展开,重点讲解模块化设计与组件化开发的实现思路。内容包括项目模块拆分策略、公共组件封装、依赖管理优化、路由通信机制以及大型项目的工程化管理方法。通过真实项目案例分析,帮助开发者构建结构清晰、易扩展且维护成本低的 Android 应用架构体系,提升团队协作效率与项目迭代速度。

    48

    2026.03.09

    JavaScript浏览器渲染机制与前端性能优化实践
    JavaScript浏览器渲染机制与前端性能优化实践

    本专题围绕 JavaScript 在浏览器中的执行与渲染机制展开,系统讲解 DOM 构建、CSSOM 解析、重排与重绘原理,以及关键渲染路径优化方法。内容涵盖事件循环机制、异步任务调度、资源加载优化、代码拆分与懒加载等性能优化策略。通过真实前端项目案例,帮助开发者理解浏览器底层工作原理,并掌握提升网页加载速度与交互体验的实用技巧。

    93

    2026.03.06

    Rust内存安全机制与所有权模型深度实践
    Rust内存安全机制与所有权模型深度实践

    本专题围绕 Rust 语言核心特性展开,深入讲解所有权机制、借用规则、生命周期管理以及智能指针等关键概念。通过系统级开发案例,分析内存安全保障原理与零成本抽象优势,并结合并发场景讲解 Send 与 Sync 特性实现机制。帮助开发者真正理解 Rust 的设计哲学,掌握在高性能与安全性并重场景中的工程实践能力。

    216

    2026.03.05

    PHP高性能API设计与Laravel服务架构实践
    PHP高性能API设计与Laravel服务架构实践

    本专题围绕 PHP 在现代 Web 后端开发中的高性能实践展开,重点讲解基于 Laravel 框架构建可扩展 API 服务的核心方法。内容涵盖路由与中间件机制、服务容器与依赖注入、接口版本管理、缓存策略设计以及队列异步处理方案。同时结合高并发场景,深入分析性能瓶颈定位与优化思路,帮助开发者构建稳定、高效、易维护的 PHP 后端服务体系。

    413

    2026.03.04

    AI安装教程大全
    AI安装教程大全

    2026最全AI工具安装教程专题:包含各版本AI绘图、AI视频、智能办公软件的本地化部署手册。全篇零基础友好,附带最新模型下载地址、一键安装脚本及常见报错修复方案。每日更新,收藏这一篇就够了,让AI安装不再报错!

    143

    2026.03.04

    Swift iOS架构设计与MVVM模式实战
    Swift iOS架构设计与MVVM模式实战

    本专题聚焦 Swift 在 iOS 应用架构设计中的实践,系统讲解 MVVM 模式的核心思想、数据绑定机制、模块拆分策略以及组件化开发方法。内容涵盖网络层封装、状态管理、依赖注入与性能优化技巧。通过完整项目案例,帮助开发者构建结构清晰、可维护性强的 iOS 应用架构体系。

    221

    2026.03.03

    C++高性能网络编程与Reactor模型实践
    C++高性能网络编程与Reactor模型实践

    本专题围绕 C++ 在高性能网络服务开发中的应用展开,深入讲解 Socket 编程、多路复用机制、Reactor 模型设计原理以及线程池协作策略。内容涵盖 epoll 实现机制、内存管理优化、连接管理策略与高并发场景下的性能调优方法。通过构建高并发网络服务器实战案例,帮助开发者掌握 C++ 在底层系统与网络通信领域的核心技术。

    31

    2026.03.03

    热门下载

    更多
    网站特效
    /
    网站源码
    /
    网站素材
    /
    前端模板

    精品课程

    更多
    相关推荐
    /
    热门推荐
    /
    最新课程
    进程与SOCKET
    进程与SOCKET

    共6课时 | 0.4万人学习

    nginx浅谈
    nginx浅谈

    共15课时 | 0.9万人学习

    关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
    php中文网:公益在线php培训,帮助PHP学习者快速成长!
    关注服务号 技术交流群
    PHP中文网订阅号
    每天精选资源文章推送

    Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号