Docker 容器已启动就崩溃,如何进入调试?

2021-04-15 11:19:04 +08:00
 nyse

一个运行 MySQL 的容器,由于操作失误,导致一启动就崩溃。

运行容器中的 bash 提示容器未启动,但是容器根本就没办法启动。

所以这种情况如何进入容器操作?

有什么办法能把容器中的文件复制出来吗?

2149 次点击
所在节点    Docker
10 条回复
sniperking1234
2021-04-15 11:20:16 +08:00
启动命令那里加个 sleep 3600
momocraft
2021-04-15 11:22:09 +08:00
试试 docker export
或者 docker inspect 可以看到容器内文件系统在 host 的路径
momocraft
2021-04-15 11:23:09 +08:00
如果你在用 docker-compose 不要随便改命令
否则可能创建个新的容器 丢失你想保留的文件
BeautifulSoap
2021-04-15 11:23:17 +08:00
虽然根本没看懂 lz 到底遇到了什么问题(连错误信息都没有),但是通过别的方式访问到容器内的文件还是有非常多方法的,搜一下就一堆
https://stackoverflow.com/questions/20813486/exploring-docker-containers-file-system

以及,容器崩了直接销毁重启不就好了,别说 lz 你所有数据都没持久化全塞容器里。。。。。。。
yuanmomo
2021-04-15 11:36:58 +08:00
在命令行用 bash 命令覆盖 dockerfile 里面默认的启动命令。

正常容器启动了过后,在 bash 执行相同的命令去排查
Vegetable
2021-04-15 11:41:08 +08:00
覆盖启动命令,进入容器手动启动 mysql,查看日志
whileFalse
2021-04-15 12:07:09 +08:00
docker run -ti --entrypoint="" 你的自定义镜像 sh

然后敲命令启动 mysql
cheng6563
2021-04-15 14:24:30 +08:00
现有容器存为镜像,然后 docker run -ti --entrypoint="" IMAGE_ID sh
killva4624
2021-04-15 14:48:22 +08:00
一个是看看上个容器出错的原因,比如 mysql 这种,出错日志会打在 stdout 里; docker ps -a 看看所有容器里刚启动就崩溃的容器,然后 docker logs 看看有没有错误输出。

另外一个方法就是调试,如上面的大佬们说的,用 sleep xxxxx 或者 ping 127.0.0.1 作为启动命令( 1 号进程),让容器跑起来,然后 docker exec 到容器里手动拉起服务看看报错。
nyse
2021-04-15 14:51:04 +08:00
感谢各位大佬提供的思路,现在解决了。

我用的是 docker-compose,通过删除 MySQL 的数据文件,重新初始化 MySQL,再恢复之前备份的数据库文件解决的。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/770795

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX