项目开发01-nginx的使用

1.问题描述

       在项目的测试阶段,我们通常首先检查日志来定位并修复简单的错误。对于那些无法仅通过日志解决的问题,需要在本地环境中复现这些问题。我们通常通过检查接口请求并使用postman在本地模拟这些请求,然后进行debug来修复问题。然而,这个过程往往繁琐和耗时。

2.问题分析

     如果能够简化这个过程,直接使测试环境的前端代码访问本地的代码,就可以直接在本地进行debug和修复,从而避免了在复现bug时需要定位接口、拼接参数和获取token等繁琐步骤,节约时间。尽管一些开发者可能考虑抓取curl命令并导入到postman以复现问题,这样依然存在多个步骤,并不理想。

    实际上,我们所需要的只是将前端项目中的接口请求转发到我们的本地环境,这可以通过配置nginx作为代理来实现。

3.解决方案

   3.1 配置host 文件

       ​​​​​​​    3.1.1 找到需要代理的域名

       3.1.2配置host文件

​​​​​​​

   3.2 配置nginx 转发(核心配置)

           ​​​​​​​

       注意:

     1.测试环境我们用的是协议是https,需要配置证书,我们去测试服务器下载到本地,自己配置就可以

     2.启动本地项目后,再次点击我们的管理后台,请求就已经代理到我们本地了

       

   4.nginx 知识拓展

         4.1 location 匹配规则

         4.1 proxy_pass 指令使

          4.1.1 使用 / 

location /hxq-edu-manage-api/ {
        proxy_pass   http://127.0.0.1:9988/;
        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;
}
https://test-sygw.xxxxx.cn/hxq-edu-manage-api/student/findStudentList 
代理后路径如下 
http://127.0.0.1:9988/student/findStudentList 

            4.1.2 不使用使用 /              

location /hxq-edu-manage-api/ {
        proxy_pass   http://127.0.0.1:9988;
        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;
}
https://test-sygw.xxxxx.cn/hxq-edu-manage-api/student/findStudentList 
转发后如下 
http://127.0.0.1:9988/hxq-edu-manage-api/student/findStudentList 

        4.1.3 总结

  •        带斜杠proxy_pass会从请求的URI中剔除 location 指令中匹配的部分,仅转发剩余的路径到后端服务器。不带斜杠的proxy_pass: 会将完整的请求URI转发到后端服务器,不剔除任何部分。我们在项目中还是推荐使用 带 / 的方式。原因如下:

         1.路径归一化:带斜杠的配置自动处理尾部斜杠的添加,保证路径的一致性,这在许多后             端.框架中.是有用的 ,因为它们可能区分带斜杠和不带斜杠的路径作为不同的路由。

        2.直接访问:不带斜杠的配置不会自动添加斜杠,可能导致对后端服务器的路由解析有所不.      同,特别是当后端框架对尾斜杠敏感时。       

       

               

                 

    

          

       

  • 25
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值