SpringBoot 应用入门与 Docker 化部署实战

SpringBoot 应用入门与 Docker 化部署实战

本文是《Java SpringBoot 多人协作平台》系列课程第二节的学习笔记整理,介绍如何使用 SpringBoot 构建一个基础的登录接口,并通过 Docker 将应用容器化部署。


一、SpringBoot 快速构建 REST 接口

1.1 什么是 SpringBoot?

Spring Boot 是基于 Spring 框架的快速开发脚手架,通过约定优于配置的理念,极大简化了 Spring 应用的初始搭建和开发流程。开发者无需繁琐的 XML 配置,即可快速启动一个生产级别的 Web 应用。

1.2 编写一个 Login 接口

下面以一个最简单的用户登录接口为例,演示 SpringBoot 如何处理 HTTP POST 请求。

接口说明
属性
请求方式 POST
接口路径 /login
请求参数 usernamepassword
返回值 String
代码实现
less 复制代码
@RequestMapping(value = "/login", method = RequestMethod.POST)
public String login(@RequestParam("username") String username,
                    @RequestParam("password") String password) {
    System.out.println("username: " + username + " password: " + password);
    return "";
}
关键注解说明
  • @RequestMapping:用于映射 HTTP 请求路径与方法。value 指定路由路径,method 指定请求方式(此处为 POST)。
  • @RequestParam:用于绑定 HTTP 请求中的表单参数或 Query 参数到方法入参。usernamepassword 会从请求体(application/x-www-form-urlencoded)或 URL 参数中自动提取。
测试接口

可以使用 curl 或 Postman 对接口进行测试:

bash 复制代码
curl -X POST http://localhost:8080/login \
  -d "username=admin&password=123456"

控制台将输出:

makefile 复制代码
username: admin password: 123456

注意:实际生产环境中,密码不应以明文传输,应使用 HTTPS 加密,并对密码进行哈希(如 BCrypt)处理后再做比对。


二、Docker 容器化部署 SpringBoot 应用

将 SpringBoot 应用打包进 Docker 镜像,可以实现环境一致性,避免"本地能跑、线上报错"的经典问题,也是现代多人协作项目中的标准化部署方式。

2.1 前置准备

在构建 Docker 镜像之前,需要先将 SpringBoot 项目打包为可执行 JAR 文件:

go 复制代码
mvn clean package -DskipTests

打包成功后,JAR 文件默认生成于 target/ 目录下,例如:

bash 复制代码
target/gs-spring-boot-0.1.0.jar

2.2 编写 Dockerfile

在项目根目录下创建 Dockerfile 文件:

bash 复制代码
# 使用带有 JDK 8 的轻量级 Alpine 基础镜像
FROM java:8u111-jdk-alpine

# 设置容器内的工作目录
WORKDIR /app

# 将打包好的 JAR 文件复制到容器的工作目录中
COPY target/gs-spring-boot-0.1.0.jar .

# 声明容器对外暴露的端口
EXPOSE 8080

# 容器启动时执行的命令
CMD ["java", "-jar", "gs-spring-boot-0.1.0.jar"]
Dockerfile 指令说明
指令 作用
FROM 指定基础镜像。java:8u111-jdk-alpine 是基于 Alpine Linux 的 JDK 8 镜像,体积小巧。
WORKDIR 设置后续指令的工作目录,若目录不存在会自动创建。
COPY 将宿主机文件复制到镜像内指定路径。
EXPOSE 声明容器运行时监听的端口(仅为文档说明,不自动映射端口)。
CMD 指定容器启动后执行的默认命令,这里启动 SpringBoot 应用。

2.3 构建 Docker 镜像

在项目根目录下(即 Dockerfile 所在目录),执行以下命令构建镜像:

复制代码
docker build . -t demo-app
  • .:指定构建上下文为当前目录。
  • -t demo-app:为镜像打上标签,命名为 demo-app

构建成功后,可通过以下命令验证镜像是否存在:

perl 复制代码
docker images | grep demo-app

2.4 运行 Docker 容器

arduino 复制代码
docker run -p 80:8080 -it demo-app
参数说明
参数 说明
-p 80:8080 端口映射,将宿主机的 80 端口映射到容器的 8080 端口。访问 http://localhost/login 即可触达应用。
-it 以交互模式运行容器,并分配伪终端,方便查看控制台日志输出。
demo-app 指定要运行的镜像名称。

启动成功后,通过浏览器或 curl 访问:

arduino 复制代码
curl -X POST http://localhost/login \
  -d "username=admin&password=123456"

2.5 完整部署流程总结

perl 复制代码
① mvn clean package          # 打包 SpringBoot 应用为 JAR
      ↓
② 编写 Dockerfile             # 定义镜像构建规则
      ↓
③ docker build . -t demo-app  # 构建镜像
      ↓
④ docker run -p 80:8080 -it demo-app  # 启动容器
      ↓
⑤ 访问 http://localhost/login  # 验证服务

三、小结

本节课通过一个简单的登录接口,完整演示了从 SpringBoot 接口开发Docker 容器化部署 的全流程:

  1. 使用 @RequestMapping + @RequestParam 快速定义 POST 接口,接收前端传参。
  2. 编写 Dockerfile,基于轻量 Alpine 镜像封装应用。
  3. 通过 docker build 构建镜像,docker run 启动服务,完成本地容器化部署。

掌握这一基础流程,是后续进行多人协作平台开发、CI/CD 流水线集成的重要基础。


系列课程:Java SpringBoot 多人协作平台实战 · 第二节

相关推荐
mldlds2 小时前
Spring Boot 集成 MyBatis 全面讲解
spring boot·后端·mybatis
阿祖zu2 小时前
OpenClaw 入门到放弃:私人 AI 的初代原型机
前端·后端·aigc
jieyucx2 小时前
Go 语言运算符与控制台输入输出详解
开发语言·后端·golang
代码N年归来仍是新手村成员3 小时前
OTel - DataDog Observability踩坑
后端·python
pupudawang3 小时前
Spring Boot 热部署
java·spring boot·后端
下地种菜小叶3 小时前
Spring Boot 2.x 升级 3.x / 4.x 怎么做?一次讲清 JDK、Jakarta、依赖兼容与上线策略
java·spring boot·后端
代码羊羊3 小时前
Rust方法速览:从self到impl
开发语言·后端·rust
子兮曰3 小时前
独立开发者主流技术栈(2026最新)
前端·后端·全栈
神奇小汤圆4 小时前
面试官:响应式编程和虚拟线程怎么选?看完这篇不再被问倒
后端