当前位置: 首页 > article >正文

第四部分-Docker网络与存储——20. 数据持久化

20. 数据持久化1. 数据持久化概述容器默认情况下数据是临时的当容器删除时数据也会丢失。数据持久化是生产环境中必须解决的问题Docker 提供了多种数据持久化方案。┌─────────────────────────────────────────────────────────────┐ │ Docker 数据持久化方案 │ ├─────────────────────────────────────────────────────────────┤ │ │ │ ┌─────────────────────────────────────────────────────┐ │ │ │ Volume推荐 │ │ │ │ - Docker 管理 │ │ │ │ - 独立于容器生命周期 │ │ │ │ - 支持多种驱动 │ │ │ │ - 适合生产环境 │ │ │ └─────────────────────────────────────────────────────┘ │ │ │ │ ┌─────────────────────────────────────────────────────┐ │ │ │ Bind Mount开发 │ │ │ │ - 宿主机任意路径 │ │ │ │ - 直接访问宿主机文件 │ │ │ │ - 适合开发环境 │ │ │ │ - 配置文件共享 │ │ │ └─────────────────────────────────────────────────────┘ │ │ │ │ ┌─────────────────────────────────────────────────────┐ │ │ │ tmpfs内存 │ │ │ │ - 内存存储 │ │ │ │ - 速度最快 │ │ │ │ - 临时数据 │ │ │ │ - 敏感信息 │ │ │ └─────────────────────────────────────────────────────┘ │ │ │ └─────────────────────────────────────────────────────────────┘2. Volume数据卷2.1 创建和管理# 创建数据卷dockervolume create mydata# 列出数据卷dockervolumels# 查看数据卷详情dockervolume inspect mydata# 显示数据卷位置# Mountpoint: /var/lib/docker/volumes/mydata/_data# 删除数据卷dockervolumermmydata# 清理未使用的卷dockervolume prune# 强制清理所有未使用卷dockervolume prune-f2.2 使用数据卷# 使用命名卷dockerrun-d-vmydata:/app/data--nameapp nginx# 使用 --mount 语法推荐dockerrun-d--mountsourcemydata,target/app/data nginx# 只读挂载dockerrun-d--mountsourcemydata,target/app/data,readonly nginx# 使用匿名卷不推荐dockerrun-d-v/app/data nginx# 查看卷使用情况dockerinspect app|grep-A10Mounts2.3 卷驱动# 使用本地驱动默认dockervolume create--driverlocalmydata# 使用 NFS 驱动dockervolume create--driverlocal\--opttypenfs\--optdevice:/path/to/nfs\--optoaddrnfs-server,rw,nfsvers4\nfs-volume# 挂载 NFS 卷dockerrun-d-vnfs-volume:/data nginx# 使用第三方驱动如 Flocker# docker volume create --driver flocker mydata3. Bind Mount3.1 基础用法# 基础语法dockerrun-d-v/host/data:/app/data nginx# 使用 --mount推荐dockerrun-d--mounttypebind,source/host/data,target/app/data nginx# 相对路径dockerrun-d-v$(pwd)/data:/app/data nginx# 只读绑定dockerrun-d--mounttypebind,source/host/config,target/app/config,readonly nginx# 绑定单个文件dockerrun-it--mounttypebind,source/host/config.json,target/app/config.json alpinesh3.2 权限管理# 指定用户 IDdockerrun-d--user1000:1000-v/host/data:/app/data nginx# 修改宿主机目录权限sudochown-R1000:1000 /host/datasudochmod755/host/data# SELinux 标签CentOS/RHELdockerrun-d-v/host/data:/app/data:Z nginx# 私有dockerrun-d-v/host/data:/app/data:z nginx# 共享4. tmpfs 挂载# 使用 tmpfsdockerrun-d--tmpfs/app/tmp:rw,noexec,nosuid,size100m nginx# 使用 --mount 语法dockerrun-d--mounttypetmpfs,destination/app/tmp,tmpfs-size100m nginx# 查看 tmpfs 使用dockerexeccontainer_namedf-h/app/tmp# 适用场景# - 临时文件# - 缓存数据# - Session 存储# - 敏感信息不落盘5. 数据备份与恢复5.1 备份数据卷# 备份卷到 tar 文件dockerrun--rm\-vmydata:/source\-v$(pwd):/backup\alpine\tarczf /backup/mydata-backup.tar.gz-C/source.# 备份 bind mountdockerrun--rm\-v/host/data:/source\-v$(pwd):/backup\alpine\tarczf /backup/data-backup.tar.gz-C/source.# 备份多个卷dockerrun--rm\-vvolume1:/source1\-vvolume2:/source2\-v$(pwd):/backup\alpine\sh-ctar czf /backup/backup.tar.gz /source1 /source25.2 恢复数据卷# 创建新卷dockervolume create newdata# 从备份恢复dockerrun--rm\-vnewdata:/target\-v$(pwd):/backup\alpine\tarxzf /backup/mydata-backup.tar.gz-C/target# 验证恢复dockerrun--rm-vnewdata:/data alpinels-la/data5.3 容器迁移# 导出容器数据CONTAINER_NAMEmyappBACKUP_FILEmyapp-data.tar.gzdockerrun--rm\--volumes-from$CONTAINER_NAME\-v$(pwd):/backup\alpine\tarczf /backup/$BACKUP_FILE/data# 在新宿主机恢复dockercreate-v/data--name>dockerrun--rm\--volumes-from>\-v$(pwd):/backup\alpine\tarxzf /backup/$BACKUP_FILE-C/6. 卷管理策略6.1 命名规范# 推荐命名格式# project-environment-purpose# 示例dockervolume create myapp-prod-dbdockervolume create myapp-prod-logsdockervolume create myapp-prod-uploadsdockervolume create myapp-dev-db6.2 卷标签# 创建带标签的卷dockervolume create\--labelprojectmyapp\--labelenvironmentproduction\--labelbackuptrue\myapp-data# 过滤卷dockervolumels--filterlabelprojectmyappdockervolumels--filterlabelenvironmentproduction# 清理特定标签的卷dockervolume prune--filterlabelprojecttemporary6.3 卷清理策略# 定期清理crontab# 0 2 * * * docker volume prune -f# 清理 24 小时前使用的卷dockervolume prune--filteruntil24h# 查找并删除特定模式的卷dockervolumels-q--filternametemp-|xargsdockervolumerm# 删除所有未使用卷dockervolume prune-a7. 实战示例7.1 MySQL 数据持久化# 创建数据卷dockervolume create mysql-datadockervolume create mysql-logs# 运行 MySQL 容器dockerrun-d\--namemysql\-vmysql-data:/var/lib/mysql\-vmysql-logs:/var/log/mysql\-eMYSQL_ROOT_PASSWORDroot123\mysql:8.0# 测试数据持久化dockerexecmysql mysql-uroot-proot123-eCREATE DATABASE testdbdockerstop mysqldockerstart mysqldockerexecmysql mysql-uroot-proot123-eSHOW DATABASES7.2 WordPress 持久化# 创建卷dockervolume create wordpress-dbdockervolume create wordpress-files# MySQLdockerrun-d\--namewp-mysql\-vwordpress-db:/var/lib/mysql\-eMYSQL_ROOT_PASSWORDroot\-eMYSQL_DATABASEwordpress\mysql:8.0# WordPressdockerrun-d\--namewordpress\-p8080:80\-vwordpress-files:/var/www/html\--linkwp-mysql:mysql\wordpress:latest# 备份dockerrun--rm\-vwordpress-db:/source\-vwordpress-files:/source-files\-v$(pwd):/backup\alpinesh-ctar czf /backup/wordpress-backup.tar.gz /source /source-files7.3 开发环境热重载# 使用 bind mount 实现代码热重载dockerrun-d\--namedev-app\-p3000:3000\-v$(pwd):/app\-v/app/node_modules\node:14\npmrun dev8. 存储对比特性VolumeBind Mounttmpfs位置Docker 管理任意路径内存持久性是是否容器删除保留保留删除备份容易容易N/A跨主机需要驱动需要共享N/A性能好好最快权限自动手动自动适用生产数据开发配置临时数据9. 监控与调试# 查看卷使用情况dockersystemdf# 查看卷详情dockervolume inspect mydata# 查看卷中文件dockerrun--rm-vmydata:/data alpinels-la/data# 查看卷大小dockerrun--rm-vmydata:/data alpinedu-sh/data# 调试卷内容dockerrun--rm-it-vmydata:/data alpinesh10. 最佳实践✅ 推荐做法生产环境使用 Volume开发环境使用 Bind Mount敏感数据使用 Volume 或 tmpfs为卷设置标签便于管理定期备份重要数据卷使用命名卷而非匿名卷❌ 避免事项在容器可写层存储持久数据在生产环境使用 Bind Mount 存储应用数据忽视卷的备份策略删除容器后忘记清理卷11. 常见问题Q1: 容器删除后数据还在吗Volume 数据还在Bind Mount 数据还在容器层数据丢失。Q2: 多个容器可以共享同一个卷吗可以支持多容器读写同一个卷。Q3: 如何迁移卷到另一台主机使用docker volume inspect定位卷位置复制 _data 目录到新主机。12. 小结Volume生产环境推荐Docker 管理Bind Mount开发环境直接访问宿主机tmpfs内存存储临时数据备份恢复使用 Docker 容器配合 tar卷管理标签、清理策略根据场景选择合适的存储方案定期备份重要数据

