github编辑

3.5 Raspberry Pi

树莓派等 ARM 架构设备在物联网和边缘计算领域应用广泛。本节介绍如何在树莓派上安装 Docker。

警告:切勿在没有配置 Docker APT 源的情况下直接使用 apt 命令安装 Docker。

3.5.1 系统要求

Docker 对 ARM 架构有着良好的支持。

Docker 不仅支持 x86_64 架构的计算机,同时也支持 ARM 架构的计算机,本小节内容以树莓派单片电脑为例讲解 ARM 架构安装 Docker。

Docker 支持以下版本的 Raspberry Pi OSarrow-up-right 操作系统:

  • Raspberry Pi OS Trixie

  • Raspberry Pi OS Bookworm

  • Raspberry Pi OS Bullseye

注:Raspberry Pi OS 由树莓派的开发与维护机构树莓派基金会arrow-up-right官方支持,并推荐用作树莓派的首选系统,其基于 Debian

3.5.2 使用 APT 安装

推荐使用 APT 包管理器进行安装,以确保版本的稳定性和安全性。

由于 apt 源使用 HTTPS 以确保软件下载过程中不被篡改。因此,我们首先需要添加使用 HTTPS 传输的软件包以及 CA 证书。

$ sudo apt-get update

$ sudo apt-get install \
     apt-transport-https \
     ca-certificates \
     curl \
     gnupg \
     lsb-release

鉴于国内网络问题,强烈建议使用国内源,官方源请在注释中查看。

为了确认所下载软件包的合法性,需要添加软件源的 GPG 密钥。

然后,我们需要向 sources.list 中添加 Docker 软件源:

以上命令会添加稳定版本的 Docker APT 源,如果需要测试版本的 Docker 请将 stable 改为 test。

报错解决办法

Raspberry Pi OS Bullseye/Bookworm 中,如果你使用 add-apt-repository 添加源,可能会出现如下报错 (推荐改用上面的 tee 方式来写入 /etc/apt/sources.list.d/docker.list,可避免此问题):

通过以下命令手动添加镜像源到 /etc/apt/sources.list 文件中即可解决:

安装 Docker

更新 apt 软件包缓存,并安装 docker-ce

3.5.3 使用脚本自动安装

在测试或开发环境中 Docker 官方为了简化安装流程,提供了一套便捷的安装脚本,Raspberry Pi OS 系统上可以使用这套脚本安装,另外可以通过 --mirror 选项使用国内源进行安装:

若你想安装测试版的 Docker,请从 test.docker.com 获取脚本

执行这个命令后,脚本就会自动的将一切准备工作做好,并且把 Docker 的稳定 (stable) 版本安装在系统中。

3.5.4 启动 Docker

3.5.5 建立 docker 用户组

默认情况下,docker 命令会使用 Unix socketarrow-up-right 与 Docker 引擎通讯。而只有 root 用户和 docker 组的用户才可以访问 Docker 引擎的 Unix socket。出于安全考虑,一般 Linux 系统上不会直接使用 root 用户。因此,更好的做法是将需要使用 docker 的用户加入 docker 用户组。

⚠️ 安全警告:docker 用户组等同于 root 权限

将用户加入 docker 组免去了每次执行 docker 命令时输入 sudo 的繁琐,但这也意味着该用户可以轻易获取主机的最高 root 权限(例如通过挂载根目录运行容器)。 如果你在一个多用户共享的生产系统上配置,切勿随意将普通用户加入此组。此时,更安全的替代方案是使用官方提供的 Rootless 模式 (Rootless mode)arrow-up-right,它允许在没有任何 root 权限的情况下运行 Docker 守护进程和容器。

建立 docker 组:

将当前用户加入 docker 组:

退出当前终端并重新登录,进行如下测试。

3.5.6 测试 Docker 是否安装正确

若能正常输出以上信息,则说明安装成功。

*注意:*ARM 平台不能使用 x86 镜像,查看 Raspberry Pi OS 可使用镜像请访问 arm32v7arrow-up-right 或者 arm64v8arrow-up-right

3.5.7 镜像加速

如果在使用过程中发现拉取 Docker 镜像十分缓慢,可以配置 Docker 国内镜像加速

最后更新于