docker容器相关命令
2015-03-31 00:00
381 查看
摘要: docker容器相关命令
简单的说容器是镜像的一个运行实例,所不同的是,它带有额外的可写文件层。如果认为虚拟机是模拟运行的一整套操作系统(提供了运行态环境和其他系统环境)和跑在上面的应用。那么Docker容器就是独立运行的一个或一组应用,以及它们的必需运行环境。
docker create -it ubuntu:last 创建一个容器,创建的容器处于停止状态
docker start ID|NAME[:TAG] 启动一个停止的容器
docker run NAME[:TAG] COMMAND 创建并启动一个容器
当利用docker run来创建并启动容器时,Docker在后台运行的标准操作包括:
•检查本地是否存在指定的镜像,不存在就从公有仓库下载。
•利用镜像创建并启动一个容器。
•分配一个文件系统,并在只读的镜像层外面挂载一层可读写层。
•从宿主主机配置的网桥接口中桥接一个虚拟接口到容器中去。
•从地址池配置一个IP地址给容器。
•执行用户指定的应用程序。
•执行完毕后容器被终止。
docker run命令参数
-t 分配一个伪终端(pseudo-tty)并绑定到容器的标准输入上
-i 让容器的标准输入保持打开
-d 以后台守护进程(Daemonized)形式运行
在伪终端下可以使用ctrl + d或者输入exit命令来退出容器
docker logs 获得容器的输出信息
docker stop [-t|--time[=10]]用来终止一个运行中的容器,先向容器发送SIGTERM信号,等待一段时间(默认10秒),再发送SIGKILL信号终止容器
当Docker中指定的应用终结时,容器也会自动终止
docker kill 强行终止容器
docker ps -a -q查看终止状态的容器的ID
docker restart 重启某个容器
进入容器
docker attach ID|NAME 进入容器,但是当多个窗口同时attach到同一个容器时,所有窗口都会同步显示,当某个窗口命令阻塞时,其他窗口无法执行抄作
docker exec ID|NAME COMMAND doker1.3之后新加命令,可以直接在容器内运行命令,例如:docker exec -it 243c32535da7 /bin/bash
还有一种进入容器的方式是通过nsenter工具,使用
nsenter --target $PID --mount --uts --ipc --net --pid连接容器,需要知道容器的PID
PID可以通PID=$(docker inspect --format "{{ .State.Pid }}" <container>)获取
删除容器
docker rm [OPTIONS]CONTAINER[CONTAINER...] 命令删除处于终止状态的容器,支持的选项包括:
•-f,--force=false强行终止并删除一个运行中的容器。
•-l,--link=false删除容器的连接,但保留容器。
•-v,--volumes=false删除容器挂载的数据卷。
导出和导入容器
docker export CONTAINER > *.tar 导出容器
cat *.tar | docker import - NAME[:TAG] 导入容器
实际上,既可以使用docker load命令来导入镜像存储文件到本地的镜像库,又可以使用docker import命令来导入一个容器快照到本地镜像库。这两者的区别在于容器快照文件将丢弃所有的历史记录和元数据信息(即仅保存容器当时的快照状态),而镜像存储文件将保存完整记录,体积也要大。此外,从容器快照文件导入时可以重新指定标签等元数据信息。
简单的说容器是镜像的一个运行实例,所不同的是,它带有额外的可写文件层。如果认为虚拟机是模拟运行的一整套操作系统(提供了运行态环境和其他系统环境)和跑在上面的应用。那么Docker容器就是独立运行的一个或一组应用,以及它们的必需运行环境。
docker create -it ubuntu:last 创建一个容器,创建的容器处于停止状态
docker start ID|NAME[:TAG] 启动一个停止的容器
docker run NAME[:TAG] COMMAND 创建并启动一个容器
当利用docker run来创建并启动容器时,Docker在后台运行的标准操作包括:
•检查本地是否存在指定的镜像,不存在就从公有仓库下载。
•利用镜像创建并启动一个容器。
•分配一个文件系统,并在只读的镜像层外面挂载一层可读写层。
•从宿主主机配置的网桥接口中桥接一个虚拟接口到容器中去。
•从地址池配置一个IP地址给容器。
•执行用户指定的应用程序。
•执行完毕后容器被终止。
docker run命令参数
-t 分配一个伪终端(pseudo-tty)并绑定到容器的标准输入上
-i 让容器的标准输入保持打开
-d 以后台守护进程(Daemonized)形式运行
在伪终端下可以使用ctrl + d或者输入exit命令来退出容器
docker logs 获得容器的输出信息
docker stop [-t|--time[=10]]用来终止一个运行中的容器,先向容器发送SIGTERM信号,等待一段时间(默认10秒),再发送SIGKILL信号终止容器
当Docker中指定的应用终结时,容器也会自动终止
docker kill 强行终止容器
docker ps -a -q查看终止状态的容器的ID
docker restart 重启某个容器
进入容器
docker attach ID|NAME 进入容器,但是当多个窗口同时attach到同一个容器时,所有窗口都会同步显示,当某个窗口命令阻塞时,其他窗口无法执行抄作
docker exec ID|NAME COMMAND doker1.3之后新加命令,可以直接在容器内运行命令,例如:docker exec -it 243c32535da7 /bin/bash
还有一种进入容器的方式是通过nsenter工具,使用
nsenter --target $PID --mount --uts --ipc --net --pid连接容器,需要知道容器的PID
PID可以通PID=$(docker inspect --format "{{ .State.Pid }}" <container>)获取
删除容器
docker rm [OPTIONS]CONTAINER[CONTAINER...] 命令删除处于终止状态的容器,支持的选项包括:
•-f,--force=false强行终止并删除一个运行中的容器。
•-l,--link=false删除容器的连接,但保留容器。
•-v,--volumes=false删除容器挂载的数据卷。
导出和导入容器
docker export CONTAINER > *.tar 导出容器
cat *.tar | docker import - NAME[:TAG] 导入容器
实际上,既可以使用docker load命令来导入镜像存储文件到本地的镜像库,又可以使用docker import命令来导入一个容器快照到本地镜像库。这两者的区别在于容器快照文件将丢弃所有的历史记录和元数据信息(即仅保存容器当时的快照状态),而镜像存储文件将保存完整记录,体积也要大。此外,从容器快照文件导入时可以重新指定标签等元数据信息。
相关文章推荐
- docker 进入容器,及docker 的相关命令
- Docker容器相关命令
- 使用Docker网络相关的命令管理容器
- docker容器相关命令
- docker 容器相关命令
- docker 容器相关命令
- 如何打包创建镜像和运行Docker容器及常用命令
- docker中 启动所有的容器命令
- [置顶] Docker镜像与容器命令
- docker仓库相关命令
- docker 容器管理常用命令
- docker 容器命令
- Docker 快速上手系列(4): 数据卷,数据卷容器的概念及相关操作
- Docker整理之Docker运行容器相关(二)
- Docker入门-镜像、容器、仓库简单命令
- docker基础命令之容器篇
- Docker的容器创建以及基本命令
- 基础的 Docker 容器网络命令
- Docker容器操作中常用命令集合
- Docker 快速上手系列(2): 容器的概念及相关操作