Ubuntu 安装 Docker 超详细教程(含配置镜像加速与常见命令)

目录

一、前言

二、Docker 的安装 (Ubuntu)

1. 卸载旧版本(可选)

2. 配置 Docker 的 APT 仓库

3. 安装 Docker

4. 启动和校验

三、配置镜像加速(强烈建议!)

1. 编辑 daemon.json 配置文件

2. 重新加载配置并重启 Docker

四、Docker 常见指令

1. Docker 服务相关命令 (systemctl)

2. 镜像相关命令

3. 容器相关命令

docker run 常见参数详解:

其他容器命令:

五、总结


一、前言

Docker 已经成为现代软件开发、测试和部署的基石。它通过容器化技术,让应用及其依赖可以打包在一起,在任何环境中以一致的方式运行。对于开发者(尤其是像我们Java后端的)来说,无论是部署微服务、搭建测试环境(如 MySQL, Redis, Nacos),还是实现 CI/CD,Docker 都是必备技能。

这篇博客是我在 Ubuntu 系统上安装和使用 Docker 的个人笔记,涵盖了安装、配置和常用命令,希望能帮助大家少走弯路。

二、Docker 的安装 (Ubuntu)

我们的安装步骤将使用阿里云的镜像源,这可以大大提高安装速度。

1. 卸载旧版本(可选)

如果你的系统之前安装过旧的 Docker 版本,建议先执行卸载:

# 执行以下命令卸载可能存在的旧版本 sudo apt-get remove docker docker-engine docker.io containerd runc 

2. 配置 Docker 的 APT 仓库

我们需要添加 Docker 官方的 GPG 密钥(用于验证软件包)并设置 APT 软件源。

# 1. 更新apt包索引并安装依赖,以允许apt通过HTTPS使用仓库 sudo apt-get update sudo apt-get install -y ca-certificates curl # 2. 添加Docker的官方GPG密钥(使用阿里云镜像加速) sudo install -m 0755 -d /etc/apt/keyrings sudo curl -fsSL https://mirrors.aliyun.com/docker-ce/linux/ubuntu/gpg -o /etc/apt/keyrings/docker.asc sudo chmod a+r /etc/apt/keyrings/docker.asc # 3. 设置Docker的APT软件源(同样使用阿里云镜像) echo \ "deb [arch=$(dpkg --print-architecture) signed-by=/etc/apt/keyrings/docker.asc] https://mirrors.aliyun.com/docker-ce/linux/ubuntu \ $(. /etc/os-release && echo "$VERSION_CODENAME") stable" | \ sudo tee /etc/apt/sources.list.d/docker.list > /dev/null # 4. 更新apt包索引,建立缓存 sudo apt-get update 

3. 安装 Docker

配置好软件源后,我们就可以执行安装了:

# 执行命令,安装Docker CE(社区版)相关组件 sudo apt-get install -y docker-ce docker-ce-cli containerd.io docker-buildx-plugin docker-compose-plugin 

4. 启动和校验

安装完成后,启动 Docker 并设置为开机自启。

# 启动Docker sudo systemctl start docker # 设置开机自启 sudo systemctl enable docker # 校验安装启动是否成功(不报错即可) sudo docker ps 

当你看到 docker ps 命令成功输出(即使是空的列表),说明 Docker 已经安装并成功运行了。

三、配置镜像加速(强烈建议!)

在国内直接从 Docker Hub(官方库)拉取镜像(docker pull)时,速度会非常慢,甚至经常失败。因此,配置国内的镜像加速器是必须的步骤。

1. 编辑 daemon.json 配置文件

我们需要创建或编辑 /etc/docker/daemon.json 文件。这里我们使用 tee 命令直接写入内容,比 nanovim 更方便。(直接完整的复制粘贴即可)

# 使用tee命令将配置内容写入daemon.json文件 sudo tee /etc/docker/daemon.json <<-'EOF' { "registry-mirrors": [ "https://docker.registry.cyou", "https://docker-cf.registry.cyou", "https://dockercf.jsdelivr.fyi", "https://docker.jsdelivr.fyi", "https://dockertest.jsdelivr.fyi", "https://mirror.aliyuncs.com", "https://dockerproxy.com", "https://mirror.baidubce.com", "https://docker.m.daocloud.io", "https://docker.nju.edu.cn", "https://docker.mirrors.sjtug.sjtu.edu.cn", "https://docker.mirrors.ustc.edu.cn", "https://mirror.iscas.ac.cn", "https://docker.rainbond.cc", "https://do.nark.eu.org", "https://dc.j8.work", "https://gst6rzl9.mirror.aliyuncs.com", "https://registry.docker-cn.com", "http://hub-mirror.c.163.com", "http://mirrors.ustc.edu.cn/", "https://mirrors.tuna.tsinghua.edu.cn/", "http://mirrors.sohu.com/" ], "insecure-registries": [ "registry.docker-cn.com", "docker.mirrors.ustc.edu.cn" ], "debug": true, "experimental": false } EOF 
注意:上面的列表包含了非常多的镜像源。Docker 会按顺序尝试,选择最快的一个。

2. 重新加载配置并重启 Docker

修改配置后,必须重新加载并重启 Docker 服务才能生效。

sudo systemctl daemon-reload sudo systemctl restart docker 

现在,你再执行 docker pull(例如 docker pull nginx),会发现速度有了质的飞跃。

四、Docker 常见指令

以下是我日常使用中总结的常用命令。

1. Docker 服务相关命令 (systemctl)

systemctl start docker # 开启docker systemctl stop docker # 停止docker systemctl restart docker # 重启docker systemctl enable docker # 设置开机启动docker systemctl status docker # 查看docker状态 

2. 镜像相关命令

