umi配置多环境变量并在docker中跑起来验证
创始人
2025-05-31 10:59:03
0

umi配置多环境变量并在docker中跑起来

  • 1、项目背景
  • 2、配置环境变量
  • 3、使用docker 容器 + nginx在本地运行

1、项目背景

最近开始自己负责一个umi项目从0到1的开发,中间遇到的环境变量配置问题记录一下,顺便再熟悉下前端项目在docker中的部署过程。
主要依赖包版本如下:
在这里插入图片描述
安装cross-env包兼容不同的服务器(linux或者windows等)

2、配置环境变量

这里是配置了 test 和 prod 两个环境

  • 先在跟目录下建立config文件夹,文件夹下再建立三个config文件: config.js,
    config.test.js, config.prod.js, 如下所示:

在这里插入图片描述

  • 其中config.test.js 和 config.prod.js 中分别配置不同的process.env.UMI_ENV的值。
    然后在package.json中写入不同环境下的build命令
    在这里插入图片描述
  • 最后在页面中打印配置好的环境变量,不同的环境应该会看到不同的值

在这里插入图片描述

3、使用docker 容器 + nginx在本地运行

设置好不同的环境变量后,先试下测试环境在docker中跑起来,通过打印检查配置是否生效。在此之前我们要先在本地电脑安装好docker并打开(小白教程在这里)

  • 第一步先在本地根目录建一个test.Dockerfile文件, 内容如下:
# 拉取nginx镜像
FROM nginx:alpine
ENV TZ=Asia/Shanghai
RUN ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && echo '$TZ' > /etc/timezone && \mv /etc/nginx/conf.d/default.conf /etc/nginx/conf.d/default-conf-bak
# 运行nginx.config文件
ADD nginx/nginx.conf /etc/nginx/nginx.conf
# dist文件夹下的index.html替换到nginx的html
ADD dist/ /usr/share/nginx/html/
# 暴露容器端口
EXPOSE 8080
CMD [ "nginx", "-g", "daemon off;" ]
  • 再建一个nginx文件夹,下面建nginx.config, 内容如下:
worker_processes  1;
events {worker_connections  1024;
}error_log  /var/log/nginx/error1.log debug;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"';access_log  /var/log/nginx/access1.log  main;sendfile        on;tcp_nopush      on;tcp_nodelay     on;keepalive_timeout  65;types_hash_max_size     2048;#gzip  on;gzip on;gzip_min_length 1k;gzip_comp_level 9;gzip_types text/plain application/javascript application/x-javascript text/css application/xml text/javascript application/x-httpd-php image/jpeg image/gif image/png;gzip_vary on;gzip_disable "MSIE [1-6]\.";include /etc/nginx/conf.d/*.conf;add_header Access-Control-Allow-Credentials true;add_header Access-Control-Allow-Headers $http_access_control_request_headers;add_header Access-Control-Allow-Methods POST,GET,OPTIONS,DELETE,PUT,HEAD,PATCH;add_header Access-Control-Allow-Origin $http_origin;add_header Access-Control-Expose-Headers $http_access_control_request_headers;# 内容会变文件名不会变add_header Cache-Control "no-cache";etag on;proxy_set_header X-Forwarded-Proto  $scheme;proxy_set_header Host $proxy_host;server {listen       8080;server_name  test.com;location / {proxy_set_header X-Real-IP $remote_addr;proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;proxy_set_header Host $http_host;client_max_body_size 600m;root   /usr/share/nginx/html;try_files $uri $uri/index.html $uri.html;index  index.html index.htm;}}
}
  • 运行npm run build:test 对测试环境资源打包。打包后会看见多出这个dist文件夹
    在这里插入图片描述

  • 运行docker build -f test.Dockerfile -t umi-test .构建一个名为umi-test的镜像,构建成功后在docker desktop 上能找到刚刚构建的镜像:
    在这里插入图片描述

  • 最后运行docker run --rm -p 3001:8080 umi-test 将镜像跑起来,成功后打开 http://localhost:3001 就能看到我们的项目啦。也可以看到我们配置的process.env.UMI_ENV = test 有生效,生产环境同理可验证。
    在这里插入图片描述

相关内容

热门资讯

【MySQL】锁 锁 文章目录锁全局锁表级锁表锁元数据锁(MDL)意向锁AUTO-INC锁...
【内网安全】 隧道搭建穿透上线... 文章目录内网穿透-Ngrok-入门-上线1、服务端配置:2、客户端连接服务端ÿ...
GCN的几种模型复现笔记 引言 本篇笔记紧接上文,主要是上一篇看写了快2w字,再去接入代码感觉有点...
数据分页展示逻辑 import java.util.Arrays;import java.util.List;impo...
Redis为什么选择单线程?R... 目录专栏导读一、Redis版本迭代二、Redis4.0之前为什么一直采用单线程?三、R...
【已解决】ERROR: Cou... 正确指令: pip install pyyaml
关于测试,我发现了哪些新大陆 关于测试 平常也只是听说过一些关于测试的术语,但并没有使用过测试工具。偶然看到编程老师...
Lock 接口解读 前置知识点Synchronized synchronized 是 Java 中的关键字,...
Win7 专业版安装中文包、汉... 参考资料:http://www.metsky.com/archives/350.htm...
3 ROS1通讯编程提高(1) 3 ROS1通讯编程提高3.1 使用VS Code编译ROS13.1.1 VS Code的安装和配置...
大模型未来趋势 大模型是人工智能领域的重要发展趋势之一,未来有着广阔的应用前景和发展空间。以下是大模型未来的趋势和展...
python实战应用讲解-【n... 目录 如何在Python中计算残余的平方和 方法1:使用其Base公式 方法2:使用statsmod...
学习u-boot 需要了解的m... 一、常用函数 1. origin 函数 origin 函数的返回值就是变量来源。使用格式如下...
常用python爬虫库介绍与简... 通用 urllib -网络库(stdlib)。 requests -网络库。 grab – 网络库&...
药品批准文号查询|药融云-中国... 药品批文是国家食品药品监督管理局(NMPA)对药品的审评和批准的证明文件...
【2023-03-22】SRS... 【2023-03-22】SRS推流搭配FFmpeg实现目标检测 说明: 外侧测试使用SRS播放器测...
有限元三角形单元的等效节点力 文章目录前言一、重新复习一下有限元三角形单元的理论1、三角形单元的形函数(Nÿ...
初级算法-哈希表 主要记录算法和数据结构学习笔记,新的一年更上一层楼! 初级算法-哈希表...
进程间通信【Linux】 1. 进程间通信 1.1 什么是进程间通信 在 Linux 系统中,进程间通信...
【Docker】P3 Dock... Docker数据卷、宿主机与挂载数据卷的概念及作用挂载宿主机配置数据卷挂载操作示例一个容器挂载多个目...