所以我试图在我的docker群中运行jenkins,我希望它能够执行docker命令来构建新的docker镜像。
当我使用docker-compose脚本在本地运行时:
version: '2'
services:
jenkins:
build: ./jenkins
image: munhunger/jenkins
container_name: "jenkins"
ports:
- "81:8080"
environment:
- minio_url=<URL>
- minio_access=<TOKEN>
- minio_secret=<SECRET>
volumes:
- /var/run/docker.sock:/var/run/docker.sock
- /root/.jenkins/workspace:/root/.jenkins/workspace
- /var/lib/jenkins:/var/lib/jenkins
- /var/lib/docker:/var/lib/docker
它完全可以按照我的意愿运行,并且可以构建以下jenkinsfile:
pipeline {
agent any
stages {
stage('build war') {
agent {
docker { image 'gradle:latest' }
}
steps {
sh 'gradle war -b oven/build.gradle'
}
}
stage('build dockerimage') {
steps {
script {
dir('oven') {
def image = docker.build("munhunger/highly-oven")
docker.withRegistry('https://registry.hub.docker.com', 'docker-hub-credentials') {
image.push("${env.BUILD_NUMBER}")
image.push("latest")
}
}
}
}
}
}
}
问题在于,似乎不可能将其部署到我的docker swarm。
我只是不断得到
invalid mount config for type "bind": bind source path does not exist
。这是在使用Portainer进行部署时。我是否配置错误或发生了什么?编辑:
我测试了使用
docker stack deploy -c jenkins.yml jenkins
部署以下撰写文件version: '3'
services:
jenkins:
image: munhunger/jenkins
container_name: "jenkins"
ports:
- "81:8080"
environment:
- minio_url=<URL>
- minio_access=<ACCESS>
- minio_secret=<SECRET>
volumes:
- /var/run/docker.sock:/var/run/docker.sock
- /root/.jenkins/workspace:/root/.jenkins/workspace
- /var/lib/jenkins:/var/lib/jenkins
- /var/lib/docker:/var/lib/docker
但是我仍然得到
invalid mount config for type "bind": bind source path does not exist
最佳答案
没有理由使用绑定(bind)安装或Docker套接字在Docker容器中使用Jenkins。可以使用命名卷来存储重要的(持久)配置数据,但是您可以使用docker命令构建镜像,而无需使用主机docker套接字。
参见https://hub.docker.com/r/jenkins/jenkins/
和https://hub.docker.com/_/docker/(docker中的docker)
和http://vfarcic.github.io/jenkins-swarm/#/cover