手动部署前后端分离的项目到本地

1.准备工作

使用maven打包springboot项目为.jar文件得到springboot-0.0.1-SNAPSHOT.jar
手动部署前后端分离的项目到本地

打包vue项目

npm install -g @vue/cli安装Vue CLI

在项目根目录下,运行npm run build命令来构建项目得到一个dist文件夹
手动部署前后端分离的项目到本地

将打包好的文件通过远程仓库中转至docker虚拟机

手动部署前后端分离的项目到本地

在虚拟机拉取镜像,并将docker12-2的内容复制(cp 命令)给我的部署项目my-project

手动部署前后端分离的项目到本地

2.部署前端到nginx docker中

将dist.zip解压放于my-project/frontend下,编写Dockerfile

```
FROM nginx:latest

COPY ./dist /usr/share/nginx/html

COPY ./nginx.conf /etc/nginx/conf.d/default.conf

EXPOSE 80
```

手动部署前后端分离的项目到本地

创建一个名为 nginx.conf 的配置文件

```
server {
    listen 80;

    server_name localhost;

    location / {
        root /usr/share/nginx/html;

        try_files $uri $uri/ /index.html;

    }

    # 代理 API 请求

location /api {
        proxy_pass http://192.168.88.3:8080;  # 替换为你的 API 服务器地址

        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;

    }

}
```

手动部署前后端分离的项目到本地

构建和运行 Docker 容器

```
docker build -t my-vite-app .(my-vite-app:自定义前端镜像名)
```

手动部署前后端分离的项目到本地

运行并查看镜像

docker run -d -p 8080:80 my-vite-app

手动部署前后端分离的项目到本地

在火狐浏览器中输入http://localhost:8080或http://192.168.88.3:8080跳至如下的登录界面
手动部署前后端分离的项目到本地

3.部署后端

将springboot-0.0.1-SNAPSHOT.jar放于my-project/backend下,编写Dockerfile

```
# 使用官方 OpenJDK 作为基础镜像

FROM openjdk:20-jdk-sli

# 设置工作目录

WORKDIR /app

# 复制项目的 JAR 文件到容器中

COPY ./springboot-0.0.1-SNAPSHOT.jar app.jar

# 暴露应用运行的端口

EXPOSE 8080

# 运行 Spring Boot 应用

ENTRYPOINT ["java", "-jar", "app.jar"]
```

手动部署前后端分离的项目到本地

构建

docker build -t my-springboot-app .
手动部署前后端分离的项目到本地

```
# 创建网络

docker network create my_network
```

注意:使用 Docker 网络连接

在 Docker 中运行多个容器时,建议使用 Docker 网络来确保它们可以相互通信。我已经创建了一个名为 my_network 的网络,确保我的 MySQL 、 my-springboot-app容器在同一个网络中运行,方便通信

运行

docker run -d -p 8090:8080 --network my_network my-springboot-app

手动部署前后端分离的项目到本地

4.部署mysql8

```
docker run --name mysql8 

-e MYSQL_ROOT_PASSWORD=mysql --network my_network 

-e MYSQL_ROOT_HOST='%' 

-p 3306:3306 

-v /root/xr/java/data:/var/lib/mysql 

-d mysql:8.0.40 

--character-set-server=utf8mb4 

--collation-server=utf8mb4_unicode_ci 

--default-authentication-plugin=mysql_native_password
```

手动部署前后端分离的项目到本地

查看构建容器成功
手动部署前后端分离的项目到本地

输入http://192.168.88.3:8090验证后端部署成功,因为还没创数据,所以显示数据为空
手动部署前后端分离的项目到本地

使用mysql容器创建对应数据库

进入mysql容器
docker exec -it mysql8 bash
手动部署前后端分离的项目到本地

登录MySQL

mysql -u root -p
手动部署前后端分离的项目到本地

创建数据库为docker_demo

创建表名为member

```
create database docker_demo;

use docker_demo;

-- 创建成员表
DROP TABLE IF EXISTS `member`;
CREATE TABLE member (
    id INT AUTO_INCREMENT PRIMARY KEY COMMENT '主键ID',
    studentId VARCHAR(50) UNIQUE NOT NULL COMMENT '学号',
   name VARCHAR(100) NOT NULL COMMENT '姓名',
   password VARCHAR(255) NOT NULL COMMENT '密码'
   ) COMMENT='成员信息表';
```

手动部署前后端分离的项目到本地

```
INSERT INTO member (studentId, name, password) VALUES ('11111111', '111', '123456');
```

5.遇到的问题

浏览器输入http://192.168.88.3:8090,结果为{"code":"200","msg":"请求成功","data":null}

问题分析:使用curl -X GET http://192.168.88.3:8090/member/selectAll验证,得到

