「走进k8s」Docker 基本命令(二)

上次说了简单的介绍了docker,基本的概念和架构,并实际操作了如何安装docker。这次就说说Docker 镜像和容器的基本操作命令。

(一)镜像

了解git的老铁都知道有github,其实docker也有个官方的镜像仓库叫dockerhub。

https://hub.docker.com/

  • ①获取镜像

    > docker pull [选项] [Docker Registry 地址[:端口]/]仓库名[:标签]

    > Docker 镜像仓库地址:地址的格式一般是 [:端口号],默认地址是 Docker Hub。

    > 在library的镜像也就是官方镜像需要:名称

    > 如果是个人的镜像需要:用户名/软件名

docker pull redis:4.0

  • ②镜像列表

    > 仓库名称,标签,镜像 ID、创建时间,镜像大小。镜像ID是唯一标识。

docker image ls

官网redis大小:40MB,但是下载到本地后是102MB。压缩后的体积。在镜像下载和上传过程中镜像是保持着压缩状态的,因此 Docker Hub 所显示的大小是网络传输中更关心的流量大小。

  • ③镜像层次

    > 我们可以使用history命令来看看,可以发现redis包含很多个镜像层。Docker的镜像的基础是联合文件系统,它支持将文件系统中的修改信息作为一次提交,并层层叠加,外界看到的是最外层的镜像。(比如外界只看到Tomcat镜像,而中间叠加了很多层镜像)

#刚才那个镜像ID
docker image 67f7ad418fdf

  • ④删除镜像

    > 删除本地的镜像

docker image rm  镜像名:版本号

docker rmi  镜像ID

  • ⑤镜像迁移

    > 场景:之前博客是通过容器的方式来进行的后来从华为云迁移到了阿里云,需要将容器打包成镜像,然后在将镜像打包成文件。将文件拷贝到另一台阿里云的机器上。

打包

docker save 镜像名称 | gzip > alpine-latest.tar.gz

到阿里云机器后将打包文件转换成镜像

docker load -i alpine-latest.tar.gz

(二)容器

  • ①创建容器

    > -it:这是两个参数,一个是 -i:交互式操作,一个是 -t 终端。我们这里打算进入 bash 执行一些命令并查看返回结果,因此我们需要交互式终端。

    > centos:7:这是指用 ubuntu:16.04 镜像为基础来启动容器。

    > /bin/bash:放在镜像名后的是命令,这里我们希望有个交互式 Shell,因此用的是 bash

    > name:容器指定一个名称

    > p :端口映射(-p 80:80)80端口映射到外部的80端口上,前一个是映射,后一个容器内的端口

    > [root@5cd9daf8961b /] 开启的容器终端,exit退出后状态就变成status (Exited 状态)

    > –restart=always 无论容器退出代码是什么,docker 都会自动重启容器。

    限制重启次数:–restart=on-failure:5 ,当容器退出代码不为0时,最多重启5次。这个很有用,我自己的博客服务器经常流量大了就挂了,有了这个命令挂了一会就自动重启了,不用半夜在给我发邮件了。这只是在我的场景下比较合适的方式。在实际生产中还是使用容器编排工具比较好。

docker run -it centos:7 /bin/bash
exit

启动一个后台运行的,如果不加入后台运行的,容器退出后,容器就关闭了

加入-d 后台运行,status (up 状态)

docker run -it -d centos:7 /bin/bash

  • ②容器列表

    > 如果不加-all,显示正常运行的容器,如果加-all显示所有的容器

docker container ls -all

  • ③进入容器

    > 存在可能修改容器内部的参数的情况,所以需要进入容器。

    > exec -it 开启交互进入容器中。

docker exec -it 容器ID /bin/bash

  • ④终止和启动容器

    > 在实际应用中有这种场景:更换springboot的容器的jar包,需要终止容器。更换完成后需要重新启动容器。

docker container stop 容器名称/容器ID
docker container start 容器名称/容器ID

  • ⑤容器日志

    > 查看容器日志

docker log -f 容器名称/容器ID

  • ⑥删除容器

    > 删除容器的操作

docker container rm  容器ID

批量删除容器,慎用

docker rm -f $(docker ps -qa)
  • ⑦容器改变

    > 容器内发生的改变

docker diff  容器ID

  • ⑧容器变成镜像

    > 就是在原有镜像的基础上,再叠加上容器的存储层,并构成新的镜像。

–author:指定修改的作者

–message:记录本次修改的内容

docker commit 命令除了学习之外,还有一些特殊的应用场合,比如被入侵后保存现场等。但是,不要使用 docker commit 定制镜像,定制镜像应该使用Dockerfile来完成。

不规范的镜像不是docker推荐的。

docker commit --author 'www.idig8.com' --message '修改打包成镜像' 镜像ID 名称:版本号

(三)总体信息查看

多少个镜像,多少个容器,多少个外部,建立了多少个缓存

docker system df

PS:基本容器和镜像的常用命令都给老铁们说了,如果你会git或者linux命令比较熟悉docker并不复杂,原理还是很重要的。

>>原创文章,欢迎转载。转载请注明:转载自,谢谢!>>原文链接地址:上一篇:

已是最新文章