docker学习(6)——容器创建、运行、停止

1、创建容器

docker create <image-id>/<image-name>

docker create 命令为指定的镜像(image)添加了一个可读写层,构成了一个新的容器。注意,这个容器并没有运行。

docker create 命令提供了许多参数选项可以指定名字,硬件资源,网络配置等等。

例:docker create -it httpd bash

2、启动容器

docker start <container-id>/<container-name>

Docker start命令为容器文件系统创建了一个进程隔离空间。注意,每一个容器只能够有一个进程隔离空间。

例:docker start c9712b3540ab

3、进入容器

docker exec <container-id>/<container-name>

在当前容器中执行新命令,如果增加 -it参数运行bash 就和登录到容器效果一样的。

例:docker exec -it c9712b3540ab bash

错误:Error response from daemon: Container a85e3457bf1bf05b3bb6d09c878d5bf10d300897ca8d94e1e4e8a31776a44dae is not running

原因:必须先运行容易,所以需要先执行docker run命令,exit后,执行docker start,再执行docker exec。

如果docker  create 的时候没有带bash等命令,start会不起作用。

4、停止容器

docker stop <container-id>

例:docker stop c9712b3540ab

5、删除容器

docker rm  <container-id>

例:docker rm c9712b3540ab

6、运行容器

docker run <image-id>

docker run就是docker create和docker start两个命令的组合,支持参数也是一致的,如果指定容器
名字是,容器已经存在会报错,可以增加 --rm 参数实现容器退出时自动删除。

例:

docker run -it --rm --name centos6.7 192ad0341c8b

docker create -it --rm --name centos6_container centos:6.7

7、查看容器列表

docker ps

docker ps 命令会列出所有运行中的容器。这隐藏了非运行态容器的存在,如果想要找出这些容器,增加 -a 参数

例: docker ps -a

8、删除镜像

docker rmi <image-id>

删除构成镜像的一个只读层。你只能够使用docker rmi来移除最顶层(top level layer)
(也可以说是镜像),你也可以使用-f参数来强制删除中间的只读层。

例: docker rmi joker/centos:dev

9、commit容器

docker commit <container-id>

将容器的可读写层转换为一个只读层,这样就把一个容器转换成了不可变的镜像。

例: docker commit -m="nothing to do" -a="joker" aab61e5455e5 cavein/centos6:6.7

10、镜像保存

docker save <image-id>

创建一个镜像的压缩文件,这个文件能够在另外一个主机的Docker上使用。和export命令不同,这个命令
为每一个层都保存了它们的元数据。这个命令只能对镜像生效。

例: docker save -o ubuntu_images.tar ubuntu:16.04

11、容器导出

docker export  <container-id>

创建一个tar文件,并且移除了元数据和不必要的层,将多个层整合成了一个层,只保存了当前统一视角看到
的内容。expoxt后的容器再import到Docker中,只有一个容器当前状态的镜像;而save后的镜像则不同,
它能够看到这个镜像的历史镜像。

例: docker export -o 2019-01-08.tar ce8a7ab57576

12、import

docker import : 从归档文件中创建镜像

例:docker import 2019-01-08.tar joker/my_ubuntu:v4
 

13、inspect

docker inspect <container-id> or <image-id>

docker inspect命令会提取出容器或者镜像最顶层的元数据

例:docker inspect ce8a7ab57576

#查看容器ce8a7ab57576的ip

 docker inspect --format='{{range .NetworkSettings.Networks}}{{.IPAddress}}{{end}}' ce8a7ab57576

ps:本文中image-id 和 image-name:tag 效果基本一样,container-id 和 container-name 效果基本一样

参考 http://www.cnblogs.com/SzeCheng/p/6822905.html

猜你喜欢

转载自blog.csdn.net/Man_In_The_Night/article/details/86062492