0

0

Solon (可替换 SpringBoot)集成 Docker 实战:30分钟搞定容器化部署

霞舞

霞舞

发布时间:2025-10-29 12:53:01

|

363人浏览过

|

来源于php中文网

原创

solon (可替换 springboot)集成 docker 实战:30分钟搞定容器化部署

作为一名 Java 开发者,你是否受够了 Spring Boot 在容器化过程中繁琐的配置和层出不穷的“坑”?想尝试更轻量、更高性能的替代方案吗?那不妨了解一下 Solon 框架。本文将手把手带你完成 Solon 与 Docker 的集成部署,从环境搭建到上线运行,全程避坑,确保你能在 30 分钟内顺利完成容器化转型!

为何选择 Solon + Docker?

在微服务与云原生大行其道的今天,应用容器化已成为开发标配。然而,Spring Boot 虽功能全面,却存在启动慢、内存占用高、镜像臃肿等问题。据一位资深开发者反馈,他们团队常维护超过 1GB 的 Spring Boot 打包文件。

Solon 的核心优势:

  • 极速启动:相比 Spring Boot,Solon 启动速度提升 5~10
  • 低资源消耗:运行时内存仅为 Spring Boot 的 1/10~1/2,基础镜像更小
  • 配置简洁高效:Docker 集成无需复杂脚本,上手即用
  • 天生云原生:框架设计之初就深度适配容器与分布式场景

环境准备:三步快速起步

开始前,请确认本地开发环境满足以下条件:

1. 版本要求一览

  • JDK:支持 JDK 8 及以上,推荐使用 JDK 11 或 JDK 17,更适合容器运行
  • Docker:建议版本 20.10+,推荐安装 Docker Desktop 4.0+
  • Maven:需 3.6+,保障插件兼容性

快速检测命令如下:

java -versiondocker -vmvn -v

2. 创建 Solon 工程

若尚未有项目,可通过官方在线生成器一键创建:

https://solon.noear.org/start/

实战环节:Docker 集成全流程

1. 添加 Maven 插件配置

pom.xml 中引入经过广泛验证的 spotify/docker-maven-plugin 插件:


    com.spotify
    docker-maven-plugin
    1.2.2
    
        
        solon-demo
        
        
            ${project.version}
            latest
        
        
        adoptopenjdk/openjdk11:jre-11.0.11_9-alpine
        
        ["java", "-jar", "/${project.build.finalName}.jar", "--server.port=8080", "--drift=1"]
        
        
            
                /
                ${project.build.directory}
                ${project.build.finalName}.jar
            
        
    

⚠️ 注意事项:

  • 推荐使用 Alpine 版 JDK 镜像以压缩镜像体积(如遇兼容问题可换为标准版)
  • entryPoint 必须为 JSON 数组格式,避免参数解析错误
  • 确保 finalName 与实际打包的 JAR 名称一致
  • --drift=1 表示当前环境 IP 可能动态变化,适用于注册中心场景,下线时不进行健康检查,是 Solon 对云原生的优化策略

2. 替代方案:使用 Dockerfile

若偏好传统方式,可在项目根目录创建 Dockerfile

# 使用轻量级 OpenJDK JRE 镜像
FROM adoptopenjdk/openjdk11:jre-11.0.11_9-alpine

设置工作目录

WORKDIR /app

复制打包后的 jar 文件

COPY target/solon-demo-1.0.0.jar app.jar

暴露服务端口

EXPOSE 8080

与光AI
与光AI

一站式AI视频工作流创作平台

下载

容器启动命令

ENTRYPOINT ["java", "-jar", "app.jar", "--server.port=8080", "--drift=1"]

随后在 pom.xml 中配置插件引用该 Dockerfile:


com.spotify
docker-maven-plugin
1.2.2

solon-demo

${project.basedir}


/
${project.build.directory}
${project.build.finalName}.jar



3. 构建并运行容器

执行以下命令完成构建:

# 先打包项目
mvn clean package

构建 Docker 镜像

mvn docker:build

构建完成后查看镜像:

docker images | grep solon-demo

启动容器:

# 启动容器并映射端口
docker run -d -p 8080:8080 --name solon-app solon-demo

查看运行状态

docker ps | grep solon-app

查看日志输出

docker logs solon-app

