Docker安装(Ubuntu22.04)-apt安装

本文详细介绍了如何在新主机上设置Docker的apt存储库,包括安装必要的依赖、添加GPG密钥、配置Apt源列表,以及后续的Docker软件包安装和验证步骤。同时,也讲述了如何让非root用户安全地管理和使用Docker。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

使用 apt 存储库安装

在新主机上首次安装 Docker Engine 之前,需要设置 Docker 存储库。之后,可以从存储库安装和更新 Docker。

1. 设置 Docker 的apt存储库。
sudo apt-get update
sudo apt-get install ca-certificates curl
sudo install -m 0755 -d /etc/apt/keyrings
sudo curl -fsSL https://download.docker.com/linux/ubuntu/gpg -o /etc/apt/keyrings/docker.asc
sudo chmod a+r /etc/apt/keyrings/docker.asc

echo \
  "deb [arch=$(dpkg --print-architecture) signed-by=/etc/apt/keyrings/docker.asc] 					        https://download.docker.com/linux/ubuntu \
   $(. /etc/os-release && echo "$VERSION_CODENAME") stable" | \
   sudo tee /etc/apt/sources.list.d/docker.list > /dev/null
sudo apt-get update
  • sudo apt-get update:

    • 更新系统的软件包列表,以确保系统可以访问最新的软件包。
  • sudo apt-get install ca-certificates curl:

    • 安装两个软件包:
      • ca-certificates:用于验证服务器的数字证书,确保连接的安全性。
      • curl:一个用于传输数据的命令行工具。
  • sudo install -m 0755 -d /etc/apt/keyrings:

    • 创建目录 /etc/apt/keyrings,权限为 0755。
    • 目录的拥有者可以读取、写入和执行,其他用户只能读取和执行。
  • sudo curl -fsSL https://download.docker.com/linux/ubuntu/gpg -o /etc/apt/keyrings/docker.asc:

    • 使用 curl 命令从 Docker 官方网站下载 GPG 公钥文件。
    • 将文件保存到 /etc/apt/keyrings/docker.asc
  • sudo chmod a+r /etc/apt/keyrings/docker.asc:

    • 将文件 /etc/apt/keyrings/docker.asc 的权限设置为所有用户都可以读取。
  • echo "deb [arch=$(dpkg --print-architecture) signed-by=/etc/apt/keyrings/docker.asc] https://download.docker.com/linux/ubuntu $(. /etc/os-release && echo "$VERSION_CODENAME") stable" | sudo tee /etc/apt/sources.list.d/docker.list > /dev/null

    • 使用 echo 命令创建 Docker 的 Apt 源列表。
    • 使用 dpkg --print-architecture 确定系统架构。
    • 使用 signed-by=/etc/apt/keyrings/docker.asc 指定 GPG 公钥文件的路径。
    • 使用 . /etc/os-release && echo "$VERSION_CODENAME" 确定当前系统版本代号。
    • 使用 sudo tee /etc/apt/sources.list.d/docker.list > /dev/null 将 Apt 源列表写入文件 /etc/apt/sources.list.d/docker.list,并将标准输出重定向到 /dev/null 以隐藏命令行输出。
  • sudo apt-get update:

    • 更新系统的软件包列表,以确保添加的 Docker 源生效。
2. 安装 Docker 软件包。

安装最新版本:

sudo apt-get install docker-ce docker-ce-cli containerd.io docker-buildx-plugin docker-compose-plugin
3. 通过运行镜像来验证Docker Engine安装是否成功 hello-world
sudo docker run hello-world
4. 以非 root 用户身份管理 Docker

Docker 守护进程绑定到 Unix 套接字,而不是 TCP 端口。默认情况下,该 root用户拥有 Unix 套接字,其他用户只能使用 sudo. Docker 守护进程始终以root用户身份运行。

如果不想docker在命令前面加上sudo,可以创建一个名为docker的 Unix 组并向其中添加用户。当 Docker 守护进程启动时,它会创建一个可由组成员访问的 Unix 套接字docker。在某些 Linux 发行版上,系统在使用包管理器安装 Docker Engine 时会自动创建该组。在这种情况下,就无需手动创建组。

  • 创建docker群组。
sudo groupadd docker
  • 将您的用户添加到docker组中。
sudo usermod -aG docker $USER
  • 激活对组的更改:
newgrp docker
  • 验证是否可以不用sudo执行docker
docker run hello-world

此命令下载测试镜像并在容器中运行它。当容器运行时,它会打印一条消息并退出。

如果在将用户添加到组之前运行 Docker CLI 命令docker,可能会看到以下错误:

WARNING: Error loading config file: /home/user/.docker/config.json -stat /home/user/.docker/config.json: permission denied

此错误表明由于之前使用过该命令,该目录的权限设置不正确。
要解决此问题,删除~/.docker/目录(它会自动重新创建,但所有自定义设置都会丢失),或者使用以下命令更改其所有权和权限:

