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

TRE: 鼓励在Trust Rigon 进行探索

TRE: 鼓励在Trust Rigon 进行探索

机构:  百度 代码: https://github.com/WhyChaos/TRE-Encouraging-Exploration-in-the-Trust-Region Abstract 熵正则化是强化学习(RL)中提升探索能力的标准技术。然而,在大语言模型(LLMs)中,它往往效果甚微,甚至会导致性能下降。我们认为,这种失败源于大语言模型所固有的累积尾部风险(cumulative tail risk),这种风险来自其庞大的词表规模以及较长的生成序列长度。 在这样的环境下,标准的全局熵最大化会将概率质量不加区分地分散到大量处于尾部的无效 token 上,而不是集中于合理候选项,从而破坏连贯的推理过程。 为了解决这一问题,我们提出了 Trust Region Entropy(TRE) 方法。该方法鼓励模型仅在其“信任区域(trust region)”内进行探索。我们在数学推理任务(MATH)、组合搜索任务(Countdown)以及偏好对齐任务(HH)上进行了大量实验,结果表明,

By Ne0inhk
Spring MVC请求处理流程源码分析与DispatcherServlet核心逻辑

Spring MVC请求处理流程源码分析与DispatcherServlet核心逻辑

目录 🎯 先说说我遇到过的真实问题 ✨ 摘要 1. 从Tomcat到DispatcherServlet:请求的"奇幻漂流" 1.1 请求是怎么到你Controller的? 1.2 DispatcherServlet的初始化:不是你想的那样简单 2. 请求处理九大步:DispatcherServlet的"工作流程" 2.1 doDispatch方法:Spring MVC的心脏 2.2 九步流程详解:每个步骤都有坑 🚨 步骤1:Multipart检查 🚨 步骤2:获取Handler 3. HandlerMapping:请求的"导航系统" 3.1 四种HandlerMapping的区别 3.2 RequestMappingHandlerMapping的匹配算法 3.3 路径匹配的性能优化

By Ne0inhk
数字身份的通行证:深入解析单点登录(SSO)的架构与艺术

数字身份的通行证:深入解析单点登录(SSO)的架构与艺术

文章目录 * 概述 * 一、什么是单点登录(SSO)? * 二、SSO 的核心价值:为何它如此重要? * 三、SSO 的基本工作原理:一次认证,处处通行 * 场景一:首次登录应用 A * 场景二:访问应用 B(无感登录) * 四、SSO 的通用语言:常见协议与标准 * 五、SSO 架构的两种主流形态 * 1. **中心化 SSO** * 2. **联邦身份** * 六、安全:SSO 的生命线 * 七、典型应用场景:SSO 在哪里发光? * 八、快速上手:从理论到实践 * 九、常见误区澄清 * 总结 概述 在数字世界日益碎片化的今天,我们每个人都在无数应用和服务之间穿梭,

By Ne0inhk
Rust异步编程实战:构建高性能网络应用

Rust异步编程实战:构建高性能网络应用

Rust异步编程实战:构建高性能网络应用 一、异步编程概述 1.1 同步vs异步的区别 💡在传统的同步编程中,代码按照顺序执行,每个操作必须等待前一个完成才能继续。例如,发送网络请求时,主线程会阻塞直到响应返回,这种方式简单直观,但在高并发场景下效率低下,因为大量线程会因阻塞而闲置。 异步编程则允许代码在等待操作完成时继续执行其他任务。当一个异步操作开始后,程序会立即返回并继续处理下一个任务,直到该操作完成后通过回调或事件通知继续执行后续代码。这种方式显著提高了CPU利用率和系统的并发处理能力。 1.2 Rust异步编程的演进 Rust的异步编程经历了几个重要阶段: * 早期阶段:依赖futures库提供基础的Future和Executor支持,但语法冗长且难以使用。 * 2018 Edition:引入了async/await语法糖的实验版本,简化了异步代码的编写。 * 2021 Edition:async/await正式稳定,成为Rust异步编程的标准范式。 * 生态成熟:Tokio、async-std等异步运行时库的发展,以及大量异步IO库的出现,使Rus

By Ne0inhk