我正在寻找一种方法来为我的供应商提供的 special-app
容器执行以下操作:
目前,对于我从 3rd 方存储库获得的其他 docker 镜像,我可以在 Github 中找到它们,它们包含 Dockerfile,然后我在我的管道中使用它来构建,然后像这样推送到我的个人存储库:
stage('Clone from Git') {
try {
git branch: 'master',
url: 'https://github.com/exampleapp.git'
} catch (Exception ex) {
println("Unable to git clone: ${ex}")
error 'Git Clone failure'
}
}
stage ('Build Docker Image') {
try {
dir('./') {
def customImage =
docker.build("myregistry.com/myimages/exampleapp:${env.BUILD_ID}")
}
} catch (Exception ex) {
error 'Docker Build failure'
}
}
stage ('Push Image to Registry') {
try {
docker.withRegistry('https://myregistry.com', 'mycreds') {
def customImage =
docker.image("myregistry.com/myimages/exampleapp:${env.BUILD_ID}")
customImage.push('latest')
}
} catch (Exception ex) {
println("Unable push image to registry: ${ex}")
error 'Registry Push failure'
}
}
但是对于special-app
,供应商基本上只提供一个 yaml 文件,然后我用它来创建容器:
docker-compose -p special-app -f vendor-provided.yml up -d
虽然这可以使容器启动并运行,但没有随此方法提供 Dockerfile,因此我无法使用上面用于其他图像的相同方法,因为我确实有 Dockerfile。 在这种情况下我应该怎么做?如果我没有 Dockerfile,如何从供应商处获取 docker 映像并将其推送到我的本地存储库以进行妥善保管?在我的管道中还有其他方法可以实现这一目标吗?
(我们保留这些图像的本地副本作为标准流程,即使我们没有对其中一些图像进行调整/自定义 - 在本 special-app
中就是这种情况)。
谢谢 J
答案 0 :(得分:0)
您可以尝试提取 vendor-provided.yml 从中提取的映像的 url/名称,并在简单的 Dockerfile 中使用它来提取映像并创建自己的映像:
使用 this post 中的技术,您可以获得图像值。
管道的新阶段,您可以在其中创建单行 Dockerfile:
stage('Make Dockerfile from vendor yaml') {
steps {
script{
def valuesYaml = readYaml (file: './path-to/vendor-provided.yml')
def line1 = "FROM ${valuesYaml.image}"
writeFile file: "Dockerfile", text: line1
}
}
}
创建 Dockerfile:
FROM vendor-image
从这里您应该能够构建镜像并将其推送到您的注册表。