sudo chown "$USER":"$USER" /home/"$USER"/.docker -R
sudo chmod g+rwx "$HOME/.docker" -R
<think>好的,用户想通过Docker安装Ubuntu 22.04镜像。让我先回忆一下相关的Docker命令和步骤。根据提供的引用内容,有几个步骤需要确认。首先,用户需要搜索Ubuntu的镜像,然后拉取特定版本。不过用户提到的是20.04,但引用里都是关于22.04安装,可能需要调整。不过用户现在的问题是如何安装22.04,所以引用里的步骤应该适用。 首先,用户可能需要安装Docker引擎,这是前提条件。根据引用[2],安装Docker Engine的步骤可以参考官方文档,比如更新apt包索引,安装必要的依赖,添加Docker的仓库,然后安装Docker。这部分是否需要详细说明呢?用户可能已经安装Docker,但为了全面,可能需要简要提及。 然后,按照引用[1]的步骤,搜索Ubuntu镜像,但docker search ubuntu可能只会列出最新版本或者其他标签,所以更好的方法是直接拉取指定标签的镜像,比如ubuntu:22.04。用户需要知道如何拉取正确的版本。 接下来,创建并启动容器时,需要注意端口映射和卷挂载。引用[1]和[4]提到使用-p参数映射端口,比如2060:22,这样可以通过SSH连接。同时,-v参数挂载目录,方便宿主机和容器之间共享文件。此外,启动容器时需要进入bash,以便配置SSH或其他服务。 用户可能还需要在容器安装SSH服务,以便远程访问,这部分引用里提到启动容器后需要安装和配置SSH。比如,更新包列表,安装openssh-server,修改SSH配置允许root登录,设置密码,然后启动服务。这样才能通过宿主机的端口访问容器。 另外,关于持久化容器的问题,使用docker run命令加上-it参数会以交互模式启动,但如果退出,容器会停止。所以可能需要使用-d参数在后台运行,然后通过exec进入容器进行操作。不过引用中的例子没有使用-d,可能需要提醒用户这一点,或者根据需求调整命令。 最后,验证部分需要确认容器是否运行,以及端口是否正确映射。用户可能需要执行docker ps查看运行中的容器,然后尝试SSH连接。如果有问题,可能需要检查防火墙设置或者端口冲突。 总结步骤应该是:安装Docker -> 拉取Ubuntu 22.04镜像 -> 创建并启动容器,配置端口和卷 -> 进入容器安装必要服务 -> 验证访问。同时,用户的问题可能还涉及到如何持久化配置,比如保存容器为镜像,或者使用Dockerfile构建自定义镜像,但引用中没有提到这些,所以可能需要保持步骤简单,按照引用内容来指导。</think>### 通过 Docker 安装 Ubuntu 22.04 镜像的步骤 #### 1. **安装 Docker 引擎** 在操作前,请确保系统已安装 Docker 引擎。若未安装,可参考以下步骤(以 Ubuntu 系统为例): ```bash sudo apt update sudo apt install docker.io sudo systemctl enable --now docker ``` 或根据官方文档安装最新版本[^2]。 #### 2. **拉取 Ubuntu 22.04 镜像** 通过以下命令搜索并拉取官方镜像: ```bash docker search ubuntu # 查看可用镜像(可选) docker pull ubuntu:22.04 # 明确指定 22.04 版本 docker images # 确认镜像已下载[^1][^4] ``` #### 3. **创建并启动容器** 使用以下命令创建容器,并配置端口映射与目录挂载: ```bash docker run --name ubuntu22.04 -it -p 2060:22 -v /宿主机目录:/容器目录 ubuntu:22.04 bash ``` - `--name ubuntu22.04`:指定容器名称[^4] - `-p 2060:22`:将宿主机的 2060 端口映射到容器22 端口(SSH 服务)[^1][^3] - `-v /宿主机目录:/容器目录`:挂载目录以实现数据持久化 #### 4. **配置容器环境** 进入容器后,需初始化环境: 1. **更新软件包并安装必要工具**: ```bash apt update && apt upgrade -y apt install openssh-server vim -y ``` 2. **配置 SSH 服务**: - 修改 `/etc/ssh/sshd_config`,添加 `PermitRootLogin yes` - 设置 root 密码:`passwd root` - 启动 SSH 服务:`service ssh start` #### 5. **验证远程访问** 退出容器后,通过宿主机 IP 和映射端口连接: ```bash ssh root@宿主机IP -p 2060 ``` #### 6. **管理容器生命周期** - 停止容器:`docker stop ubuntu22.04` - 启动已停止的容器:`docker start -ai ubuntu22.04` - 删除容器:`docker rm ubuntu22.04` ### 注意事项 - 若需长期运行容器,建议添加 `-d` 参数以守护进程模式启动 - 可通过 `docker commit` 将配置好的容器保存为新镜像 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值