{"code":"500","msg":"请求失败","data":null} 意思是服务器请求失败。我使用docker logs命令查看部署过程,发现MyBatis 在尝试执行数据库操作时遇到了异常,我看了后端代码和部署步骤,发现后端数据库连接用的是本地MySQL

手动部署前后端分离的项目到本地

,而我部署用的是MySQL容器(也就是说我的本地并没有MySQL),导致我的springboot找不到数据库,自然没有数据,请求也不会成功。

解决方案:更新springboot代码,重新打包,重复部署操作。

解决步骤:

1.更新数据库连接 URL

在您的 Spring Boot 应用中,您需要将数据库连接 URL 更新为 MySQL 容器的名称,而不是使用 localhost。在 Docker 中,容器的名称可以用作主机名。
手动部署前后端分离的项目到本地

2. 重新构建并运行后端应用

使用docker stop,docker rm ,docker rmi删除旧容器和旧镜像(内容太多,未截图)

重新构建运行

docker build -t my-springboot-app .
手动部署前后端分离的项目到本地

```
docker run -d -p 8090:8080 --network my_network my-springboot-app
浏览器输入http://192.168.88.3:8090/member/selectAll
```

手动部署前后端分离的项目到本地

表示后端与数据库部署成功

注意: 本身步骤是没有错的,如果结果不如意,可以检查ip地址,我这里用的地址基本都是本地主机,如果你需要改其他主机,请相应地修改;另外注意后端数据库的密码与前端是否匹

文章整理自互联网,只做测试使用。发布者:Lomu,转转请注明出处:https://www.it1024doc.com/6048.html

(0)
LomuLomu
上一篇 2025 年 1 月 12 日 下午5:19
下一篇 2025 年 1 月 12 日

相关推荐

  • 《动态演进架构(第二版)》电子版获取指南

    书籍概要 这本专业著作系统阐述了架构适应性评估体系、智能化架构管理方案以及数据动态演进的前沿方法与实践经验。全书采用三模块结构:首模块着重解析动态架构的核心机制——详细说明开发团队如何运用技术手段构建适应性评估模型、自动化部署流程等现代化软件项目管理工具;次模块聚焦架构模式与设计准则,深入探讨组件耦合度、功能复用性等关键要素,为构建可持续优化的系统架构提供专…

    2025 年 5 月 14 日
    14300
  • 【Java】面向对象编程基础:类与对象详解

    🌟个人主页:开发者_小杰 💖欢迎互动交流:点赞❤️评论💬收藏⭐ 📚专题推荐:Java核心技术精讲【开篇导言】作为Java语言的核心范式,面向对象编程(OOP)通过类和对象的概念构建程序结构。这些基础元素不仅是代码组织的单元,更是实现复杂系统模块化的关键。本文将系统解析类与对象的原理及应用,配合实例演示助您掌握这一编程范式。 内容导航: 一、OOP基础理念 1…

    2025 年 5 月 11 日
    16800
  • Java内存泄漏问题的高效排查与优化指南

    目录导航1. 系统化诊断与优化框架2. 内存快照获取技术2.1 自动生成堆转储文件2.2 手动创建堆转储文件3. 专业分析工具应用3.1 内存分析工具MAT3.2 性能分析工具JProfiler3.3 企业级专用工具4. 深度排查内存泄漏4.1 内存差异对比分析4.2 可疑泄漏对象检测4.3 内存占用大户识别4.4 不可达对象追踪5. 问题确认与验证6. 代…

    2025 年 5 月 13 日
    20900
  • Android Studio更改项目使用的JDK

    一、对配置流程的不满 在安卓开发领域,配置JDK和Gradle本应是一项简单的任务。通常情况下,开发者只需在Android Studio的File菜单下选择Project Structure,便能轻松完成设置,这一流程可谓便捷至极。 以下是原先修改JDK的界面: 然而,众所周知,Android Studio的性能问题一直为人所诟病,加之其对用户需求的忽视,使…

    2024 年 12 月 28 日
    77000
  • Java中的线程安全的集合类(如果想知道Java中有关线程安全的集合类的知识,那么只看这一篇就足够了!)

    前言:在多线程编程领域,确保集合类的线程安全性对于维护数据的一致性和防止并发问题至关重要。Java 提供了一系列线程安全的集合类,它们各自在不同的并发场景下展现出独特的优势和局限。 在深入探讨之前,让我们先概览本文将要覆盖的主要内容: 目录 1.线程安全的集合类概览 2.多线程环境下ArrayList的使用策略 (1)直接操作ArrayList (2)利用C…

    2024 年 12 月 28 日
    35000

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们

400-800-8888

在线咨询: QQ交谈

邮件:admin@example.com

工作时间:周一至周五,9:30-18:30,节假日休息

关注微信