nginx访问静态文件的方式

在最近的项目中,需要nginx来访问具体静态资源。针对这种情况,除了常规使用nginx的反向代理,还有那些方式可以访问具体静态资源。本文列举一些针对静态资源的访问方式。

新建 D:\nginx\json\config.json

json 复制代码
{
    "title":"config.json"
}   

新建 D:\nginx\json\games.json

css 复制代码
[    {        "title":"games.json"    }       ]

新建 D:\nginx\json\localhost\games.json

css 复制代码
[    {        "title":"localhost/games.json"    }        ]

1、方式:

a、proxy_pass

bash 复制代码
server {
        listen       80;
        server_name  localhost;

        location ~ ^/api/(?<param>[^/]+)$ {
            add_header 'Access-Control-Allow-Origin' '*';
            add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS';
            add_header 'Access-Control-Allow-Headers' 'Origin, X-Requested-With, Content-Type, Accept';             
            default_type application/json;
            set $target_url "http://127.0.0.1:5500/json/$param";
            proxy_pass $target_url;
        }  

    }

b、try_files

  • try_files 是 Nginx 中的一个指令,它的作用是按顺序尝试在本地文件系统中查找指定的文件,并返回第一个找到的文件,若所有的文件或文件夹都找不到,会进行一个内部重定向到最后一个参数。
bash 复制代码
server {
        listen       80;
        server_name  localhost;

        location ~ ^/api/(?<param>[^/]+)$ {
            add_header 'Access-Control-Allow-Origin' '*';
            add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS';
            add_header 'Access-Control-Allow-Headers' 'Origin, X-Requested-With, Content-Type, Accept';             
            default_type application/json;
            root json;
            try_files /$host/$param /$param @notfound;
        }  
        location @notfound {
            return 404;
        }

    }

运行指令

javascript 复制代码
docker run --name some-nginx -p 8801:80 -v D:/nginx/json:/etc/nginx/json:ro -v D:/nginx/config/nginx.conf:/etc/nginx/nginx.conf -d nginx

结果:

bash 复制代码
访问http://localhost:8801/api/games.json,结果显示:localhost/games.json
访问http://localhost:8801/api/config.json,结果显示:config.json

c、alias

alias 是 Nginx 中的一个指令,它的作用是为指定的路径设置一个别名(即替换路径)。当客户端请求匹配到指定的路径时,Nginx 会将路径替换为指定的别名,并将请求转发到替换后的路径上。

bash 复制代码
server {
        listen       80;
        server_name  localhost;

        location ~ ^/api/(?<param>[^/]+)$ {
            add_header 'Access-Control-Allow-Origin' '*';
            add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS';
            add_header 'Access-Control-Allow-Headers' 'Origin, X-Requested-With, Content-Type, Accept';             
            default_type application/json;
            alias json/$param;
        }  
        location @notfound {
            return 404;
        }

    }

重新运行指令后,结果:

bash 复制代码
访问http://localhost:8801/api/games.json,结果显示:games.json
访问http://localhost:8801/api/config.json,结果显示:config.json

d、proxy_pass+minio+路径优先级访问验证

需要proxy_pass+error_page+minio来实现类似try_files功能。当访问http://localhost:8801/api/games.json 优先读取minio上:/域名/games.json数据。如果找不到文件,默认读取minio上:/games.json数据。其中https://play.min.io:9000是官方测试地址。

ini 复制代码
server {
        listen       80;
        server_name  localhost;
        resolver 8.8.8.8;
        fastcgi_intercept_errors on;
        proxy_intercept_errors on; 

        location ~ ^/api/(?<param>[^/]+)$ {
            proxy_pass https://play.min.io:9000/mini-wzx/localhost/$param;
            error_page 404 =200 @fallback;
        }

        location @fallback {
            proxy_pass https://play.min.io:9000/mini-wzx/$param;
            error_page 404 =404 @notfound;
        }

        error_page 404 = @notfound;
        location @notfound {
            return 404 "Page not found";
        }


    }

经过测试,这样是可以实现这个文件读取优先级功能,但是存在一些小问题:

1、就是接口在nginx这边产生访问两次,默认访问时间会变长点

2、以及第二次访问子路径数据,如果数据不存在,404变成默认的404处理。

2、参考

相关推荐
雨落Liy2 天前
Nginx 从入门到进阶:反向代理、负载均衡与高性能实战指南
运维·nginx·负载均衡
Yyyy4822 天前
Nginx负载均衡集群实验步骤
运维·nginx·负载均衡
qq_264220893 天前
Nginx优化与 SSL/TLS配置
运维·nginx
matlab的学徒3 天前
Web与Nginx网站服务(改)
linux·运维·前端·nginx·tomcat
邂逅星河浪漫3 天前
【Docker+Nginx+Ollama】前后端分离式项目部署(传统打包方式)
java·nginx·docker·部署
IT成长日记3 天前
【Nginx开荒攻略】Nginx主配置文件结构与核心模块详解:从0到1掌握nginx.conf:
linux·运维·nginx·配置文件
ZzzZZzzzZZZzzzz…3 天前
Nginx_Tomcat综合案例
运维·nginx·tomcat·负载均衡·rhce·反向代理·https加密服务
VueVirtuoso4 天前
SaaS 建站从 0 到 1 教程:Vue 动态域名 + 后端子域名管理 + Nginx 配置
前端·vue.js·nginx
007php0074 天前
Redis高级面试题解析:深入理解Redis的工作原理与优化策略
java·开发语言·redis·nginx·缓存·面试·职场和发展
Xxtaoaooo4 天前
Nginx 502 网关错误:upstream 超时配置的踩坑与优化
运维·nginx·负载均衡·502错误·upstream超时