docker - 使用 Docker Hub 中的镜像
  猿来如此 2023年07月12日 419 0

自己编写 Dockerfile 能够很好的实现想要的程序运行环境,不过如果装有想要环境的镜像已经由热心的开发者构建好并共享在 Docker Hub 上,直接使用就会远比自己编写 Dockerfile 并进行构建要来的简单的多了。事实上,在开发过程中用到的镜像大部分还是直接采用 Docker Hub 中已经存在的镜像的,即使自己编写 Dockerfile,也只是对已有镜像进行简单的改动,很少会从零开始搭建镜像。

选择镜像与程序版本

由于 Docker 的容器设计是程序即容器的,所以组成服务系统的多个程序一般会搭建在多个容器里,互相之间协作提供服务。例如一套最简单的 Web 服务,可能会需要 Java 容器来运行基于 Spring Boot 的程序,需要 MySQL 容器来提供数据库支持,需要 Redis 容器来作为高速 KV 存储等等。装有这些程序的镜像都可以很容易的在 Docker Hub 上找到并直接使用,但在使用前,光选择镜像还是不够的,还得根据需要选择对应程序版本的镜像。

虽然常把软件的版本放在 Tag 里作为镜像名的一部分,但对于一些复杂的应用,除了版本外,还存在很多的变量,镜像的维护者们也喜欢将这些变量一同组合到镜像的 Tag 里,所以在使用镜像前,一定要先了解不同 Tag 对应的不同内容。

通常来说,镜像的维护者会在镜像介绍中展示出镜像所有的 Tag,如果没有,也能够从页面上的 Tags 导航里进入到镜像标签列表页面。

在 OpenJDK 镜像的 Tag 列表里,可以看到同样版本号的镜像就存在多种标签。在这些不同的标签上,除了定义 OpenJDK 的版本,还有操作系统,软件提供者等信息。

镜像维护者为提供这么多的标签进行选择,其实方便了在不同场景下选择不同环境实现细节时,都能直接用到这个镜像,而不需要再单独编写 Dockerfile 并构建。

但是换句话说,正是有这么多不同标签的镜像存在,所以在选择的时候,更要仔细认真,找到想要的那个镜像。

Alpine 镜像

如果多接触几个镜像,就会发现带有 Alpine 的版本是许多镜像中都常见的标签。带有 Alpine 标签的镜像到底是什么样的存在呢?它与相同软件不同标签的镜像又有什么样的区别呢?

镜像标签中的 Alpine 其实指的是这个镜像内的文件系统内容,是基于 Alpine Linux 这个操作系统的。Alpine Linux 是一个相当精简的操作系统,而基于它的 Docker 镜像可以仅有数 MB 的尺寸。如果软件基于这样的系统镜像之上构建而得,可以想象新的镜像也是十分小巧的。

在 Docker 里,Alpine 系统的镜像到底有多小,不妨来与其他系统镜像做一个比较。

操作系统镜像

占用空间

alpine:latest

4.4 MB

ubuntu:latest

84.1 MB

debian:latest

101 MB

centos:latest

200 MB

可以看到,Alpine 系统镜像的尺寸要远小于其他常见的系统镜像。让再来比较同一个软件在基于普通系统的镜像和基于 Alpine 系统的镜像后尺寸上的区别。

镜像标签

占用空间

python:3.6-alpine

74.2 MB

python:3.6-jessie

697 MB

由于基于 Alpine 系统建立的软件镜像远远小于基于其他系统的软件镜像,它在网络传输上的优势尤为明显。如果选择这类的镜像,不但可以节约网络传输的时间,也能减少镜像对硬盘空间的占用。

当然,有优点也会有缺点,Alpine 镜像的缺点就在于它实在过于精简,以至于麻雀虽小,也无法做到五脏俱全了。在 Alpine 中缺少很多常见的工具和类库,以至于如果想基于软件 Alpine 标签的镜像进行二次构建,那搭建的过程会相当烦琐。所以如果你想要对软件镜像进行改造,并基于其构建新的镜像,那么 Alpine 镜像不是一个很好的选择 (这时候更提倡基于 Ubuntu、Debian、CentOS 这类相对完整的系统镜像来构建)。

对容器进行配置

除了合理选择镜像外,许多镜像还为提供了更加方便的功能,这些细节通常都可以在镜像的详情里阅读到。

这里以 MySQL 为例,看看通常是怎样阅读和使用镜像的特殊功能的。

自己安装过 MySQL 的朋友一定知道,搭建 MySQL 最麻烦的地方并不是安装的过程,而是安装后进行初始化配置的过程。就拿更改 root 账号的密码来说,在初始的 MySQL 里就要耗费不少工作量。

如果拿到一个 MySQL 镜像,运行起来的 MySQL 也就约等于一个刚刚安装好的程序,面临的正好是复杂的初始化过程。

好在 MySQL 镜像的维护者们为打造了一些自动化脚本,通过它们,只需要简单的传入几个参数,就能够快速实现对 MySQL 数据库的初始化。

在 MySQL 镜像的详情里,描述了要如何传入这些参数来启动 MySQL 容器。

对于 MySQL 镜像来说,进行软件配置的方法是通过环境变量的方式来实现的 ( 在其他的镜像里,还有通过启动命令、挂载等方式来实现的 )。只需要通过这些给出的环境变量,就可以初始化 MySQL 的配置了。

例如,可以通过下面的命令来直接建立 MySQL 中的用户和数据库。

$ sudo docker run --name mysql -e MYSQL_DATABASE=webapp -e MYSQL_USER=www -e MYSQL_PASSWORD=my-secret-pw -d mysql:5.7

通过这条命令启动的 MySQL 容器,在内部就已经完成了用户的创建和数据库的创建,通过 MySQL 客户端就能够直接登录这个用户和访问对应的数据库了。

共享自己的镜像

如果希望将镜像公开给网络上的开发者们,那通过 Docker Hub 无疑是最佳的方式。

要在 Docker Hub 上共享镜像,必须有一个 Docker Hub 的账号,这自不必说了。在登录到账号的控制面板后,能够找到创建的按钮,在这里选择 Create Automated Build ( 创建自动构建 )。

最后一次编辑于 2023年07月12日 0

暂无评论