
作为一名 Java 开发者,你是否受够了 Spring Boot 在容器化过程中繁琐的配置和层出不穷的“坑”?想尝试更轻量、更高性能的替代方案吗?那不妨了解一下 Solon 框架。本文将手把手带你完成 Solon 与 Docker 的集成部署,从环境搭建到上线运行,全程避坑,确保你能在 30 分钟内顺利完成容器化转型!
在微服务与云原生大行其道的今天,应用容器化已成为开发标配。然而,Spring Boot 虽功能全面,却存在启动慢、内存占用高、镜像臃肿等问题。据一位资深开发者反馈,他们团队常维护超过 1GB 的 Spring Boot 打包文件。
5~10 倍1/10~1/2,基础镜像更小开始前,请确认本地开发环境满足以下条件:
快速检测命令如下:
java -versiondocker -vmvn -v
若尚未有项目,可通过官方在线生成器一键创建:
https://solon.noear.org/start/
在 pom.xml 中引入经过广泛验证的 spotify/docker-maven-plugin 插件:
<plugin>
    <groupId>com.spotify</groupId>
    <artifactId>docker-maven-plugin</artifactId>
    <version>1.2.2</version>
    <configuration>
        <!-- 镜像名称 -->
        <imageName>solon-demo</imageName>
        <!-- 多标签支持 -->
        <imageTags>
            <imageTag>${project.version}</imageTag>
            <imageTag>latest</imageTag>
        </imageTags>
        <!-- 使用轻量级基础镜像 -->
        <baseImage>adoptopenjdk/openjdk11:jre-11.0.11_9-alpine</baseImage>
        <!-- 容器启动命令 -->
        <entryPoint>["java", "-jar", "/${project.build.finalName}.jar", "--server.port=8080", "--drift=1"]</entryPoint>
        <!-- 复制 jar 包至镜像 -->
        <resources>
            <resource>
                <targetPath>/</targetPath>
                <directory>${project.build.directory}</directory>
                <include>${project.build.finalName}.jar</include>
            </resource>
        </resources>
    </configuration>
</plugin>⚠️ 注意事项:
entryPoint 必须为 JSON 数组格式,避免参数解析错误finalName 与实际打包的 JAR 名称一致--drift=1 表示当前环境 IP 可能动态变化,适用于注册中心场景,下线时不进行健康检查,是 Solon 对云原生的优化策略若偏好传统方式,可在项目根目录创建 Dockerfile:
# 使用轻量级 OpenJDK JRE 镜像
FROM adoptopenjdk/openjdk11:jre-11.0.11_9-alpine
<h1>设置工作目录</h1><p>WORKDIR /app</p><h1>复制打包后的 jar 文件</h1><p>COPY target/solon-demo-1.0.0.jar app.jar</p><h1>暴露服务端口</h1><p>EXPOSE 8080</p>
                    <div class="aritcle_card">
                        <a class="aritcle_card_img" href="/ai/%E9%9B%86%E7%AE%80%E4%BA%91">
                            <img src="https://img.php.cn/upload/ai_manual/000/969/633/68b6dac7dd9e4837.png" alt="集简云">
                        </a>
                        <div class="aritcle_card_info">
                            <a href="/ai/%E9%9B%86%E7%AE%80%E4%BA%91">集简云</a>
                            <p>软件集成平台,快速建立企业自动化与智能化</p>
                            <div class="">
                                <img src="/static/images/card_xiazai.png" alt="集简云">
                                <span>22</span>
                            </div>
                        </div>
                        <a href="/ai/%E9%9B%86%E7%AE%80%E4%BA%91" class="aritcle_card_btn">
                            <span>查看详情</span>
                            <img src="/static/images/cardxiayige-3.png" alt="集简云">
                        </a>
                    </div>
                <h1>容器启动命令</h1><p>ENTRYPOINT ["java", "-jar", "app.jar", "--server.port=8080", "--drift=1"]随后在 pom.xml 中配置插件引用该 Dockerfile:
<plugin>
<groupId>com.spotify</groupId>
<artifactId>docker-maven-plugin</artifactId>
<version>1.2.2</version>
<configuration>
<imageName>solon-demo</imageName>
<!-- 指定 Dockerfile 路径 -->
<dockerDirectory>${project.basedir}</dockerDirectory>
<resources>
<resource>
<targetPath>/</targetPath>
<directory>${project.build.directory}</directory>
<include>${project.build.finalName}.jar</include>
</resource>
</resources>
</configuration>
</plugin>执行以下命令完成构建:
# 先打包项目 mvn clean package</p><h1>构建 Docker 镜像</h1><p>mvn docker:build
构建完成后查看镜像:
docker images | grep solon-demo
启动容器:
# 启动容器并映射端口 docker run -d -p 8080:8080 --name solon-app solon-demo</p><h1>查看运行状态</h1><p>docker ps | grep solon-app</p><h1>查看日志输出</h1><p>docker logs solon-app
常用容器管理命令:
# 停止容器 docker stop solon-app</p><h1>重启容器</h1><p>docker restart solon-app</p><h1>删除容器</h1><p>docker rm solon-app
为便于管理,建议打上版本标签并推送到私有或公共仓库:
# 打标签 docker tag solon-demo:latest your-repo/solon-demo:1.0.0 docker tag solon-demo:latest your-repo/solon-demo:latest</p><h1>推送至远程仓库</h1><p>docker push your-repo/solon-demo:1.0.0 docker push your-repo/solon-demo:latest
部署生产环境时,应限制资源并添加健康监控:
docker run -d \ -p 8080:8080 \ --name solon-app \ --memory=512m \ --cpus=1.0 \ solon-demo
docker logs solon-app
docker ps 检查端口映射是否正确0.0.0.0,而非 127.0.0.1
Solon 框架结合 Docker,实现了极简高效的容器化体验,主要体现在:
通过本文的实战步骤,你已具备将 Solon 项目快速 Docker 化的能力。现在就动手试试吧!遇到问题欢迎留言交流。
源码地址:点击下载
以上就是Solon (可替换 SpringBoot)集成 Docker 实战:30分钟搞定容器化部署的详细内容,更多请关注php中文网其它相关文章!
 
                        
                        每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
 
                Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号