相关文章:

第四部分-Docker网络与存储——20. 数据持久化

20. 数据持久化 1. 数据持久化概述 容器默认情况下数据是临时的,当容器删除时数据也会丢失。数据持久化是生产环境中必须解决的问题,Docker 提供了多种数据持久化方案。 ┌──────────────────────────────────────…...

终极指南:3分钟快速找回Navicat数据库连接密码的免费工具

终极指南:3分钟快速找回Navicat数据库连接密码的免费工具 【免费下载链接】navicat_password_decrypt 忘记navicat密码时,此工具可以帮您查看密码 项目地址: https://gitcode.com/gh_mirrors/na/navicat_password_decrypt 你是否曾经因为忘记Navicat保存的数…...

第四部分-Docker网络与存储——19. 容器间通信

19. 容器间通信 1. 容器间通信概述 容器间通信是 Docker 编排的核心,理解容器如何相互通信对于构建微服务架构至关重要。Docker 提供了多种容器间通信方式,每种方式适用于不同场景。 ┌────────────────────────────────…...

从Word到LaTeX的完美转换:3种方案对比与docx2tex终极指南

从Word到LaTeX的完美转换:3种方案对比与docx2tex终极指南 【免费下载链接】docx2tex Converts Microsoft Word docx to LaTeX 项目地址: https://gitcode.com/gh_mirrors/do/docx2tex 深夜三点,李博士盯着电脑屏幕,手指在键盘上机械地…...

