我正在研究Centos7。我有一个运行Jenkins的Docker容器。在那个Jenkins容器中,我必须构建并运行其他Docker容器。但是詹金斯不认识码头工人。我能够执行一个shell并将docker安装在容器中。但是,是否有可能让容器在主机上使用我的docker-engine?如何使用?
在Jenkins-(docker)-容器内安装Docker的最佳选择是什么?
通常,容器中容器的设置涉及链接/var/run/docker.sock
及其docker
本身。
例如,在此线程中:
docker run --name jenkins --privileged=true -t -i --rm -v /var/run/docker.sock:/var/run/docker.sock -v $(which docker):/bin/docker -p 8080:8080 jenkins
这并不完全是您的情况,因为您无需在“ cic”(容器中的容器”)中运行Jenkins本身,
但这说明了如何在容器中运行带有docker的任何容器。
确保该容器中的用户是docker组的一部分(如果您不想使用root),如此jenkins/setup-docker-and-start-jenkins.sh
脚本中所示
#!/bin/sh
set -e
JUSER="jenkins"
DOCKER_GID=$(ls -aln /var/run/docker.sock | awk '{print $4}')
if ! getent group $DOCKER_GID; then
echo creating docker group $DOCKER_GID
addgroup --gid $DOCKER_GID docker
fi
if ! getent group $GID; then
echo creating $JUSER group $GID
addgroup --gid $GID $JUSER
fi
if ! getent passwd $JUSER; then
echo useradd -N --gid $GID -u $UID $JUSER
useradd -N --gid $GID -u $UID $JUSER
fi
DOCKER_GROUP=$(ls -al /var/run/docker.sock | awk '{print $4}')
if ! id -nG "$JUSER" | grep -qw "$DOCKER_GROUP"; then
adduser $JUSER $DOCKER_GROUP
fi
chown -R $JUSER:$JUSER /var/jenkins_home/
请注意,此设置用于tini
启动Jenkins(如我在“在Docker容器中安装后Jenkins不会自动运行”中所述)
exec su $JUSER -c "/bin/tini -- /usr/local/bin/jenkins.sh"
同样,这些脚本用于在“ cic”中使用Jenkins。
就您而言,您可以将这些脚本用于Jenkins必须运行的容器。
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句