用docker compose部署vue+springboot最简单教程

1.首先需要安装docker和docker compose

2.把需要的文件放在linux服务器中,可以用termius软件连接服务器,有界面可以传输文件进服务器

一、部署web前端

在linux服务器中放置文件目录/home/ubuntu/teachweb

teachweb里面存放的文件有compose.yaml,default.conf ,dist文件夹, Dockerfile

dist文件夹是vue或者其他前端打包后的文件夹,详情可以看下面blog,打包生成dist文件
手摸手教你用Docker部署web前端vue项目_docker部署vue的前端项目-CSDN博客

default.conf的内容

复制代码
server {
    listen       80;
    server_name  localhost; # 修改为docker服务宿主机的ip
 
    location / {
        root   /usr/share/nginx/html;
        index  index.html index.htm;
        try_files $uri $uri/ /index.html =404;
    }
 
    error_page   500 502 503 504  /50x.html;
    location = /50x.html {
        root   html;
    }
}

Dockerfile的内容

复制代码
FROM nginx
 
MAINTAINER onesummer
 
RUN rm /etc/nginx/conf.d/default.conf
 
ADD default.conf /etc/nginx/conf.d/
 
COPY dist/ /usr/share/nginx/html/

compose.yaml内容

复制代码
services:
  teachweb_first:
    build:
      context: .
      dockerfile: Dockerfile
    container_name: teachImages_first
    restart: always
    ports:
      - "88:80"
    volumes:
      - ./dist:/usr/share/nginx/html
      - ./default.conf:/etc/nginx/conf.d/default.conf

在相同目录下运行命令,就可以成功生成容器,前端运行成功

复制代码
docker compose up -d

在浏览器输入IP+端口号就能看到网页内容了

docker compose down是删除容器的命令.

当需要更新网页的时候,把本地打包好的dist替换服务器中的dist,先运行docker compose down删除容器,再docker compose up新建一个容器。

二、部署springboot后端

在linux服务器中放置文件目录/home/ubuntu/AI_Platform_Back

AI_Platform_Back里面存放的文件有compose.yaml,jar包, Dockerfile

jar包是springboot后端打包后的文件夹,详情可以看下面blog,打包生成jar

手摸手教你使用Docker部署Springboot项目(详细版)_springboot dockerfile 端口映射-CSDN博客

Dockerfile的内容

复制代码
FROM maven:3.8.1-jdk-8-slim as builder

ADD ./***(jar包名字).jar app.jar

EXPOSE 8101

CMD java -jar app.jar

compose.yaml内容

复制代码
services:
  app:
    build:
      context: .
      dockerfile: Dockerfile
    container_name: ai_platform_back
    ports:
      - "89:89"
    restart: always

在相同目录下运行命令,就可以成功生成容器,后端运行成功

复制代码
docker compose up -d
相关推荐
—Qeyser16 分钟前
用 Deepseek 写的uniapp油耗计算器
前端·vue.js·gpt·chatgpt·uni-app·gpt-3·deepseek
拖孩18 分钟前
【Nova UI】九、打造组件库第一个组件-图标组件(中):属性、功能与样式的完美融合
前端·javascript·vue.js
bing_1581 小时前
在 Spring Boot 项目中,如何进行高效的数据库 Schema 设计?
数据库·spring boot·后端·数据库schema设计
❀͜͡傀儡师1 小时前
Docker部署禅道21.6开源版本
运维·docker·容器
luckilyil2 小时前
springboot自定义starter(避坑教学)
java·spring boot·spring
卷不动的打工仔2 小时前
Ubuntu利用docker搭建Java相关环境记录(二)
java·ubuntu·docker
wqq10272 小时前
docker Windows 存放位置
运维·docker·容器
谁点的猪脚饭2 小时前
vue2 element-ui 中 el-radio 单选框点击事件失效问题
vue.js·elementui·vue2
kfepiza2 小时前
HttpSessionAttributeListener 的用法笔记250417
java·spring boot·笔记·servlet·java-ee·tomcat
苹果酱05673 小时前
redis系列--1.redis是什么
java·vue.js·spring boot·mysql·课程设计