BUUCTF:[极客大挑战 2019]RCE ME 深度解析:从正则绕开到LD_PRELOAD的完整利用链

1. 题目背景与初步分析 BUUCTF的[极客大挑战 2019]RCE ME是一道典型的PHP代码审计与绕过题目。题目给出了一个简单的PHP页面&#xff0c;核心代码如下&#xff1a; <?php error_reporting(0); if(isset($_GET[code])){$code$_GET[code];if(strlen($code)>40){die(&quo…...

如何快速提取Unity游戏素材:AssetStudio完整使用指南

如何快速提取Unity游戏素材&#xff1a;AssetStudio完整使用指南 【免费下载链接】AssetStudio AssetStudio - Based on the archived Perfares AssetStudio, I continue Perfares work to keep AssetStudio up-to-date, with support for new Unity versions and additional i…...

“社恐”技术大牛周志明的写作哲学:如何像他一样,用开源文档和博客打造个人技术品牌

“社恐”技术大牛的写作哲学&#xff1a;用开源与博客构建个人技术品牌 在技术圈里&#xff0c;有这样一群人&#xff1a;他们不善言辞&#xff0c;却能用代码和文字征服同行&#xff1b;他们回避社交&#xff0c;却在GitHub和博客上拥有大批追随者。这类"社恐"技术大…...

LinkSwift:如何让网盘下载从龟速到光速?这款工具给出了答案

LinkSwift&#xff1a;如何让网盘下载从龟速到光速&#xff1f;这款工具给出了答案 【免费下载链接】Online-disk-direct-link-download-assistant 一个基于 JavaScript 的网盘文件下载地址获取工具。基于【网盘直链下载助手】修改 &#xff0c;支持 百度网盘 / 阿里云盘 / 中国…...

如何快速掌握思源宋体:7种免费商用字体让你的设计瞬间专业

如何快速掌握思源宋体&#xff1a;7种免费商用字体让你的设计瞬间专业 【免费下载链接】source-han-serif-ttf Source Han Serif TTF 项目地址: https://gitcode.com/gh_mirrors/so/source-han-serif-ttf 还在为中文排版设计而烦恼吗&#xff1f;你是否曾经在寻找既美观…...

GetQzonehistory:5分钟免费备份你的QQ空间青春回忆

GetQzonehistory&#xff1a;5分钟免费备份你的QQ空间青春回忆 【免费下载链接】GetQzonehistory 获取QQ空间发布的历史说说 项目地址: https://gitcode.com/GitHub_Trending/ge/GetQzonehistory 还在担心那些承载青春记忆的QQ空间说说会随着时间消失吗&#xff1f;GetQ…...

