- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用 Spring Boot 2.3.0.M1 引入的 Spring buildpacks用于创建基于 Spring 的应用程序的 Docker 镜像。一切顺利,我可以通过执行 ./gradlew bootBuildImage
为每个应用程序创建 docker 镜像Gradle 任务,将 docker-compose 文件指向创建的图像(例如 image: spring-test:latest
),最后成功运行所有应用程序( docker-compose up
)。
即使我有一个 bash 脚本来自动化构建过程,我还是想摆脱这个额外的步骤,让 Spring buildpacks 任务在我运行时自动执行 docker-compose up --build
命令,因此每个应用程序的 docker 镜像将被构建并上传到主机的本地 docker 存储库,从那里它将被 docker compose 接管。
我的第一次尝试是为每个执行 bootBuildImage
的应用程序创建一个虚拟 Dockerfile。主机上的任务,但这需要从 docker 到主机的 SSH 连接,甚至不确定是否可以正常工作。
另一个想法是使用类似的方法,唯一的变化是首先将应用程序的源代码挂载或复制到 docker,配置 buildpacks 以将图像存储到主机的本地 docker image repo(可能是 SSH 连接),最后在 docker 上执行 buildpacks。
我想知道是否没有更好,更优雅的解决方案。
最佳答案
这个问题真的把我逼疯了,因为 I've been playing around with Spring Boot & Paketo Buildpacks for quite a while now - 和 我真的很喜欢 Docker-Compose 的简单性 .所以问题已经在我的脑海里了,但后来你问了:)
我没有找到 100% 完美的解决方案,但我认为有一些想法。让我们假设一个由多个 Spring Boot 应用程序组成的示例项目,这些应用程序由 Maven 多模块设置组成(我知道您正在使用 Gradle,但是在出色的 spring.io 指南中有 a guide on doing multi module setups with Gradle):
github.com/jonashackt/cxf-spring-cloud-netflix-docker .我创建了一个新分支 buildpacks-paketo
包含我们需要的所有内容 - 并删除了所有 Dockerfiles
来自各自的 Spring Boot 应用程序。因为我们不再需要它们了,使用 Cloud Native Buildpacks (这是他们的设计目标)。
TLDR:我的想法是使用 spring-boot-maven-plugin
(或等效的 Gradle)在每个“正常 docker-compose up
之前发布一个新的 Paketo 构建,如下所示:
mvn clean spring-boot:build-image && docker-compose up
The example projects parent pom.xml
看起来像这样(缩短):
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>de.jonashackt</groupId>
<artifactId>cxf-spring-cloud-netflix-docker-build-all</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>pom</packaging>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.4.1</version>
</parent>
<modules>
<module>eureka-serviceregistry</module>
<module>spring-boot-admin</module>
<module>zuul-edgeservice</module>
<module>weatherbackend</module>
<module>weatherservice</module>
<module>weatherclient</module>
</modules>
</project>
example projects docker-compose.yml
看起来很简单,并使用 Paketo 生成的容器镜像(由 Maven 插件触发)——它们的命名如下:
eureka-serviceregistry:0.0.1-SNAPSHOT
.这是完整的
docker-compose.yml
对于所有 Spring Boot 服务:
version: '3.3'
services:
eureka-serviceregistry:
image: eureka-serviceregistry:0.0.1-SNAPSHOT
ports:
- "8761:8761"
tty:
true
restart:
unless-stopped
spring-boot-admin:
image: spring-boot-admin:0.0.1-SNAPSHOT
ports:
- "8092:8092"
environment:
- REGISTRY_HOST=eureka-serviceregistry
tty:
true
restart:
unless-stopped
# no portbinding here - the actual services should be accessible through Zuul proxy
weatherbackend:
image: weatherbackend:0.0.1-SNAPSHOT
ports:
- "8090"
environment:
- REGISTRY_HOST=eureka-serviceregistry
tty:
true
restart:
unless-stopped
# no portbinding here - the actual services should be accessible through Zuul proxy
weatherservice:
image: weatherservice:0.0.1-SNAPSHOT
ports:
- "8095"
environment:
- REGISTRY_HOST=eureka-serviceregistry
tty:
true
restart:
unless-stopped
zuul-edgeservice:
image: zuul-edgeservice:0.0.1-SNAPSHOT
ports:
- "8080:8080"
environment:
- REGISTRY_HOST=eureka-serviceregistry
tty:
true
restart:
unless-stopped
===
可能的改进 ======================
docker-compose.yml
上,并且只使用你要求的
docker-compose up
- 没有额外的命令。因此我创建了另一个“Docker Compose 构建服务”,它应该只构建这样的服务镜像:
version: '3.3'
services:
paketo-build:
image: maven:3.6-openjdk-15
command: "mvn clean spring-boot:build-image -B -DskipTests --no-transfer-progress" # build all apps
volumes:
- "/var/run/docker.sock:/var/run/docker.sock:ro" # Mount Docker from host into build container for Paketo to work
- "$HOME/.m2:/root/.m2" # Mount your local Maven repository into build container to prevent repeated downloads
- "$PWD:/workspace" # Mount all Spring Boot apps into the build container
working_dir: "/workspace"
我首先在
docker-compose.yml
中集成了这项服务我已经有了。运行
docker-compose up paketo-build
做了我想要的:在 Compose 设置中构建我们所有的 Spring Boot 应用程序:
...
paketo-build_1 | [INFO] --- spring-boot-maven-plugin:2.4.1:build-image (default-cli) @ eureka-serviceregistry ---
paketo-build_1 | [INFO] Building image 'docker.io/library/eureka-serviceregistry:0.0.1-SNAPSHOT'
paketo-build_1 | [INFO]
paketo-build_1 | [INFO] > Pulling builder image 'docker.io/paketobuildpacks/builder:base' 100%
paketo-build_1 | [INFO] > Pulled builder image 'paketobuildpacks/builder@sha256:3cff90d13d353ffdb83acb42540dae4ce6c97d55c07fb01c39fe0922177915fa'
paketo-build_1 | [INFO] > Pulling run image 'docker.io/paketobuildpacks/run:base-cnb' 100%
paketo-build_1 | [INFO] > Pulled run image 'paketobuildpacks/run@sha256:f393fa2927a2619a10fc09bb109f822d20df909c10fed4ce3c36fad313ea18e3'
paketo-build_1 | [INFO] > Executing lifecycle version v0.10.1
paketo-build_1 | [INFO] > Using build cache volume 'pack-cache-9d8694845b92.build'
paketo-build_1 | [INFO]
paketo-build_1 | [INFO] > Running creator
paketo-build_1 | [INFO] [creator] ===> DETECTING
...
paketo-build_1 | [INFO] [creator]
paketo-build_1 | [INFO] [creator] Paketo Spring Boot Buildpack 3.5.0
paketo-build_1 | [INFO] [creator] https://github.com/paketo-buildpacks/spring-boot
paketo-build_1 | [INFO] [creator] Creating slices from layers index
...
paketo-build_1 | [INFO] [creator] Adding label 'io.buildpacks.project.metadata'
paketo-build_1 | [INFO] [creator] Adding label 'org.opencontainers.image.title'
paketo-build_1 | [INFO] [creator] Adding label 'org.opencontainers.image.version'
paketo-build_1 | [INFO] [creator] Adding label 'org.springframework.boot.spring-configuration-metadata.json'
paketo-build_1 | [INFO] [creator] Adding label 'org.springframework.boot.version'
paketo-build_1 | [INFO] [creator] Setting default process type 'web'
paketo-build_1 | [INFO] [creator] *** Images (7efae8be1167):
paketo-build_1 | [INFO] [creator] docker.io/library/eureka-serviceregistry:0.0.1-SNAPSHOT
paketo-build_1 | [INFO]
paketo-build_1 | [INFO] Successfully built image 'docker.io/library/eureka-serviceregistry:0.0.1-SNAPSHOT'
...
但这感觉不太对劲,原因有很多。一个是你
需要以某种方式等待所有其他 Compose 服务的启动,直到 paketo-build
服务做到了并构建所有图像。
BUT as the Docker docs tell us ,我们将需要反对 Compose 中做出的设计决策才能实现这一目标!还有
did I find this great answer , Max 解释说
“污染”“生产”不是一个好的设计docker-compose.yml
使用仅用于构建的容器。
paketo-build
服务到它自己的 Compose 文件中 - 称为
build.yml
inside the example project .有了它,我们现在能够运行 Paketo 构建,而无需依赖主机安装 Maven - 并且仅使用 Docker-Compose:
docker-compose -f build.yml up && docker-compose up
请记住不要使用
-d
与第一个容器分离因为在我们开始我们的
docker-compose.yml
之前必须完成完整的 Paketo 构建。 .使用这种方法,我们也绝对不需要
Dockerfile
.但与此同时,我想到了
完全不需要单独的构建容器,只需使用 Maven(或 Gradle)在
up
之前由
&&
连接就像 TLDR 中已经描述的那样:
mvn clean spring-boot:build-image && docker-compose up
希望这对您有所帮助。很高兴听到您的反馈!
Here's also a full GitHub actions build显示 Cloud CI 服务器上的所有“魔法”。
docker-compose up --build
使用 Paketo Buildpacks 触发所有 Spring Boot 应用程序的全新镜像构建。
关于spring - 调用 docker-compose build 命令时执行 Spring buildpacks,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/65325129/
关闭。这个问题是off-topic .它目前不接受答案。 想改进这个问题吗? Update the question所以它是on-topic用于堆栈溢出。 关闭 9 年前。 Improve this
我有一系列 SQL 命令,我想在大约 40 个不同的表上运行。必须有一种方法可以在不编写 40 条不同命令的情况下执行此操作... 我在 SQL Server 中运行它。所有表都有不同的名称,我要操作
我习惯在 PHP 中使用命令“mysql_insert_id()”来返回插入到我的数据库中的最后一行的 id。 在 C# 中的 SQLite 中是否有等效的命令? 谢谢! -阿德娜 最佳答案 选择 l
试图找出一种方法来回填 ds 分区 Hive 表的分区。 我知道如何从 CLI 运行 Hive 命令,例如 $HIVE_HOME/bin/hive -e 'select a.col from tab1
我有 .bat 文件。看起来像下一个 ....many commands1 ftp -i -s:copy.txt ...many commands2 copy.txt 包含下一个命令 open ...
基本上我想输入 show 并检查是否有 show 命令或别名已定义并触发它,如果未定义则触发 git show 。 例如 rm 应该执行 rm 但 checkout 应该执行 git checkout
我公司的主数据库是 iSeries 机器,我已经非常习惯使用 DB2 命令和结构。我现在正在尝试做一个小项目,更新一个包含超过 300 万条记录的表。我想出一种比较和“清理”数据的更快方法是使用 My
我想在带有 Node 的终端中制作一个简单的按钮板,并“blessed”用于连接或运行不同的命令。 ----------------------------------------------- _
我们有一个 selenium IDE 脚本,正在转换为 python webdriver。以下命令未转换: [openWindow | http://mywebsite.com/index.php |
我正在学习这个关于从 GIT HUB 下载和安装 Web 文件的在线教程。我进入主题:启动我们的静态网站,系统提示我输入命令以下载和安装 Web 文件。但是,当我输入命令 yarn install 时
我在 shell 脚本中使用 elif 命令时遇到问题,就像在 fortran 中一样。 我有 100 家公司的员工名单。我想屏蔽那些员工少于 500 人的公司。我的脚本是 rm -f categor
我有一些 Linux 命令可以生成 token 。我在 Linux 机器上使用操作系统库形式的 Python 自动化了这些命令。它工作正常。 但是,当我在 Windows 中尝试相同的代码时,它没有返
本文分享自华为云社区《Git你有可能不知道交互式暂存》,作者:龙哥手记。 本节中的几个交互式 Git 命令可以帮助你将文件的特定部分组合成提交。 当你在修改了大量文件后,希望这些改动能拆分为若干提交而
我想知道如何使用 IN 比较语法来做到这一点。 当前的 SQL 查询是: select * from employee where (employeeName = 'AJAY' and month(e
我在这个位置安装了 Hadoop /usr/local/hadoop$ 现在我想列出 dfs 中的文件。我使用的命令是: hduser@ubuntu:/usr/local/hadoop$ bin/ha
是否有一个单一的 docker 命令可用于清除所有内容?如果正在运行,请停止所有容器、删除所有图像、删除所有卷...等。 最佳答案 我认为没有一个命令可以做到这一点。您首先需要停止所有容器使用 $ d
我基本上是在 clojure/nrepl 模式中寻找与 C-u C-x C-e 或 C-c C-p 等效的 Scheme。 我想要一个 C-x C-e 将输出打印到缓冲区,而不是仅仅在 repl 中。
我可以在 vim 中使用 pudb(一个 ncurses Python 调试器),因为,例如,:!python %在实际的终端窗口中运行。我更喜欢使用 gvim,但 gvim 运行 :!python
我正在尝试编写一个 FFMPEG 命令: 取为 输入 一个视频 input.mp4 和一个图像 pic.jpg 作为 输出 将 input.mp4 拆分为 20 秒的视频,按顺序重命名;对于每个分割视
我想转储视频每帧的比特率。我正在尝试使用 -vstats 获取此信息命令。当我运行此命令时 - ffmpeg -i input.mp4 -vstats 它显示至少应该定义一个文件。 如果有人能建议我任
我是一名优秀的程序员,十分优秀!