Docker(Nginx)部署Vue

简介:目标使用docker将vue生成的dist文件,结合nginx生成镜像,然后运行;

1、首选确保vue项目正确运行,并能正确打包dist文件;

2、查看已经生成的dist文件

3、将dist文件打包为rar文件或者zip文件,本文使用rar文件

4、确保服务器已经安装docker;

新建文件夹:/home/questionaire-app/

将dist.rar 上传到该目录下,并解压到当前目录下;

unrar x dist.rar

5、在/home/questionaire-app/下新建nginx配置文件default.conf,新建Dockerfile文件;
1)编辑default.conf文件

sql 复制代码
server {
    listen       80;
    server_name  127.0.0.1;
 
    #charset koi8-r;
    #access_log  /var/log/nginx/log/host.access.log  main;
 
    location / {
        root   /usr/share/nginx/html;
        try_files $uri $uri/ /index.html
        index  index.html index.htm;
    }
 
    location /prod-api/ {
        proxy_pass  http://127.0.0.1:18080/;
    }
 
    #error_page  404              /404.html;
 
    # redirect server error pages to the static page /50x.html
    #
    error_page   500 502 503 504  /50x.html;
    location = /50x.html {
        root   html;
    }
 
    # proxy the PHP scripts to Apache listening on 127.0.0.1:80
    #
    #location ~ \.php$ {
    #    proxy_pass   http://127.0.0.1;
    #}
 
    # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
    #
    #location ~ \.php$ {
    #    root           html;
    #    fastcgi_pass   127.0.0.1:9000;
    #    fastcgi_index  index.php;
    #    fastcgi_param  SCRIPT_FILENAME  /scripts$fastcgi_script_name;
    #    include        fastcgi_params;
    #}
 
    # deny access to .htaccess files, if Apache's document root
    # concurs with nginx's one
    #
    #location ~ /\.ht {
    #    deny  all;
    #}
}

代理可以根据需求配置,不强求

2)编辑Dockerfile文件:

shell 复制代码
# 使用nginx镜像
FROM nginx
# 作者
MAINTAINER cmh
# 删除nginx 默认配置
RUN rm /etc/nginx/conf.d/default.conf
# 添加我们自己的配置 default.conf 在下面
ADD default.conf /etc/nginx/conf.d/
# 把刚才生成dist文件夹下的文件copy到nginx下面去
COPY dist/  /usr/share/nginx/html/

最终该目录下是这样的:

6、生成镜像并运行

1)生成镜像

" . " 这个点不要省略

shell 复制代码
docker build -t mall-admin-vue .

2)运行容器

shell 复制代码
docker run -d --name mall-admin-vue -p 8088:80 mall-admin-vue

7、测试:

浏览器通过ip+端口访问

参考文档:https://blog.csdn.net/cmh1008611/article/details/144793141

相关推荐
zheshiyangyang36 分钟前
Vue+ElementPlus的一些问题修复汇总
前端·javascript·vue.js
武昌库里写JAVA1 小时前
《AI 大模型 ChatGPT 的传奇》
数据结构·vue.js·spring boot·算法·课程设计
猿大师播放器2 小时前
猿大师播放器:网页内嵌VLC/FFPlayer在Web端直接播放RTSP/RTMP/H.265视频流
vue.js·chrome·h.265·rtsp
猿大师播放器2 小时前
猿大师播放器:交通水利、公安消防Web端Vue网页播放20路RTSP H.265 1080P监控视频流
vue.js·chrome·音视频·web·h.265·rtsp
林涧泣2 小时前
【uniapp-Vue3】beforeRegister在注册用户入库前设置初始用户
前端·vue.js·uni-app
Sunshinedada3 小时前
微信小程序面试题
前端·javascript·vue.js
码农研究僧3 小时前
【Vue 3 | Uniapp】 从一个页面 (index) 传输数值到另一个页面 (form) 的方法详解(附Demo)
javascript·vue.js·uni-app
老友@4 小时前
Docker 部署 Jenkins持续集成(CI)工具
运维·ci/cd·docker·云原生·容器·jenkins·自动化部署
星之卡比*4 小时前
前端面试题---vue和react的区别
前端·vue.js·react.js
天天向上10245 小时前
vue 修改el-tree高亮样式
前端·javascript·vue.js