程序员转大模型,这8个必备框架,新手也能快速落地项目

文章目录前言1. LangChain 2026&#xff1a;AI应用开发的"事实标准"&#xff0c;新手入门绕不开1.1 大白话理解LangChain1.2 2026年核心更新亮点1.3 新手快速上手代码示例1.4 避坑指南2. LlamaIndex&#xff1a;RAG专属神器&#xff0c;知识库搭建就靠它2.1 大白话理…...

Anylogic建模效率翻倍秘诀:活用‘智能体类型’实现模块化设计与复用

Anylogic建模效率翻倍秘诀&#xff1a;活用‘智能体类型’实现模块化设计与复用 在复杂系统仿真领域&#xff0c;Anylogic凭借其多方法建模能力已成为工业级解决方案的首选工具。但当我们面对包含数百个交互实体的产线仿真时&#xff0c;传统逐个创建智能体的方式不仅效率低下&…...

ECharts地图可视化踩坑实录:从GeoJSON数据获取到本地开发跨域问题的全链路解决

ECharts地图可视化实战指南&#xff1a;从数据获取到跨域问题解决的全流程解析 地图可视化是现代数据展示的重要手段之一&#xff0c;而ECharts作为国内最流行的可视化库之一&#xff0c;其地图功能被广泛应用于各类项目中。但在实际开发过程中&#xff0c;从数据获取到最终呈现…...

Vivado里用OSERDESE2+OBUFDS实现LVDS输出,一个完整可复用的Verilog模块(含XDC约束)

Vivado中LVDS输出的工程化实现&#xff1a;OSERDESE2与OBUFDS的模块化封装 在高速数字电路设计中&#xff0c;LVDS&#xff08;低压差分信号&#xff09;因其抗干扰能力强、功耗低、传输速率高等优势&#xff0c;已成为FPGA与外部器件通信的重要接口标准。对于Xilinx FPGA开发者…...

编程应届生面试,HR最常问的20个问题,高分答案都在这里

文章目录前言一、自我认知类&#xff1a;HR想知道你是不是“对的人”问题1&#xff1a;请你做一个3分钟的自我介绍问题2&#xff1a;你最大的优点和缺点是什么&#xff1f;问题3&#xff1a;你为什么选择这个专业/行业&#xff1f;二、职业规划类&#xff1a;看你能不能在公司待…...

Transformer架构优化实战2026:注意力机制、KV Cache与推理加速完整指南

Transformer架构诞生已近十年&#xff0c;但它的工程优化故事才刚刚开始。2026年&#xff0c;理解并掌握Transformer的核心优化技术&#xff0c;是每个LLM工程师的必修课。一、为什么Transformer的优化如此重要一个7B参数的LLM在A100上推理时&#xff0c;如果没有优化&#xff…...

对比自行维护多个API密钥,Taotoken的密钥管理与审计日志更省心

&#x1f680; 告别海外账号与网络限制&#xff01;稳定直连全球优质大模型&#xff0c;限时半价接入中。 &#x1f449; 点击领取海量免费额度 对比自行维护多个API密钥&#xff0c;Taotoken的密钥管理与审计日志更省心 在构建基于大模型的应用时&#xff0c;项目管理者常常需…...

从选型到调试:MCP2517FD与ATA6563收发器搭配实战避坑指南

从选型到调试&#xff1a;MCP2517FD与ATA6563收发器搭配实战避坑指南 在工业控制和车载电子系统中&#xff0c;CAN FD总线技术正逐步取代传统CAN总线&#xff0c;成为高速数据传输的新标准。作为硬件工程师&#xff0c;我们常常面临这样的挑战&#xff1a;如何在有限的项目周期…...

别再只配防火墙了!华为USG+交换机联动配置实战:让内网用户顺利上网的完整闭环

华为USG防火墙与交换机联动配置&#xff1a;构建企业内网安全上网的完整方案 当企业内网用户反馈无法访问互联网时&#xff0c;很多网络工程师的第一反应是检查防火墙配置。然而&#xff0c;真实情况往往是防火墙只是整个网络出口链条中的一环。本文将从一个完整的网络架构视角…...

观察不同时段调用Taotoken多模型API的延迟波动情况

&#x1f680; 告别海外账号与网络限制&#xff01;稳定直连全球优质大模型&#xff0c;限时半价接入中。 &#x1f449; 点击领取海量免费额度 观察不同时段调用Taotoken多模型API的延迟波动情况 在构建依赖大模型能力的应用时&#xff0c;服务的响应延迟是一个直接影响用户体…...

