DevOps搭建(十一)-Jenkins容器内部使用Docker详解

1、目的

配置的目的是使得Jenkins容器可以直接使用宿主机的Docker,从而可以直接使用Docker命令进行本地打包操作,然后推送到Harbor镜像仓库。

2、修改数据卷

如何在docker中执行宿主机的docker操作,我们管它叫docker in docker。

至于为什么要在docker中操作宿主机的docker,优点不言而喻,我们既可以将你的具体需求容器化部署,又不用直接在宿主机上安装(假设我们没有办法在docker中操作宿主机的docker,那么我们只能将这样的软件程序直接安装到宿主机上,这样显然是不利于管理和维护的)。

实现这种需求,其实非常简单,只需要将docker宿主机的docker文件和docker.sock文件挂载到容器中即可,具体为:

cd /usr/local/docker/jenkins_docker/
vi docker-compose.yml

数据卷追加以下配置:

- /var/run/docker.sock:/var/run/docker.sock
- /usr/bin/docker:/usr/bin/docker
- /etc/docker/daemon.json:/etc/docker/daemon.json

完整的配置如下:

version: "3.1"
services:
  jenkins:
    image: jenkins/jenkins:2.401.2-lts
    container_name: jenkins
    restart: always
    ports:
      - 8080:8080
      - 50000:50000
    #数据卷,后面的操作会在这个目录下进行操作
    volumes:
      - ./data/:/var/jenkins_home/
      - /var/run/docker.sock:/var/run/docker.sock
      - /usr/bin/docker:/usr/bin/docker
      - /etc/docker/daemon.json:/etc/docker/daemon.json

配置完后重新启动下Jenkins容器

docker-compose up -d

3、配置容器内访问daemon.json权限

虽然前个步骤我们已经挂载了对应的数据卷,但是会存在一个问题,docker.sock是属于docker用户组的。

ls -l /var/run/docker.sock

图片

只有docker用户组下的用户才有权限操作docker.sock这个文件。

而jenkins容器内的默认用户是jenkins用户,单宿主机是没有叫jenkins这个用户的,所以我们没法直接在宿主机把jenkins用户添加到docker用户组。

幸运的是,容器在内外访问的uid和gid是相同的,也就是容器在访问外部挂载文件的用户和组的唯一标识是完全一样的。

我们先进入宿主机查看docker用户组的ID,如下图,发现ID为981

cat /etc/group | grep docker

图片

接着,我们可以进入jenkins容器中,将jenkins用户添加到docker用户组里。

docker exec -it jenkins bash
ls -l /var/run/docker.sock

图片

从上图中可知,docker.sock的属组是981,由于容器内部没有组id为981的组,所以显示981,而jenkins容器内的默认用户是jenkins用户,所以我们需要创建组id为981的组,把jenkins用户添加到id为981的组,就能满足jenkins容器访问容器外的docker。

创建组id为981的docker用户组:

groupadd -g 981 docker

然后把jenkins用户加入到docker组中:

gpasswd -a jenkins docker

图片

退出容器:exit,并重启jenkins容器

docker restart jenkins

4、验证直接使用Docker命令

进入Jenkins容器内部使用Docker命令

docker exec -it jenkins bash

进入容器后,执行查看Docker版本的命令

docker version

出现以下信息,证明已经成功配置。

图片

  • 17
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Java高知社区

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值