50万奖金+官方证书,深圳国际金融科技大赛正式启动,点击报名 了解详情
写点什么

CentOS 下修改 Devicemapper 存储驱动为 Direct-lvm 模式

  • 2020-04-12
  • 本文字数:1647 字

    阅读完需:约 5 分钟

CentOS下修改Devicemapper存储驱动为Direct-lvm模式

Device Mapper 是基于内核的框架,支持 Linux 上的许多高级卷管理技术。Docker 的 devicemapper 存储驱动程序利用此框架的精简配置和快照功能进行映像和容器管理。本文将 Device Mapper 存储驱动程序称为 devicemapper,并将内核框架称为 Device Mapper。


对于支持它的系统,Linux 内核中包含支持。但是,Docker 需要使用特定的配置。例如,在 RHEL 或 CentOS 操作系统中,Docker 将默认为 overlay,overlay 官方不建议在生产中使用。


该 devicemapper 驱动程序使用专用于 Docker 的块设备,并在块级而非文件级进行操作。这些设备可以通过将物理存储添加到 Docker 主机来扩展,并且比在操作系统级别使用文件系统性能更好。

配置用于生产的 direct-lvm 驱动模式

CentOS 安装好 Docker 后,默认 Storage Driver 为 devicemapper 的 loop-lvm 模式,这种模式从性能和稳定性上都不可靠,此模式仅适用于测试环境。

配置 direct-lvm 模式

生产环境使用 devicemapper 存储驱动程序的主机必须使用 direct-lvm 模式。此模式使用块设备来创建精简池。这比使用 loop-lvm 设备更快,更有效地使用系统资源,并且块设备可以根据需要扩增。


在 Docker 17.06 及更高版本中,Docker 可以为您管理块设备,简化 direct-lvm 模式的配置。这仅适用于新的 Docker 设置,并且只能使用一个块设备。


注:如果您需要使用多个块设备,需要手动配置 direct-lvm 模式。



编辑 daemon.json 文件并设置适当的选项,然后重新启动 Docker 以使更改生效。以下 daemon.json 设置了上表中的所有选项。


手动配置 DIRECT-LVM 模式

假定有一块 100G 空闲块设备 /dev/sdb 。设备标识符和音量大小在您的环境中可能不同,您应该在整个过程中替换您自己的值。

停止 docker

sudo systemctl stop docker
复制代码

安装依赖

RHEL / CentOS的:device-mapper-persistent-data,lvm2,和所有的依赖
复制代码

把整块硬盘创建物理卷(PV)

sudo pvcreate /dev/sdb
复制代码

创建 dockervg 卷组(VG)

sudo vgcreate dockervg /dev/sdb
复制代码

划分两个逻辑卷(LV)

划分两个逻辑卷(LV),分别用于:docker_data,docker_metadata。


sudo lvcreate --wipesignatures y -n data dockervg -L 35Gsudo lvcreate --wipesignatures y -n metadata dockervg -L 1G
复制代码

转换为 thin pool

sudo lvconvert -y --zero n -c 512K --thinpool dockervg/data --poolmetadata dockervg/metadata
复制代码

配置自动扩展

cat>>/etc/lvm/profile/dockervg-data.profile<<EOFactivation {   thin_pool_autoextend_threshold=80   thin_pool_autoextend_percent=20}EOF
复制代码

划分逻辑卷(LV):docker_dir

docker_dir 主要是用于存储容器运行时产生的数据卷等文件。


sudo lvcreate --wipesignatures y -n dockerdir dockervg -l+100%FREE
复制代码

应用以上配置

lvchange --metadataprofile dockervg-data dockervg/data
复制代码

启用磁盘空间监控

lvs -o+seg_monitor
复制代码

映射相应目录

mkfs -t xfs /dev/dockervg/dockerdirmkdir /var/lib/dockermount/dev/dockervg/dockerdir/var/lib/docker
cat>> /etc/fstab <<EOF/dev/dockervg/dockerdir /var/lib/docker xfs defaults 0 0EOF
复制代码


设置 Docker 启动参数


存储池扩容

假定现在新增一块 100G 的块设备 /dev/sdc

通过 pvdisplay 查看卷组与物理卷/块设备的对应关系

