实例 : 查看Docker容器内文件系统-阿里云开发者社区

开发者社区> biocodee> 正文

实例 : 查看Docker容器内文件系统

简介: dockfile ; docker container ; docker images
+关注继续查看
目的:下载 docker images 之后,了解 images 内部目录、文件结构,以及容器内部程序运行情况

方法:

1. 使用docker exec (最简单)

nsenter命令类似,docker exec 命令可以在已经运行的容器运行新的进程(容器必须已经运行才可以,否则会报错),可以运行/bin/bash进入容器:

[arthur@localhost Downloads]$ sudo docker ps
[sudo] password for arthur: 
CONTAINER ID   IMAGE                COMMAND       CREATED       STATUS       PORTS     NAMES
09b6673f175a   hicstuff:v1.0        "/bin/bash"   2 hours ago   Up 2 hours             quizzical_chatelet
c67a7e98646a   koszullab/hicstuff   "/bin/bash"   4 hours ago   Up 4 hours             sleepy_bhabha
[arthur@localhost Downloads]$ sudo docker exec -it  quizzical_chatelet /bin/bash
(base) root@09b6673f175a:/app# pwd
/app
(base) root@09b6673f175a:/app# ls
LICENSE      __init__.py  distance_law.py  io.py     pipeline.py       test_commands.py     test_filter.py    tests
MANIFEST.in  commands.py  filter.py       iteralign.py  requirements.txt  test_digest.py     test_hicstuff.py  version.py
Makefile     cutsite.py   hicstuff       log.py     setup.cfg       test_distance_law.py  test_io.py       view.py
README.md    digest.py      hicstuff.py       main.py     setup.py       test_doctests.py     test_pipeline.py
2. 使用快照(snapshotting)
#查看已经运行的容器,记录要查看容器的 ID 
$ docker ps
#创建新的 images 
$ docker commit  ID  NewImagesName
#通过 `bash` 进入新镜像
$ docker run -it NewImagesName /bin/bash
#删除新的镜像 NewImagesName
$ docker rmi NewIamgesName
3. 使用 ssh

如果需要持续性连接到容器,可以在容器内安装sshd,并运行sshd

#查看 容器 port
$ docker ps
#
$ docker run -d -p PortNumber ContainerName /usr/sbin/sshd -D
4. 使用nsenter
5. 覆盖默认的 ENTRYPOINT
$ docker run --rm -it --entrypoint=/bin/bash NameofImage
#########################################################################
--entrypoint string              Overwrite the default ENTRYPOINT of the image

#覆盖默认 entrypoint  
[arthur@localhost Downloads]$ sudo docker run --rm -it --entrypoint=/bin/bash koszullab/hicstuff  
[sudo] password for arthur: 
(base) root@1f60e1415681:/app# pwd
/app
(base) root@1f60e1415681:/app# ls
LICENSE      __init__.py  distance_law.py  io.py     pipeline.py       test_commands.py     test_filter.py    tests
MANIFEST.in  commands.py  filter.py       iteralign.py  requirements.txt  test_digest.py     test_hicstuff.py  version.py
Makefile     cutsite.py   hicstuff       log.py     setup.cfg       test_distance_law.py  test_io.py       view.py
README.md    digest.py      hicstuff.py       main.py     setup.py       test_doctests.py     test_pipeline.py
(base) root@1f60e1415681:/app# 

#未覆盖
[arthur@localhost Downloads]$ sudo docker run -it koszullab/hicstuff 
[sudo] password for arthur: 
INFO :: generated new fontManager
usage:
    hicstuff [-hv] <command> [<args>...]
[arthur@localhost Downloads]$ sudo docker run -it koszullab/hicstuff  /bin/bash
INFO :: generated new fontManager
Unknown command.
usage:
    hicstuff [-hv] <command> [<args>...]
[arthur@localhost Downloads]$ 
#运行其他 images 
[arthur@localhost Downloads]$ sudo docker run -it hicpro:homo.v1
root@5bf6508e2b7c:/# exit
exit
[arthur@localhost Downloads]$ sudo docker run -it nservant/hicpro:v3.01
root@fb00a89cb150:/# exit
exit
#原镜像运行 commit 之后的
[arthur@localhost Downloads]$ 
[arthur@localhost Downloads]$ sudo docker run -it hicstuff:v1.0 
[sudo] password for arthur: 
(base) root@4de5fd7f7bae:/app# pwd
/app
(base) root@4de5fd7f7bae:/app# ls
LICENSE      __init__.py  distance_law.py  io.py     pipeline.py       test_commands.py     test_filter.py    tests
MANIFEST.in  commands.py  filter.py       iteralign.py  requirements.txt  test_digest.py     test_hicstuff.py  version.py
Makefile     cutsite.py   hicstuff       log.py     setup.cfg       test_distance_law.py  test_io.py       view.py
README.md    digest.py      hicstuff.py       main.py     setup.py       test_doctests.py     test_pipeline.py

拓展:

  1. 镜像构建 dockfile 存在差别:

    koszullab/hicstuff 镜像为 from conda , nservant/hicpro from ubuntu

  2. 原镜像 koszullab/hicstuff commit 之后与原镜像的差别:登陆方式出现差别

Reference :
[1] exploring Docker container's file system.stack overflow.

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
Python 技术篇-利用pickle库查看pkl文件实例演示。pkl是什么类型的文件?怎么来打开它?
Python 技术篇-利用pickle库查看pkl文件实例演示。pkl是什么类型的文件?怎么来打开它?
14 0
Python 技术篇 - 通过代码查看文本的编码类型实例演示,如何查看文件的编码类型,文件编码查看方法
文件主要分为二进制文件和文本文件这两种,看你想要查看哪种文件的编码,如果是文本文件的话,open 函数里的就要用 r,二进制文件用的是 rb,别搞错哦!
11 0
阿里云容器网络文件系统 CNFS 1.0 发布,体验云原生时代的容器共享存储
简介:CNFS 通过将阿里云的文件存储抽象为一个 Kubernetes 对象(CRD)进行独立管理,包括创建、删除、描述、挂载,监控及扩容等运维操作,使用户可以在享受容器使用文件存储带来的便捷的同时,提高文件存储的性能和数据安全,并提供容器一致的声明式管理。
121 0
MDF文件查看器(SQL MDF Viewer) 1.0 绿色版
当你想查看一个 SQL Server 数据库的 MDF 文件的时候,而你却没有安装 SQL Server  (那么庞大的一个软件,安装之后想卸载?根本卸载不干静), 那怎么办呢? MDF文件查看器(SQL MDF Viewer) 1.0 绿色版,这是一个很不错的工具,下载即用,不过只有 Windows 版。
1282 0
使用阿里云容器服务 ACK 和文件存储 NAS 构建现代化企业应用
大规模构建容器化应用程序需要高可靠、弹性、共享且支持高性能数据处理的数据存储解决方案。通过迁移到公共云,企业可以获得更高的生产效率和更低的成本。阿里云文件存储可以为现代化应用提供强健的数据稳定性,可靠性,高性能和在线扩展能力。
1322 0
使用阿里云文件存储实现容器持久化存储
阿里云文件存储实现容器持久化存储的架构、最佳实践、应用场景以及案例。
4065 0
+关注
biocodee
bio2coder
24
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
《2021云上架构与运维峰会演讲合集》
立即下载
《零基础CSS入门教程》
立即下载
《零基础HTML入门教程》
立即下载