相关疑难解决方法(0)

Docker,如何从容器中获取容器信息?

我想让我docker containers了解他们的配置,就像通过元数据获取有关EC2实例的信息一样.

我可以使用(提供的docker是监听端口4243)

curl http://172.17.42.1:4243/containers/$HOSTNAME/json
Run Code Online (Sandbox Code Playgroud)

得到它的一些数据,但想知道是否有更好的方法至少获得容器的完整ID,因为HOSTNAME实际上缩短为12个字符,并且docker似乎在它上执行"最佳匹配".

另外,如何获取docker主机的外部IP(除了访问特定于AWS的EC2元数据)

linux docker

111
推荐指数
11
解决办法
10万
查看次数

如何确定哪个容器拥有哪个覆盖目录?

我的/var/lib/docker/overlay目录包含我的容器的数据,但目录名称都是散列的。如何确定哪个容器拥有哪个覆盖层?

docker

11
推荐指数
3
解决办法
5277
查看次数

在 Debian 11 (Bullseye) 上,docker 容器内的 /proc/self/cgroup 不显示 docker 信息

我最近从 Debian 10 (Buster) 更新到 11 (Bullseye),从那时起,我在 Docker 内的 Jenkins 设置就不再工作了,因为 Jenkins 试图通过检查/proc/self/cgroup.

通常,/proc/self/cgroupdocker 容器内部看起来像这样:

12:rdma:/
11:perf_event:/docker/a2ffe0e97ac22657a2a023ad628e9df837c38a03b1ebc904d3f6d644eb1a1a81
10:freezer:/docker/a2ffe0e97ac22657a2a023ad628e9df837c38a03b1ebc904d3f6d644eb1a1a81
9:memory:/docker/a2ffe0e97ac22657a2a023ad628e9df837c38a03b1ebc904d3f6d644eb1a1a81
8:cpuset:/docker/a2ffe0e97ac22657a2a023ad628e9df837c38a03b1ebc904d3f6d644eb1a1a81
7:devices:/docker/a2ffe0e97ac22657a2a023ad628e9df837c38a03b1ebc904d3f6d644eb1a1a81
6:net_cls,net_prio:/docker/a2ffe0e97ac22657a2a023ad628e9df837c38a03b1ebc904d3f6d644eb1a1a81
5:hugetlb:/docker/a2ffe0e97ac22657a2a023ad628e9df837c38a03b1ebc904d3f6d644eb1a1a81
4:pids:/docker/a2ffe0e97ac22657a2a023ad628e9df837c38a03b1ebc904d3f6d644eb1a1a81
3:cpu,cpuacct:/docker/a2ffe0e97ac22657a2a023ad628e9df837c38a03b1ebc904d3f6d644eb1a1a81
2:blkio:/docker/a2ffe0e97ac22657a2a023ad628e9df837c38a03b1ebc904d3f6d644eb1a1a81
1:name=systemd:/docker/a2ffe0e97ac22657a2a023ad628e9df837c38a03b1ebc904d3f6d644eb1a1a81
0::/system.slice/containerd.service
Run Code Online (Sandbox Code Playgroud)

但自从我更新到 Debian 11 后,它看起来很小:

0::/
Run Code Online (Sandbox Code Playgroud)

由于 Jenkins 不再认识到它是在 docker 容器本身内运行,因此它会使用错误的参数启动其他构建容器。

问题

简单的问题是:这是一个错误吗?

但真正的问题可能是我做错了什么?我找不到其他人遇到此问题,因此可能是配置错误或类似的问题。

我重新安装了 Docker,删除了所有配置,甚至尝试将 Docker 降级到 20.10.6,因为这是我所知道的在 Debian 10 下运行的最后一个版本,但这些都没有改变任何东西。

我不知道如何进一步解决这个问题。我已经花了一整天的时间才发现问题不是 Jenkins 本身(几乎疯狂地阅读 Jenkins 日志)。我现在正在打基础,所以非常感谢任何帮助和意见!


詹金斯的东西

对于那些对 Jenkins 部分感兴趣的人,这里 Jenkins 检查它是否在容器内运行: https://github.com/jenkinsci/docker-workflow-plugin/blob/b174d46226ef1095903f2e789355a3b216b46dda/src/main/java/org/jenkinsci/plugins /docker/workflow/client/DockerClient.java#L347

Jenkins 认为它​​没有在容器内运行,会记录如下内容:

Jenkins does not seem to be running inside a container
$ …
Run Code Online (Sandbox Code Playgroud)

linux debian jenkins cgroups docker

8
推荐指数
1
解决办法
4530
查看次数

Ubuntu 22.04 上的 Docker jenkins ssh-agent“未在容器内运行”

现在 Ubuntu 22.04 已经发布了,我在我们的一位 jenkins-workers 上进行了全新安装来测试它,但我无法让 docker ssh-agent 正常工作。它无法再识别它是否在容器内运行,因此每当启动使用 docker 的作业时,我都可以在控制台中看到“Jenkins-worker-X 似乎没有在容器内运行”,然后管道失败。

我从之前就知道jenkins使用cgroup信息来检测它是否在容器中运行,因此例如cat /proc/self/cgroup在容器中执行应该会产生以 结尾的行列表/docker/<container-id>,然后Jenkins使用该列表来检测容器。但是,一旦我安装了 Ubuntu 22.04,cgroup 信息就不再包含 ,这/docker/<container-id>会导致 jenkins 代理认为它在裸机上运行。

即使执行官方镜像也有同样的问题,即docker run jenkins/ssh-agent:jdk11最后docker exec <container-id> cat /proc/self/cgroup会得到一个在我的机器上没有容器哈希的列表。

我该如何解决这个问题?从 Ubuntu 21.10 到 22.04 是否发生了某些变化导致了此问题?是否需要一些额外的配置?

我正在运行最新的 Ubuntu 22.04 (5.15.0-27-generic)、Docker 版本 20.10.12、内部版本 20.10.12-0ubuntu4。

任何帮助,将不胜感激!

编辑:我现在意识到,如果将所有软件包升级到最新版本(并使用最新的 jenkins/ssh-agent 映像),21.10 中也会发生同样的情况,因此原因可能出在升级的软件包之一中

jenkins cgroups docker

3
推荐指数
1
解决办法
1167
查看次数

标签 统计

docker ×4

cgroups ×2

jenkins ×2

linux ×2

debian ×1