docker 部署 vue-element-ui 项目

docker 部署 vue-element-ui 项目

一. 前言

前后端分离的项目,除了后端微服务的部署之外,当然还少不了前端工程的部署。所以本篇讲述如何通过Docker安装Nginx实现前端Vue项目工程的部署。

1.项目打包

执行npm run build:prod打包项目,打包生成的文件在项目根目录下的dist文件夹。

npm run build:prod

image-20230113145437159

二. Docker安装Nginx

1.创建目录

mkdir -p /usr/share/nginx/conf
mkdir -p /usr/share/nginx/html

2.创建配置文件

touch /usr/share/nginx/conf/nginx.conf

nginx.conf文件添加如下配置

worker_processes  1;

events {
    worker_connections  1024;
}


http {
    include       mime.types;
    default_type  application/octet-stream;
    sendfile        on;
    keepalive_timeout  65;

    server {
        listen     80;
        server_name  localhost;

        location / {
            root /usr/share/nginx/html;
            index index.html index.htm;
	    }
        # 代理转发请求至网关,prod-api标识解决跨域问题
	    location /prod-api/ {
            proxy_pass http://www.youlai.store:9999/;
	    }
    }
}

3. 创建容器并启动

需要创建好nginx镜像

docker run -it -d \
--name nginx \
-p 80:80 \
-v /usr/share/nginx/conf/nginx.conf:/etc/nginx/nginx.conf \
-v /usr/share/nginx/html:/usr/share/nginx/html \
nginx 

两个-v 分别表示配置文件和nginx工作空间目录的映射,冒号左边是宿主机,右边是容器的,这样修改宿主机的配置文件和工作空间就可以同步到容器

4.查看nginx启动日志

docker logs nginx

三. vue-element-admin落地项目线上部署

完成上面的Nginx安装和相关配置后,接下来开始部署前端项目。

vue-element-admin是开源的前端管理系统快速构建脚手架。这里讲述如何将其部署到线上环境。

1.上传项目

使用FTP工具上传dist文件夹下的所有文件至服务器/usr/share/nginx/html目录下

2.项目测试

docker restart nginx

访问项目

image-20230113151126759

访问成功!!

4. 其他说明

在Nginx配置文件中其中有下面这一段配置

location /prod-api/ {
    proxy_pass http://www.youlai.store:9999/;
}

至于为什么会拦截 prod-api 这段标识进行代理转发,看下浏览器的一个完整请求路径你应该就会明白。img

无论是本地的dev-api还是线上的prod-api的标识本质上都是解决前后端分离项目的跨域问题,只不过本地使用的vue的proxyTable代理,线上使用的是nginx的代理,手段则是统一的替换标识为真正的后端地址。

posted @ 2023-01-13 15:17  zrzicu  阅读(266)  评论(0)    收藏  举报