docker images # 查看本地所有镜像 docker search [镜像名] # 从Docker Hub搜索镜像 docker pull [镜像名]:[版本] # 拉取镜像(不写版本默认latest) docker rmi [镜像ID/镜像名] # 删除指定镜像 docker rmi -f $(docker images -aq) # 强制删除所有镜像 

3. 容器相关命令

这是 Docker 命令的核心,特别是 docker run

# 查看容器 docker ps # 查看正在运行的容器 docker ps -a # 查看所有容器(包括已停止的) # 运行容器 (docker run) docker run [参数] [镜像名] # 基于镜像启动一个新容器 
docker run 常见参数详解:

docker run 是最复杂的命令,掌握好参数非常重要:

  • -d: 后台运行容器(daemonize)。
  • -p [宿主机端口]:[容器端口]: 端口映射。例如 -p 8080:80,将宿主机的 8080 端口映射到容器的 80 端口。
  • -v [宿主机目录]:[容器目录]: 卷挂载。用于数据持久化,例如 -v /mydata/mysql:/var/lib/mysql
  • --name [容器名]: 为容器指定一个名称,方便管理。
  • -e [环境变量名]=[值]: 设置环境变量。例如 -e MYSQL_ROOT_PASSWORD=123456
  • --network [网络名]: 指定容器加入的网络。
  • --restart=always: 设置容器的重启策略。always 表示无论何种情况退出,都自动重启。

示例:

# 启动一个Nginx容器,命名为my-nginx,后台运行,并将宿主机的80端口映射到容器的80端口 docker run -d -p 80:80 --name my-nginx nginx 
其他容器命令:
# 启动/停止/重启 容器 docker start [容器名/ID] # 启动已停止的容器 docker stop [容器名/ID] # 停止正在运行的容器 docker restart [容器名/ID] # 重启容器 # 删除容器 docker rm [容器名/ID] # 删除已停止的容器 docker rm -f [容器名/ID] # 强制删除正在运行的容器 docker rm $(docker ps -aq) # 删除所有已停止的容器 # 查看日志 docker logs [容器名/ID] # 查看容器日志 docker logs -f [容器名/ID] # 实时查看容器日志(类似 tail -f) # 容器开机自启(针对已创建的容器) docker update --restart=always [容器名/ID] 

Read more

Java IO详解:File、FileInputStream与FileOutputStream

Java IO详解:File、FileInputStream与FileOutputStream

文章目录 * 引言:Java IO体系与文件操作 * 第一章:IO流基础概念 * 1.1 什么是流(Stream) * 1.2 Java IO流的分类 * 1.3 文件IO的核心类 * 第二章:File类深度剖析 * 2.1 类的定义与核心字段 * 2.2 构造方法:创建File对象 * 2.3 常用API详解 * 2.3.1 获取文件和目录基本信息 * 2.3.2 判断功能 * 2.3.3 列出目录内容 * 2.3.4 创建与删除 * 2.3.5 重命名与移动 * 2.

By Ne0inhk
能做影视级可商业视频的AI工具,Seedance 2.0 全球首发实测

能做影视级可商业视频的AI工具,Seedance 2.0 全球首发实测

如果你是短片导演、影视团队,或者长期做内容的自媒体,一定有同感: AI 视频不是不好,而是太“难用”。 * 想复刻一个爆款运镜,结果画面乱飞 * 想做商用级视频,角色和产品每一帧都在变 * 想快点出片,却被排队、算力、复杂参数拖住 大多数 AI 视频工具的现状是: 看 Demo 很震撼,真到实操,全靠赌。 而 Seedance2.0 给我的第一感受是—— 它不是在“秀模型能力”,而是在解决真实创作流程中的控制问题,把“做视频”这件事,拉回到像 P 图一样直觉、可控。 一、模型重磅发布:Seedance2.0 到底解决了什么? Seedance2.0 是即梦最新一代视频模型,核心定位非常明确: 影视级质量 + 商业可用 + 一站式生成。

By Ne0inhk
【JAVA探索之路】简单聊聊Kafka

【JAVA探索之路】简单聊聊Kafka

目录 一、Kafka核心概念与架构 核心概念解析 集群架构一览 二、Kafka核心特性与工作原理 顺序I/O与零拷贝 生产者可靠性保证 精确一次语义 三、Kafka关键API与生态系统 四、Kafka运维管理 五、Kafka典型应用场景 一、Kafka核心概念与架构 要掌握 Kafka,必须从理解其精心设计的基本模型开始。 核心概念解析 * 消息与批次:Kafka 的基本数据单元称为“记录”,包含键、值和时间戳。为提高效率,多条记录会组合成“批次”进行传输。 * 主题与分区:消息按“主题”进行分类,类似于数据库的表。每个主题可被分割为多个“分区”,这是 Kafka 实现并行处理和横向扩展的基石。消息在分区内按追加顺序存储,并分配一个单调递增的偏移量,从而保证了消息的顺序性。 * 生产与消费:生产者将消息发布到指定主题的特定分区;消费者则以“拉”

By Ne0inhk
Java Map常用方法和实现类深度详解

Java Map常用方法和实现类深度详解

文章目录 * 前言 * 第一章 Map接口概述 * 1.1 Map的继承体系 * 1.2 Map的核心特性 * 1.3 存储结构的理解 * 第二章 HashMap:最常用的Map实现 * 2.1 底层数据结构演进 * 2.2 核心源码深度解析 * 2.2.1 重要成员变量 * 2.2.2 设计哲学解读 * 2.3 put方法执行流程 * 2.4 扩容机制(resize) * 2.5 线程安全问题 * 第三章 LinkedHashMap:保持插入顺序 * 3.1 数据结构特点 * 3.2 两种排序模式 * 3.

By Ne0inhk