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

原创文章,欢迎转载。转载请注明:转载自IT人故事会,谢谢!
原文链接地址:「走进k8s」Docker 基本命令(二)

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

(一)镜像

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

  • ①获取镜像

docker pull [选项] [Docker Registry 地址[:端口]/]仓库名[:标签]
Docker 镜像仓库地址:地址的格式一般是 <域名/IP>[:端口号],默认地址是 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并不复杂,原理还是很重要的。

你可能感兴趣的:(「走进k8s」Docker 基本命令(二))