镜像操作
列出docker下的所有镜像
docker images
/**
REPOSITORY:镜像所在的仓库名称
TAG:镜像标签
IMAGE ID:镜像ID
CREATED:镜像的创建日期(不是获取该镜像的日期)
SIZE:镜像大小
这些镜像都是存储在Docker宿主机的/var/lib/docker目录下
**/
搜索镜像
docker search 镜像名称
/**
NAME:仓库名称
DESCRIPTION:镜像描述
STARS:用户评价,反应一个镜像的受欢迎程度
OFFICIAL:是否官方
AUTOMATED:自动构建,表示该镜像由Docker Hub自动构建流程创建的
**/
拉取镜像
docker pull centos:7
删除镜像
docker rmi $IMAGE_ID //删除指定镜像
docker rmi `docker images -q`//删除所有镜像
容器操作
查看容器
docker ps //查看正在运行容器
docker ps –a //查看所有的容器(启动过的历史容器)
docker ps -l //查看最后一次运行的容器
docker ps -f status=exited //查看停止的容器
创建与启动容器
创建容器命令:docker run
创建容器常用的参数说明:
参数 | 说明 |
---|---|
-i | 表示运行容器 |
-t | 表示容器启动后会进入其命令行。加入这两个参数后,容器创建就能登录进去。即分配一个伪终端 |
--name | 为创建的容器命名 |
-v | 表示目录映射关系(前者是宿主机目录,后者是映射到宿主机上的目录),可以使用多个-v做多个目录或文件映射。注意:最好做目录映射,在宿主机上做修改,然后共享到容器上 |
-d | 在run后面加上-d参数,则会创建一个守护式容器在后台运行(这样创建容器后不会自动登录容器,如果只加-i -t两个参数,创建后就会自动进去容器) |
-p | 表示端口映射,前者是宿主机端口,后者是容器内的映射端口。可以使用多个-p做多个端口映射 |
创建交互式容器
举例创建centos容器并进入centos系统
docker run -it --name=mycentos centos:7 /bin/bash
/**
/bin/bash 只是针对centos才加的命令,不加无法进入命令行
:7 是指可能有很多centos镜像,7是先前PULL镜像时的打的TAG,这样就能指定创建哪个centos镜像了
**/
使用exit命令 退出当前容器
创建守护式容器
创建一个守护式容器:如果对于一个需要长期运行的容器来说,我们可以创建一个守护式容器。命令如下(容器名称不能重复)
docker run -di --name=mycentos2 centos:7
登录守护式容器方式
docker exec -it container_name (或者 container_id) /bin/bash(exit退出时,容器不会停止)
停止与启动容器
docker stop $CONTAINER_NAME/ID //停止正在运行的容器
docker start $CONTAINER_NAME/ID //启动已运行过的容器
文件拷贝
文件拷贝使用cp命令(这个不等同于linux的cp命令,是docker的cp命令),应用在把宿主机的文件或文件夹拷贝到容器里或者把容器里的文件或文件夹拷贝到宿主机
将文件拷贝到容器内
docker cp 需要拷贝的文件或目录 容器名称:容器目录
将文件从容器内拷贝出来
docker cp 容器名称:容器目录 需要拷贝的文件或目
目录挂载
我们可以在创建容器的时候,将宿主机的目录与容器内的目录进行映射,这样我们就可以通过修改宿主机某个目录的文件从而去影响容器
创建容器 添加-v参数 后边为 宿主机目录:容器目录
docker run -di -v /usr/local/myhtml:/usr/local/myhtml --name=mycentos3 centos:7
查看容器IP地址
docker inspect mycentos2 //查看容器运行的各种数据
docker inspect --format='{{.NetworkSettings.IPAddress}}' mycentos2 //直接输出IP地址
删除容器
删除指定的容器:docker rm $CONTAINER_ID/NAME
注意,只能删除停止的容器