sudo pvdisplay |grep dockerPV Name               /dev/sdbVG Name               docker
复制代码

通过 vgextend 命令进行卷组扩容

sudo vgextend docker /dev/sdcinfo: Physical volume "/dev/sdc" successfully created.info: Volume group "docker" successfully extended
复制代码

给逻辑卷(LV)扩容

sudo lvextend -l+100%FREE  -n docker/dockerresize2fs /dev/docker/docker-l+100%FREE: 表示使用全部空闲空间,改为-L 10G指定扩展大小;-n docker/thinpool: 指定逻辑卷名(卷组/逻辑卷名)
复制代码

激活逻辑卷(LV)

# LV扩容重启后,可能会出现“Non existing device" 的提示,需要对LV卷进行激活操作:
sudo lvchange -ay docker/thinpool
复制代码


更多详情亦可参照 Docker 官方文档:


https://docs.docker.com/engine/userguide/storagedriver/device-mapper-driver/


2020-04-12 20:391262

评论

发布
暂无评论
发现更多内容

架构实战营 模块六作业

Dylan

架构实战营

从 Flutter 和前端角度出发,聊聊单线程模型下如何保证 UI 流畅性

魅影

大前端 事件驱动 Event iOS 知识体系

Python——双向队列 (deque)

在即

6月日更

EasyRecovery,拯救那些遗失的文件

淋雨

文件恢复 Easyrecovery破解 数据恢复软件 免费数据恢复

34岁安卓开发大叔感慨,帮你突破瓶颈

欢喜学安卓

android 程序员 面试 移动开发

模块六:课后作业

菲尼克斯

架构实战营

鸿蒙究竟是什么?

Nydia

MySQL 页完全指南——浅入深出页的原理

leonsh

MySQL 数据库 innodb

共享存储设备,如何实现差异化IO分配策略

怀瑾握瑜

云计算 负载均衡 存储 数据中心 SSD

浪潮云说 | 开源新势力—云溪数据库ZNBase

云计算

chia奇亚算力挖矿分发APP系统开发

薇電13242772558

区块链

架构实战营模块 6

阿体

推荐 3 款超好用的 Docker 图形化管理工具

学神来啦

Docker Linux 程序员 分布式 运维

活久见!低访问量竟然也能导致系统问题

三石

mycat

密码学系列之:blowfish对称密钥分组算法

程序那些事

加密解密 密码学 程序那些事 密码学和算法

电商系统微服务

贯通

架构实战营

云图说|初识云数据库GaussDB(for Cassandra)

华为云开发者联盟

开源 Cassandra 云数据库 GaussDB(for Cassandra) 宽列数据库

【Vue2.x 源码学习】第二十篇 - 使用真实节点替换原始节点

Brave

源码 vue2 6月日更

架構實戰營 - 模塊 6 作業

Frank Yang

架构实战营

Cookie常见面试题

悟空聊架构

缓存 面试 Cookie 6月日更

不动如山,表备份硬核技术:物理细粒度备份恢复

华为云开发者联盟

集群 数仓 Roach 物理细粒度 备份恢复

HarmonyOS学习路之开发篇——Data Ability

爱吃土豆丝的打工人

HarmonyOS Ability 鸿蒙 Ability Data Ability

Linux之mkdir命令

入门小站

Linux

架构实战营 模块六课后作业

iProcess

架构实战营

【Flutter 专题】128 图解 ColorTween 颜色补间动画 & ButtonBar 按钮容器

阿策小和尚

Flutter 小菜 0 基础学习 Flutter Android 小菜鸟 6月日更

从工单到需求管理,企业如何快速响应客户反馈?

万事ONES

项目管理 需求管理 需求 ONES

在线crontab表达式执行时间计算工具

入门小站

工具分享

Flink集成hive测试及生产规划

一弦思华年

大数据 hive 实时数仓 数仓 flink 执行

34岁Android开发大叔感慨,已拿offer附真题解析

欢喜学安卓

android 程序员 面试 移动开发

第6模块作业

高亮

架构训练营

顶级程序员都是如何诞生的?

Nydia

话题讨论

CentOS下修改Devicemapper存储驱动为Direct-lvm模式_文化 & 方法_Rancher_InfoQ精选文章