5分钟掌握LayerDivider:AI图像分层工具终极指南

5分钟掌握LayerDivider&#xff1a;AI图像分层工具终极指南 【免费下载链接】layerdivider A tool to divide a single illustration into a layered structure. 项目地址: https://gitcode.com/gh_mirrors/la/layerdivider 你是否曾经面对复杂的插画作品&#xff0c;花…...

WeChatMsg完整指南:如何永久保存并深度分析你的微信聊天记录

WeChatMsg完整指南&#xff1a;如何永久保存并深度分析你的微信聊天记录 【免费下载链接】WeChatMsg 提取微信聊天记录&#xff0c;将其导出成HTML、Word、CSV文档永久保存&#xff0c;对聊天记录进行分析生成年度聊天报告 项目地址: https://gitcode.com/GitHub_Trending/we…...

【管理科学】【财务领域】第四十九篇 企业资本通过金融工具获取资本与通过制造舆论冲突吸引注意力01

企业资本运作与注意力经济融合模型分析 本模型旨在揭示企业如何将金融资本杠杆与注意力经济策略相结合,以实现资本扩张与用户习惯的深度绑定。 编号 类型 企业资本注意力经济和长期购买/消费习惯培养模型 逐步推理思考的方程式 时序数学方程式 交互周期和交互流程的数学…...

30_AI短片实战第三弹:头盔一致性、连续动作推导与情绪特写叠加(附提示词)

文章目录 一、锁定造型:为角色建立“三视图”头盔参考 问题诊断 解决方案:角色三视图思路 二、连续动作推导:从一张图“衍生”出下一帧 工作流创新 具体操作 效果 适用场景 三、怪兽摔落镜头:场景切换中的叙事连续性 镜头设定 关键调整点 生成结果 四、情绪特写:瞳孔与面罩…...

OpenClaw用户迁移至Taotoken平台的具体配置步骤详解

&#x1f680; 告别海外账号与网络限制&#xff01;稳定直连全球优质大模型&#xff0c;限时半价接入中。 &#x1f449; 点击领取海量免费额度 OpenClaw用户迁移至Taotoken平台的具体配置步骤详解 如果你正在使用OpenClaw这类Agent框架&#xff0c;并希望将后端模型服务切换至…...

告别虚拟机卡顿:在Windows 11的WSL2里为树莓派4B编译Automotive Grade Linux镜像

告别虚拟机卡顿&#xff1a;在Windows 11的WSL2里为树莓派4B编译Automotive Grade Linux镜像 嵌入式开发者在Windows平台上常面临一个尴尬处境&#xff1a;项目需要Linux环境&#xff0c;但物理机切换或虚拟机性能损耗让人头疼。去年我在为某车载HMI项目构建AGL镜像时&#xff…...

Unity UGUI点击事件避坑指南:为什么你的Image点了没反应?

Unity UGUI点击事件避坑指南&#xff1a;为什么你的Image点了没反应&#xff1f; 当你信心满满地在Unity中为Image组件添加了IPointerClickHandler接口&#xff0c;点击运行时却发现无论如何点击屏幕都没有反应——这种挫败感每个Unity开发者都经历过。本文将深入剖析UGUI事件系…...

3分钟快速上手:免费AI语音修复工具VoiceFixer终极指南 [特殊字符]

3分钟快速上手&#xff1a;免费AI语音修复工具VoiceFixer终极指南 &#x1f3a4; 【免费下载链接】voicefixer General Speech Restoration 项目地址: https://gitcode.com/gh_mirrors/vo/voicefixer 你是否曾经因为录音质量不佳而烦恼&#xff1f;会议录音充满杂音、珍…...

Windows与Office终极激活指南:KMS_VL_ALL_AIO智能脚本免费解决方案

Windows与Office终极激活指南&#xff1a;KMS_VL_ALL_AIO智能脚本免费解决方案 【免费下载链接】KMS_VL_ALL_AIO Smart Activation Script 项目地址: https://gitcode.com/gh_mirrors/km/KMS_VL_ALL_AIO 还在为系统激活烦恼吗&#xff1f;KMS_VL_ALL_AIO智能激活脚本为您…...

Diablo Edit2深度解析:技术架构与安全使用的暗黑2存档编辑完全手册

Diablo Edit2深度解析&#xff1a;技术架构与安全使用的暗黑2存档编辑完全手册 【免费下载链接】diablo_edit Diablo II Character editor. 项目地址: https://gitcode.com/gh_mirrors/di/diablo_edit Diablo Edit2是一款功能强大的开源暗黑破坏神2存档编辑器&#xff0…...