镜像
1.获取镜像
如果不指定TAG,则下载最新版本,默认选择latest标签
docker pull ubuntu:18.04
docker pull ubuntu
下载非官方镜像
docker pull hub.c.163.com/public/ubuntu:18.04
2.查看镜像
列出镜像
docker images 或 docker image ls
tag添加镜像标签
docker tag ubuntu:latest myubuntu:latest
inspect查看详细信息
docker inspect ubuntu:18.04
history查看镜像历史
docker history ubuntu:18.04
3.搜寻镜像
docker search [option] keyword
-f ,–filter filter:过滤输出内容
–format string:格式化输出内容
–limit int:限制输入结果个数,默认为25个
–no-trunc:不截断输出结果
搜索带nginx关键词的镜像
docker search --filter=is-official=true nginx
搜索收藏数超过4的关键词包括tensorflow镜像
docker search --filter=stars=4 tensorflow
4.删除和清理镜像
使用标签删除镜像
docker rmi 或 docker image rm
docker rmi myubuntu:latest
使用镜像ID删除镜像
docker rmi id(12位)
-
当该镜像创建的容器存在时,镜像文件默认是无法删除的,需先删除依赖镜像的所有容器,然后再删除镜像
==> 使用 docker ps -a 查看已关联使用的容器,然后使用 docker rm ID 删除容器
清理镜像
长时间使用会产生临时文件
docker image prune -f
-a ,-all:删除所有无用镜像,不光是临时镜像
-filter filter:只清理符合给定过滤器的镜像
-f, -force:强制删除镜像,而不进行提示确认
5.创建镜像
基于已有容器创建
docker commit [OPTIONS] CONTAINER [REPOSITORY[:TAG]]
1) 首先先启动一个镜像
>> docker run it ubuntu:18.04 /bin/bash
49d5d4e7b3f6 >> touch test
49d5d4e7b3f6 >> exit
记住容器的ID为:49d5d4e7b3f6
2)创建提交一个新的镜像
docker commit -m “Added a new file” -a “testdocker” 49d5d4e7b3f6 test:0.1
-a , --author="": 作者信息;
-c, --change=[]: 提交的时候执行Dockerfile指令,包括CMD|ENTRYPOINT|ENV|EXPOSE|LABEL|ONBUILD|USER|VOLUME|WORKDIR等
-m, --message="": 提交信息;
-p, --pause=true: 提交时暂停容器运行
基于Dockerfile创建
docker build
6.存出和载入镜像
存出镜像 - 镜像导出
docker save
docker save -o ubuntu_18.04.tar ubuntu:18.04
载入镜像 - 镜像导入
docker load
docker load -i ubuntu_18.04.tar
7.上传镜像
push上传至docker hub
1)先登录,输入注册的用户名和密码
docker login
2)然后使用push命令上传,username为你注册的名称
docker push username/xxxx:xx
容器
1.创建容器
新建容器 + 启动
1)新建容器
docker create -it ubuntu:latest
2)启动容器
docker start xxx
新建并启动 = 新建+启动
docker run ubuntu /bin/echo 'Hello world’
允许用户进行交互
docker run -it ubuntu:18.04 /bin/bash
后台运行
docker run -d ubuntu /bin/sh -c ‘while true; do echo hello world; sleep 1; done’
容器输出
docker logs ID
2.停止容器
暂停容器、恢复暂停
docker pause test
docker unpause test
终止容器、重新启动
docker stop ID
docker start ID
docker restart ID
3.进入容器
exec命令
docker exec -it ID /bin/bash
-d, --detach: 在容器中后台执行命令 ;
–detach-key="": 指定将容器切回后台的按键 ;
-e, --env=[]: 指定环境变量列表 ;
-i, --interactive=true|false: 打开标准输入接受用户输入命令,默认值为 false ;
–privileged=true|false: 是否给执行命令以高权限,默认值为 false ;
-t, --tty=true|false: 分配伪终端,默认值为 false ;
-u, --user="": 执行命令的用户名或ID。
4.删除容器
rm命令
docker rm ID
-f, --force=false: 是否强制终止并删除一个运行中的容器 ;
-l, --link=false: 删除容器的连接,但保留容器 ;
-v, --volumes=false: 删除容器挂载的数据卷 。
5.导入和导出容器
导出 export
docker export -o XXX.tar ID
导入 import
docker import XXX.tar test/ubuntu:v1.0
-
docker load => 镜像存储文件到本地镜像库
docker import => 容器快照到本地镜像库
区别:容器快照文件将丢弃所有的历史记录和元数据信息,但可以重新制定标签等元数据信息,而镜像存储文件将保存完整记录,体积更大。
6.查看容器
查看容器详细,会以JSON格式返回
docker container inspect ID
查看容器内进程
docker top ID
7.其他容器命令
复制文件
将本地路径 data 复制到 test 容器的 /tmp 路径下:
docker cp data ID:/tmp/
查看变更
docker container diff ID
查看端口映射
docker container port ID
更新配置
docker update 参数 ID
仓库
1.搭建本地私有仓库
使用 registry 镜像创建私有仓库
docker run -d -p 5000:5000 registry:2