【日常记录-JS】多个react打包的dist目录如何同时放到一个nginx上生效

Author:赵志乾
Date:2024-08-26
Declaration:All Right Reserved!!!

1. 简介

        多个React打包的dist目录同时放到一个Nginx服务器上并使其生效,需要通过Nginx的配置文件来区分不同的项目,并确保它们能够分别被正确地访问。这通常可通过定义不同的server块或在同一个server块内使用不同的location块来实现。

2. 使用不同的server块

        若Nginx服务器有多个域名或子域名指向它,则可以为每个React应用配置一个独立的server块,每个块监听不同的域名或端口。

# 第一个React应用的配置  
server {  
    listen 80;  
    server_name app1.example.com;  
  
    location / {  
        root /path/to/react-app1/dist;  
        index index.html index.htm;  
        try_files $uri $uri/ /index.html;  
    }  
}  
  
# 第二个React应用的配置  
server {  
    listen 80;  
    server_name app2.example.com;  
  
    location / {  
        root /path/to/react-app2/dist;  
        index index.html index.htm;  
        try_files $uri $uri/ /index.html;  
    }  
}

3. 使用同server块下的不同location块

        若所有的React应用都使用相同的域名,但拥有不同的路径前缀,则可以在同一个server块内配置多个location块。

server {  
    listen 80;  
    server_name example.com;  
  
    # 第一个React应用  
    location /app1/ {  
        alias /path/to/react-app1/dist/; # 注意这里使用alias而非root,因为路径中有/app1/  
        try_files $uri $uri/ /app1/index.html; # 确保index.html的路径也更新  
    }  
  
    # 第二个React应用  
    location /app2/ {  
        alias /path/to/react-app2/dist/;  
        try_files $uri $uri/ /app2/index.html;  
    }  
  
    # 其他配置...  
}

        注意:在使用alias时,需要注意Nginx解析路径的原理。alias指定的路径是相对于location中指定的URI前缀,如上面示例中的/app1/index.html实际会被Nginx解析为/path/to/react-app1/dist/index.html。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

我叫白小猿

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值