微应用部署环境下,子应用无法访问(问题记录),try_files详解

64 篇文章 3 订阅
60 篇文章 1 订阅

问题起因

最初将微应用打包到uniCloud上做前端网页托管,没什么问题,能够调到后端,页面也没什么问题。
直到将页面打包部署到服务器上时,页面开始出现各种报错:

  • 缺少生命周期 you need to export lifecycle functions in xxx(微应用名称) entry【其实就是没有加载到微应用,但是确定已经在微应用中main.js已经暴露出了bootstrap()等生命周期—所以这个不是真实的问题】
  • 目标容器不存在 Target container with #my-mico-app not existed after qiankun-vue loading【容器没有,导致浏览器疯狂循环子应用的layout层(如果有容器子应用是没有这个的,应该加载本身的页面)闪烁

解决方案

最终,在测试了各种服务的情况下,尝试修改nginx,想起了vuehistory路由在nginx路径问题

  1. nginx配置微应用路径/xxx/与/404
location / {
        root   /usr/share/nginx/html;
        index  index.html index.htm;
        try_files $uri $uri/ /index.html; #$uri/用于匹配子应用目录下的索引页
        error_page 404 /index.html; # 配上404页面
    }

try_files:其作用是按顺序检查本地(服务器)文件是否存在,返回第一个找到的文件或文件夹(结尾加斜线表示为文件夹),如果所有的文件或文件夹都找不到,会进行一个内部重定向到最后一个参数。

查找方式:

  1. 按指定的file顺序查找存在的文件,并使用第一个找到的文件进行请求处理
  2. 查找路径是按照给定的root或alias为根路径来查找的
  3. 如果给出的file都没有匹配到,则重新请求最后一个参数给定的uri,就是新的location匹配
  4. 如果是格式2,如果最后一个参数是 = 404 ,若给出的file都没有匹配到,则最后返回404的响应码

打包后的结构
在这里插入图片描述

  • map子应用结构
    在这里插入图片描述
  • 如果不写上 $uri/,当直接访问一个目录路径如127.0.0.1/map/xxx(即子应用下的路由时,不会去map包下的index.html127.0.0.1/map/index.html】)
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
nginx的try_files指令用于在处理请求时进行文件查找并执行不同的操作。它的语法如下: ``` try_files file ... uri; ``` 其中,`file`是要查找的文件路径,可以是绝对路径或相对路径。`uri`是要重写的URI或转发的URI。 当接收到一个请求时,Nginx会按照try_files指令中的顺序依次查找文件。如果找到了指定的文件,Nginx会返回该文件的内容。如果找不到文件,则会将请求重写为指定的URI,并继续查找。如果最后一个URI也找不到文件,则会返回404错误页面。 举个例,假设我们有一个目录结构如下: ``` - /var/www/html/ - index.html - images/ - logo.png ``` 我们可以使用try_files指令来配置Nginx: ``` location / { try_files $uri $uri/ /index.html; } location /images/ { try_files $uri $uri/ =404; } ``` 在上面的配置中,如果请求的URI匹配到`/images/`,Nginx会先尝试查找该URI对应的文件。如果找到了文件,比如`/images/logo.png`存在,则会返回该文件。如果找不到文件,则会继续尝试查找`/images/logo.png/`这样的目录。如果目录也不存在,则会返回404错误。 对于其他请求,比如`/about`,Nginx会先尝试查找该URI对应的文件。如果找到了文件,比如`/var/www/html/about`存在,则会返回该文件。如果找不到文件,则会继续尝试查找`/var/www/html/about/`这样的目录。如果目录也不存在,则会返回`/var/www/html/index.html`文件的内容。 总之,try_files指令提供了一种方便的方式来处理文件查找和请求重写,使得我们能够更灵活地配置Nginx的行为。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值