AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 596994
Accepted
estani
estani
Asked: 2014-05-20 07:28:30 +0800 CST2014-05-20 07:28:30 +0800 CST 2014-05-20 07:28:30 +0800 CST

如何调试 docker 容器初始化?

  • 772

我遇到了一个容器问题,即使它构建得很好,它也没有正确启动。原因是我添加到 Dockerfile 中的一种解决方法(用于具有自配置 /etc/hosts 路由)

RUN mkdir -p -- /lib-override /etc-override && cp /lib/libnss_files.so.2 /lib-override
ADD hosts.template /etc-override/hosts
RUN perl -pi -e 's:/etc/hosts:/etc-override/hosts:g' /lib-override/libnss_files.so.2
ENV LD_LIBRARY_PATH /lib-override

显然那里有一些错误,但我想知道如何获得更多关于 docker 在运行时正在做什么的信息。例如,这有效:

$ docker run image ls
usr bin ...

但这不会:

$ docker run image ls -l
$

日志中没有任何内容,我也无法调用交互式 shell。我可以使用 strace 来查看发生了什么,但我希望有更好的方法。

有什么办法可以让 docker 更详细吗?

编辑:感谢 Andrew D。我现在知道上面的代码有什么问题(我留下了它,以便可以理解他的答案)。现在的问题仍然是我如何调试这样的东西或了解为什么ls -l失败了为什么ls没有。

编辑: -D=true 可能会提供更多输出,但在我的情况下不是...

docker
  • 5 5 个回答
  • 260000 Views

5 个回答

  • Voted
  1. Best Answer
    Peter Lamberg
    2015-12-23T05:24:06+08:002015-12-23T05:24:06+08:00

    Dockerevents命令可能会有所帮助,即使在映像无法启动后, Docker logs命令也可以获取日志。

    首先docker events在后台启动,看看发生了什么。

    docker events&
    

    然后运行失败的docker run ...命令。然后您应该在屏幕上看到类似以下内容:

    2015-12-22T15:13:05.503402713+02:00 xxxxxxxacd8ca86df9eac5fd5466884c0b42a06293ccff0b5101b5987f5da07d: (from xxx/xxx:latest) die
    

    然后您可以从上一条消息或运行命令的输出中获取启动十六进制 id。然后你可以将它与 logs 命令一起使用:

    docker logs <copy the instance id from docker events messages on screen>
    

    您现在应该会看到来自失败的映像启动的一些输出。

    正如@alexkb 在评论中建议的那样:docker events&如果您的容器不断地从 AWS ECS 服务之类的东西重新启动,这可能会很麻烦。在这种情况下,从日志中获取容器十六进制 id 可能更容易/var/log/ecs/ecs-agent.log.<DATE>。然后使用 docker logs <hex id>。

    • 158
  2. estani
    2014-05-27T01:07:44+08:002014-05-27T01:07:44+08:00

    到目前为止,我发现的最好的是:

    #stop the current demon and start it in debug modus
    sudo service docker stop
    dockerd -D # --debug
    

    刚刚从一个新的 shell 启动客户端。误解是认为客户端实际上做了任何事情......好吧,它只是与守护进程通信,所以你不想调试客户端而是调试守护进程本身(通常)。

    • 24
  3. claytond
    2016-03-30T05:27:26+08:002016-03-30T05:27:26+08:00

    就我而言,-a(附加到 STDOUT/STDERR)标志就足够了:

    user@machine:~$ docker start -a server_name
    Error: The directory named as part of the path /log/log_path/app.log does not exist.
    For help, use /usr/bin/supervisord -h
    

    它显示了启动错误(在我们的例子中,缺少使用的日志路径supervisord)。我认为大多数容器启动错误也会出现在这里。

    • 22
  4. Andrew Domaszek
    2014-05-20T13:01:42+08:002014-05-20T13:01:42+08:00

    我无法回答您关于如何使 docker 输出更完整的问题,但我可以告诉您,就地正则表达式替换 .so 文件中的字符串有点疯狂:字符串只分配了这么多空间,并且如果更改其他条目的文件偏移量,elf 文件将损坏。在容器外部运行 perl 命令(在 LD_LIBRARY_PATH 更改之前)后,尝试在 .so 文件上运行 objdump 或 readelf —— 美元到甜甜圈现在已损坏。

    它在这个非常必要的 hack中起作用的原因是因为“tmp”和“etc”是相同的字符串长度,所以没有偏移量改变。如果您不想使用 /tmp,请考虑目录 /dkr 或类似目录。

    如果您必须采用这种方法并且您所需的路径不可更改,请重建库并更改源中 /etc/hosts 的默认路径。或者更好的是,在构建修改后的libnss_files.so重命名时,将其重命名为类似libnss_altfiles.so并更改nsswitch.conf为hosts: altfiles在启动 docker 容器时使用(除非 docker 也绑定了挂载的 nsswitch.conf,否则您无法更改它)。这将使您拥有 libnss_altfiles.so 与基本系统中的普通库并行。如果 docker 确实绑定挂载 nsswitch.conf,请在 /lib-override 目录中保留重建的 libnss_files.so 的副本,以供 LD_LIBRARY_PATH 加载。

    提醒一下,suid/sgid 二进制文件会忽略 LD_LIBRARY_PATH 和 LD_PRELOAD,因此如果您使用这些变量,有些东西会被破坏(阅读:返回使用默认的 /etc/hosts)。

    • 4
  5. user674669
    2019-03-28T17:30:06+08:002019-03-28T17:30:06+08:00

    有时,您可以通过 ssh 进入运行 docker 守护进程的节点然后执行以下操作来找到有用的错误消息:

    $ tail -f /var/log/containers/* /var/log/docker.log 2>&1
    

    在 Mac OS 上的“Docker 社区版”上,您可以通过以下方式连接到 docker vm:

    $  screen ~/Library/Containers/com.docker.docker/Data/vms/0/tty
    
    • 3

相关问题

  • 创建后立即启动 Docker 容器?

  • 如何在不指定命令的情况下在 Docker 容器中运行完整的操作系统?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve