为了账号安全,请及时绑定邮箱和手机立即绑定

请问我该如何进入正在运行中的Docker容器?

请问我该如何进入正在运行中的Docker容器?

慕村225694 2019-08-13 15:11:22
如何进入正在运行中的Docker容器
查看完整描述

4 回答

?
森栏

TA贡献1810条经验 获得超5个赞

开始安装docker之旅:
  [root@localhost ~]# uname -r
  2.6.32-431.el6.x86_64
  [root@localhost ~]# cat /etc/issue
  CentOS release 6.5 (Final)
  Kernel \r on an \m
  注意其他的源可能导致你的内核和docker的版本不一致,需要升级内核至3.x。
  安装:
  [root@localhost ~]# rpm -ivh
  Retrieving
  warning: /var/tmp/rpm-tmp.JN76fI: Header V3 RSA/SHA256 Signature, key ID 0608b895: NOKEY
  Preparing.。。 ########################################### [100%]
  1:epel-release ########################################### [100%]
  [root@localhost ~]# rpm --import /etc/pki/rpm-gpg/RPM-GPG-KEY-EPEL-6
  [root@localhost ~]# yum -y install docker-io
  启动并设置开机自动启动
  [root@localhost ~]# service docker start
  Starting cgconfig service: [确定]
  Starting docker: [确定]
  [root@localhost ~]# chkconfig docker on
  获取cnetos镜像
  [root@localhost ~]# docker pull centos:latest
  centos:latest: The image you are pulling has been verified
  511136ea3c5a: Pull complete
  5b12ef8fd570: Pull complete
  34943839435d: Downloading [===》 ] 18.38 MB/232.5 MB 1h7m49s
 #官方安装方式docker pull imagename从docker的索引中心下载,imagename是镜像名称,例如docker pull Ubuntu就是下载base ubuntu并且tag是latest。
  我们还可以搜索基于 Fedora 和 Ubuntu 操作系统的容器。
  [root@localhost ~]# docker search ubuntu
  [root@localhost ~]# docker search fedora
  查看docker镜像
  [root@localhost ~]# docker images centos
  REPOSITORY TAG IMAGE ID CREATED VIRTUAL SIZE
  centos latest 34943839435d Less than a second ago 224 MB
  运行docker运行shell
  [root@localhost ~]# docker run -i -t centos /bin/bash
  [root@2ce733141ece /]#
  [root@2ce733141ece /]#
  [root@2ce733141ece /]#
  [root@2ce733141ece /]#
  停止容器
  [root@localhost ~]# docker stop 《CONTAINER ID》
  删除所有容器
  docker rm $(docker ps -a -q)
  查看docker的子命令,直接敲docker 或完整的docker help 就可以
  常用命令
  总结一下常用命令:
  其中《》阔起来的参数为必选,[]阔起来为可选
  docker version 查看docker的版本号,包括客户端、服务端、依赖的Go等
  docker info 查看系统(docker)层面信息,包括管理的images, containers数等
  docker search 在docker index中搜索image
  docker pull 从docker registry server 中下拉image
  docker push 推送一个image或repository到registry
  docker push :TAG 同上,指定tag
  docker inspect 查看image或container的底层信息
  docker images TODO filter out the intermediate image layers (intermediate image layers 是什么)
  docker images -a 列出所有的images
  docker ps 默认显示正在运行中的container
  docker ps -l 显示最后一次创建的container,包括未运行的
  docker ps -a 显示所有的container,包括未运行的
  docker logs 查看container的日志,也就是执行命令的一些输出
  docker rm 删除一个或多个container
  docker rm `docker ps -a -q` 删除所有的container
  docker ps -a -q | xargs docker rm 同上, 删除所有的container
  docker rmi 删除一个或多个image
  docker start/stop/restart 开启/停止/重启container
  docker start -i 启动一个container并进入交互模式
  docker attach attach一个运行中的container
  docker run 使用image创建container并执行相应命令,然后停止
  docker run -i -t /bin/bash 使用image创建container并进入交互模式, login shell是/bin/bash
  docker run -i -t -p 将container的端口映射到宿主机的端口
  docker commit [repo:tag] 将一个container固化为一个新的image,后面的repo:tag可选
  docker build
  寻找path路径下名为的Dockerfile的配置文件,使用此配置生成新的image
  docker build -t repo[:tag] 同上,可以指定repo和可选的tag
  docker build - 使用指定的dockerfile配置文件,docker以stdin方式获取内容,使用此配置生成新的image
  docker port 查看本地哪个端口映射到container的指定端口,其实用docker ps 也可以看到。
  上面就是CentOS6.5安装Docker的方法介绍了,在安装Docker的时候,需要升级内核至3.x,以免版本不一样,本文除了介绍Docker的安装,还介绍了其常用的命令,希望对你有所帮助。
,



查看完整回答
反对 回复 2019-08-24
?
繁华开满天机

TA贡献1816条经验 获得超4个赞

官方镜像下的简单示例 本节中,将创建一个 Container 来运行 Docker 的官方 Registry 镜像。你将推送(Push)一个镜像到这个 Registry 服务器,然后再从该 Registry 中拉取(Pull)同一个镜像。 这是个很好的练习,有助于理解客户端与本地 Regis

查看完整回答
反对 回复 2019-08-24
?
Cats萌萌

TA贡献1805条经验 获得超9个赞

避免Docker容器启动脚本运行后自动退出的解决法dockerrun指定的命令如果不是那些一直挂起的命令(比如运行top,不断echo),就是会自动退出的。-d命令是设置detach为true,根据官方的文档,意思是让这个命令在后台运行,但并不是一直运行(我们在一个正常的LinuxTerminal中运行/bin/bash,运行完了也就完了,不会一直挂着等待响应的,所以确实没法用daemon方式来跑/bin/bash)。这个地方官方早期和现在的文档也确实有些前后不一致,现在是detach,早期的文档说指定-d以daemon方式来运行容器,可能存在一定的误解。另外,如果你需要跑容器里的bash,直接运行dockerrun-i-tCONTAINER_NAME/bin/bash就可以了,如果觉得参数比dockerattach多,可以设置一个别名(alias)来解决:aliasdockerbash='dockerrun-i-tCONTAINER_ID/bin/bash'设置好别名后,直接运行dockerbash就可以进入容器的bash了

查看完整回答
反对 回复 2019-08-24
?
浮云间

TA贡献1829条经验 获得超4个赞

  不推荐更改运行中的容器配置,容器本身是无状态的,当然也可以通过进入容器内部的方式进行更改:
  docker exec -it <容器id> </bin/bash|/bin/sh>

  这样的更改是无法持久化保存的,当容器重启后,更改就丢失了,正确的做法是将需要持久化保存的数据放在挂载的存储卷中,当配置需要改变时直接删除重建。

查看完整回答
反对 回复 2019-08-24
  • 4 回答
  • 0 关注
  • 1239 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信