当前位置: 首页 > article >正文

前端vue项目服务器部署(docker)

前端vue项目服务器部署(docker)

步骤 1: 导入 Nginx Docker 镜像

1、上传 Nginx Docker 镜像

将你的nginx-alpine.tar包上传到服务器上。假设路径为 /var/v3-admin-vite/nginx-alpine.tar

scp -r "C:\Users\86184\Desktop\v3-admin-vite" root@110.40.179.182:/var/
2、导入 Nginx Docker 镜像

使用以下命令将 .tar 文件加载为 Docker 镜像:

docker load -i /var/v3-admin-vite/nginx-alpine.tar

执行后会显示类似如下的输出,表示镜像已成功加载:

Loaded image: nginx:alpine
3、验证镜像是否加载

确认镜像已经导入成功:

docker images

应该可以看到 nginx:alpine 镜像在列表中。

步骤 2: 设置 Docker 项目

1、确保目录结构正确

在你的服务器上确保 /var/v3-admin-vite/ 目录下包含以下内容:

- dist/:Vue 项目构建后的静态文件。

- nginx.conf:自定义的 Nginx 配置文件。

- Dockerfile

确保 dist 目录中有你的 Vue 项目的打包内容。

2、编写 Dockerfile

/var/v3-admin-vite/ 下编写或确保已经有如下内容的 Dockerfile

# 使用导入的 nginx:alpine 镜像
FROM nginx:alpine

# 将自定义的 Nginx 配置文件复制到容器中
COPY ./nginx.conf /etc/nginx/nginx.conf

# 将 Vue 项目的构建文件复制到 Nginx 的静态资源目录中
COPY ./dist /usr/share/nginx/html

# 暴露 Nginx 的端口
EXPOSE 80

# 启动 Nginx
CMD ["nginx", "-g", "daemon off;"]
3、编写nginx.conf

由于我的Vue 项目构建后的静态文件/var/v3-admin-vite/dist的结构是:

-static

-app-loading

-cssfavicon.ico

-index.html

因此编写的nginx内容如下:

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  110.40.179.182;  # 部署服务器的 IP 地址

        root /usr/share/nginx/html;  # Nginx 的根目录

        index index.html;

        location / {
            try_files $uri $uri/ /index.html;
        }

        location /api/v1/ {
            proxy_pass http://122.228.26.226:36519/api/v1/; # 你的后端服务地址
            proxy_set_header Host $host;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
            proxy_set_header X-Forwarded-Proto $scheme;
        }

        location /static/ {
            alias /usr/share/nginx/html/static/;
            expires 1y;
            add_header Cache-Control "public, max-age=31536000, immutable";
        }

        location /favicon.ico {
            try_files $uri =404;
        }

        location /app-loading.css {
            try_files $uri =404;
        }

        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   /usr/share/nginx/html;
        }
    }
}

步骤 3: 构建和运行 Docker 容器

1、构建 Docker 镜像

使用以下命令构建 Docker 镜像:

cd /var/v3-admin-vite
docker build -t my-vue-app .

这将使用 Dockerfile 来构建名为 my-vue-app 的 Docker 镜像。

2、运行 Docker 容器

构建完成后,运行容器:

docker run -d -p 80:80 --name my-vue-app-container my-vue-app

- -d:后台运行容器。

- -p 80:80:将容器的 80 端口映射到服务器的 80 端口。

- --name my-vue-app-container:将容器命名为 my-vue-app-container

步骤 4: 访问应用

部署完成后,可以通过访问服务器的 IP 地址在浏览器中查看应用。

http://<服务器IP>

此时,如果没有错误,应该能看到你的 Vue 项目正常运行。

指令总结:

在服务器上执行以下指令即可部署完成:

docker load -i /var/v3-admin-vite/nginx-alpine.tar
cd /var/v3-admin-vite
docker build -t my-vue-app .
docker run -d -p 80:80 --name my-vue-app-container my-vue-app

常见问题排查

1、504 Gateway Timeout

如果你依然遇到 504 Gateway Timeout 问题,可能是后端接口无法响应,建议检查:

- 后端服务是否正常运行。

- Nginx 的代理配置是否正确,尤其是代理地址和端口。

2、修改 Nginx 配置后重启

如果你对 nginx.conf 进行了修改,可以通过以下命令重启容器:

docker restart my-vue-app-container

或者停止并重新运行容器:

docker stop my-vue-app-container
docker rm my-vue-app-container
docker run -d -p 80:80 --name my-vue-app-container my-vue-app

http://www.kler.cn/a/303043.html

相关文章:

  • 51.WPF应用加图标指南 C#例子 WPF例子
  • YoloV10改进策略:Neck层改进|EFC,北理提出的适用小目标的特征融合模块|即插即用
  • 光伏储能电解水制氢仿真模型Matlab/Simulink
  • 【AI学习】地平线首席架构师苏箐关于自动驾驶的演讲
  • Pandas库的常用内容归纳
  • sparkSQL练习
  • [linux 驱动]platform总线设备驱动详解与实战
  • WEB渗透Linux提权篇-MYSQL漏洞提权
  • Spring Boot实现大文件分块上传
  • woocommerce 调用当前product_tag 为标题
  • swoole协程 是单线程的,还是多线程的
  • 数学建模笔记—— 整数规划和0-1规划
  • 跟我一起写 SIPp XML scenario file 之二
  • LeetCode 每日一题 2024/9/2-2024/9/8
  • OpenAI gym: Trouble installing Atari dependency (Mac OS X)
  • CVE-2024-38063 ipv6远程蓝屏
  • 基于SpringBoot+Vue+MySQL的招聘管理系统
  • 【课程系列12】某客时间AI大模型微调训练营
  • C#中的可空类型和空合并运算符
  • Perfetto 如何查看主线程哪些操作最耗时
  • P1332 血色先锋队
  • 为什么在EffectiveJava中建议用EnumSet替代位字段,以及使用EnumMap替换序数索引
  • layui复选框删除
  • 计算机毕业设计选题推荐-流浪动物领养管理系统-Java/Python项目实战(亮点:数据可视化分析、智能推荐)
  • 开发模式和环境搭建
  • Android 开发避坑经验第三篇:RecyclerView 高效使用与常见问题解决