常用容器管理命令:

# 停止容器
docker stop solon-app

重启容器

docker restart solon-app

删除容器

docker rm solon-app

进阶操作:生产级优化与部署

1. 镜像标签与推送

为便于管理,建议打上版本标签并推送到私有或公共仓库:

# 打标签
docker tag solon-demo:latest your-repo/solon-demo:1.0.0
docker tag solon-demo:latest your-repo/solon-demo:latest

推送至远程仓库

docker push your-repo/solon-demo:1.0.0 docker push your-repo/solon-demo:latest

2. 生产环境建议配置

部署生产环境时,应限制资源并添加健康监控:

docker run -d \
-p 8080:8080 \
--name solon-app \
--memory=512m \
--cpus=1.0 \
solon-demo

常见问题与解决方案

1. 容器启动后立即退出

  • 查看日志:docker logs solon-app
  • 确认 JAR 路径是否正确
  • 检查端口是否冲突或被占用

2. 服务无法访问

  • 使用 docker ps 检查端口映射是否正确
  • 确认防火墙或安全组规则
  • 查看应用是否监听 0.0.0.0,而非 127.0.0.1

3. 镜像体积过大

  • 使用 JRE 镜像替代完整 JDK
  • 采用 Alpine 系统基础镜像
  • 考虑多阶段构建,剔除编译依赖

总结

Solon 框架结合 Docker,实现了极简高效的容器化体验,主要体现在:

  • 配置清晰:Maven 插件开箱即用,减少人为错误
  • 镜像精简:最小可控制在 100MB 以内
  • 启动飞快:秒级启动,适合弹性扩缩容场景

通过本文的实战步骤,你已具备将 Solon 项目快速 Docker 化的能力。现在就动手试试吧!遇到问题欢迎留言交流。

源码地址:点击下载

相关专题

更多
java
java

Java是一个通用术语,用于表示Java软件及其组件,包括“Java运行时环境 (JRE)”、“Java虚拟机 (JVM)”以及“插件”。php中文网还为大家带了Java相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

834

2023.06.15

java正则表达式语法
java正则表达式语法

java正则表达式语法是一种模式匹配工具,它非常有用,可以在处理文本和字符串时快速地查找、替换、验证和提取特定的模式和数据。本专题提供java正则表达式语法的相关文章、下载和专题,供大家免费下载体验。

739

2023.07.05

java自学难吗
java自学难吗

Java自学并不难。Java语言相对于其他一些编程语言而言,有着较为简洁和易读的语法,本专题为大家提供java自学难吗相关的文章,大家可以免费体验。

735

2023.07.31

java配置jdk环境变量
java配置jdk环境变量

Java是一种广泛使用的高级编程语言,用于开发各种类型的应用程序。为了能够在计算机上正确运行和编译Java代码,需要正确配置Java Development Kit(JDK)环境变量。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

397

2023.08.01

java保留两位小数
java保留两位小数

Java是一种广泛应用于编程领域的高级编程语言。在Java中,保留两位小数是指在进行数值计算或输出时,限制小数部分只有两位有效数字,并将多余的位数进行四舍五入或截取。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

399

2023.08.02

java基本数据类型
java基本数据类型

java基本数据类型有:1、byte;2、short;3、int;4、long;5、float;6、double;7、char;8、boolean。本专题为大家提供java基本数据类型的相关的文章、下载、课程内容,供大家免费下载体验。

446

2023.08.02

java有什么用
java有什么用

java可以开发应用程序、移动应用、Web应用、企业级应用、嵌入式系统等方面。本专题为大家提供java有什么用的相关的文章、下载、课程内容,供大家免费下载体验。

430

2023.08.02

java在线网站
java在线网站

Java在线网站是指提供Java编程学习、实践和交流平台的网络服务。近年来,随着Java语言在软件开发领域的广泛应用,越来越多的人对Java编程感兴趣,并希望能够通过在线网站来学习和提高自己的Java编程技能。php中文网给大家带来了相关的视频、教程以及文章,欢迎大家前来学习阅读和下载。

16926

2023.08.03

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

41

2026.01.16

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 2.6万人学习

C# 教程
C# 教程

共94课时 | 6.9万人学习

Java 教程
Java 教程

共578课时 | 47万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号