热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

ceph查看卷_cephRBD克隆卷的io模式分析.pptx

cephRBD克隆卷的io模式分析RBD克隆卷IO性能分析谷忠言Agenda什么是克隆卷写操作,op_rw?写操作延迟细分线上集群cloud.shhp实例分析如何优化

cephRBD克隆卷的io模式分析

RBD 克隆卷IO性能分析谷忠言Agenda什么是克隆卷写操作,op_rw?写操作延迟细分线上集群cloud.shhp实例分析如何优化clone写/op_rw克隆写和Op_rw凡是从快照克隆出来的RBD image, 所有的写操作在集群内部被标记为op_rw类型。op_rw:一个请求首先有读操作(检查child object是否存在),然后修改数据再写入。凡是从快照克隆出来的RBD image,第一次写被定义为copyup操作,即先从parent 拷贝原快照对象,再追加写操作。第一次clone写产生1个op_r + 1个op_rw注意:如果clone卷做了resize操作,比如扩容了100G,则对扩容的100G的写被标记为op_w操作。Op_w vs. Op_rw非克隆写op_w,image没有parent克隆写op_rw,image有parentLIBRBD_AIO_WRITE_FLATLIBRBD_AIO_WRITE_GUARD写入object是否Object是否存在done写入object从parent拷贝整个object(copyup), 合并写操作done整个object写入child imageCase 1doneCase 2:no copyupCase 3: copyupOp_rw实验线下集群,构建copyup模型,让几乎所有写操作都走copyup路径。为一个大image做快照,并克隆child:test_iamge_1T_cloneOp_rw实验数据Fio latency=177ms后台Rados数据统计深入op_rwClient构建写操作:[stat, set-alloc-hint, write 4KB],发送至 primary osd.0osd.0收到消息,stat操作失败。osd.0向client返回消息,查无此对象。client计算定位parent osd.5,构建读操作[sparse-read 4MB],发送至 osd.5osd.5收到消息,读取object 4MB。向client端返回消息client重构写操作:[call rbd.copyup, set-alloc-hint, write 4KB],发送至primary osd.0primary osd.0写入journal replica osd.19写入journalreplica osd.27写入journal11/12,replica osd 写返回13.primary osd 返回Client IO latency breakdown2.5ms181.5ms44ms op_r134msop_rwOp_r latency breakdownOsd 完成op_r的时间是29ms, 读取并发送object实际大小是3.9MB:2016-04-15 11:35:20.421053 7ffa0a43d700 2 op_tracker client.6528.0:2684 rbd_data.13c26b8b4567.0000000000005957 osd_op [sparse-read 0~3891200] 2.b008a075 duration: msg_throttle 0.018 msg_read 0.029 msg_dispatch 0.055 osd_dispatch 0.099 op_wq_dispatch 0.056 op_prepare.find_object_context 1.052 op_prepare.total 1.645 prepare_transaction 27.25 do_op 29.152单机文件系统读取数据花了26.7ms还有15ms gap~~Op_rw latency breakdownOsd 收到object实际大小是4194304B:2016-04-15 11:35:26.124428 7ff 2 op_tracker client.6528.0:2778 rbd_data.181e6b8b4567.00000000000263a7 osd_op [call rbd.copyup,set-alloc-hint object_size 4194304 write_size 4194304,write 2838528~4096] 2.c98265ff duration: msg_throttle 0.018 msg_read 38.536 msg_dispatch 0.074 osd_dispatch 0.174 op_wq_dispatch 0.095 op_prepare.find_object_context 1.438 op_prepare.total 1.966 prep



推荐阅读
  • Objective-C 中的委托模式详解与应用 ... [详细]
  • 本文介绍了如何利用Shell脚本高效地部署MHA(MySQL High Availability)高可用集群。通过详细的脚本编写和配置示例,展示了自动化部署过程中的关键步骤和注意事项。该方法不仅简化了集群的部署流程,还提高了系统的稳定性和可用性。 ... [详细]
  • 第六章:枚举类型与switch结构的应用分析
    第六章深入探讨了枚举类型与 `switch` 结构在编程中的应用。枚举类型(`enum`)是一种将一组相关常量组织在一起的数据类型,广泛存在于多种编程语言中。例如,在 Cocoa 框架中,处理文本对齐时常用 `NSTextAlignment` 枚举来表示不同的对齐方式。通过结合 `switch` 结构,可以更清晰、高效地实现基于枚举值的逻辑分支,提高代码的可读性和维护性。 ... [详细]
  • 在过去,我曾使用过自建MySQL服务器中的MyISAM和InnoDB存储引擎(也曾尝试过Memory引擎)。今年初,我开始转向阿里云的关系型数据库服务,并深入研究了其高效的压缩存储引擎TokuDB。TokuDB在数据压缩和处理大规模数据集方面表现出色,显著提升了存储效率和查询性能。通过实际应用,我发现TokuDB不仅能够有效减少存储成本,还能显著提高数据处理速度,特别适用于高并发和大数据量的场景。 ... [详细]
  • 基于Node.js的高性能实时消息推送系统通过集成Socket.IO和Express框架,实现了高效的高并发消息转发功能。该系统能够支持大量用户同时在线,并确保消息的实时性和可靠性,适用于需要即时通信的应用场景。 ... [详细]
  • 深入解析Android 4.4中的Fence机制及其应用
    在Android 4.4中,Fence机制是处理缓冲区交换和同步问题的关键技术。该机制广泛应用于生产者-消费者模式中,确保了不同组件之间高效、安全的数据传输。通过深入解析Fence机制的工作原理和应用场景,本文探讨了其在系统性能优化和资源管理中的重要作用。 ... [详细]
  • 本文深入解析了WCF Binding模型中的绑定元素,详细介绍了信道、信道管理器、信道监听器和信道工厂的概念与作用。从对象创建的角度来看,信道管理器负责信道的生成。具体而言,客户端的信道通过信道工厂进行实例化,而服务端则通过信道监听器来接收请求。文章还探讨了这些组件之间的交互机制及其在WCF通信中的重要性。 ... [详细]
  • 深入解析CAS机制:全面替代传统锁的底层原理与应用
    本文深入探讨了CAS(Compare-and-Swap)机制,分析了其作为传统锁的替代方案在并发控制中的优势与原理。CAS通过原子操作确保数据的一致性,避免了传统锁带来的性能瓶颈和死锁问题。文章详细解析了CAS的工作机制,并结合实际应用场景,展示了其在高并发环境下的高效性和可靠性。 ... [详细]
  • 在使用 Qt 进行 YUV420 图像渲染时,由于 Qt 本身不支持直接绘制 YUV 数据,因此需要借助 QOpenGLWidget 和 OpenGL 技术来实现。通过继承 QOpenGLWidget 类并重写其绘图方法,可以利用 GPU 的高效渲染能力,实现高质量的 YUV420 图像显示。此外,这种方法还能显著提高图像处理的性能和流畅性。 ... [详细]
  • PHP预处理常量详解:如何定义与使用常量 ... [详细]
  • 本文探讨了 Kafka 集群的高效部署与优化策略。首先介绍了 Kafka 的下载与安装步骤,包括从官方网站获取最新版本的压缩包并进行解压。随后详细讨论了集群配置的最佳实践,涵盖节点选择、网络优化和性能调优等方面,旨在提升系统的稳定性和处理能力。此外,还提供了常见的故障排查方法和监控方案,帮助运维人员更好地管理和维护 Kafka 集群。 ... [详细]
  • 本文深入探讨了原型模式在软件设计中的应用与实现。原型模式通过使用已有的实例作为原型来创建新对象,而不是直接通过类实例化。这种方式不仅简化了对象的创建过程,还提高了系统的灵活性和效率。具体来说,原型模式涉及一个支持克隆功能的接口或基类,子类通过实现该接口来提供具体的克隆方法,从而实现对象的快速复制。此外,文章还详细分析了原型模式的优缺点及其在实际项目中的应用场景,为开发者提供了实用的指导和建议。 ... [详细]
  • 期末Web开发综合实践项目:运用前端技术打造趣味小游戏体验
    期末Web开发综合实践项目中,学生通过运用HTML、CSS和JavaScript等前端技术,设计并实现了一款趣味性十足的小游戏。该项目不仅检验了学生对前端基础知识的掌握情况,还提升了他们的实际操作能力和创意设计水平。视频链接展示了项目的最终成果,直观呈现了游戏的互动性和视觉效果。 ... [详细]
  • 本文详细介绍了使用响应文件在静默模式下安装和配置Oracle 11g的方法。硬件要求包括:内存至少1GB,具体可通过命令`grep -i memtotal /proc/meminfo`进行检查。此外,还提供了详细的步骤和注意事项,确保安装过程顺利进行。 ... [详细]
  • 在稀疏直接法视觉里程计中,通过优化特征点并采用基于光度误差最小化的灰度图像线性插值技术,提高了定位精度。该方法通过对空间点的非齐次和齐次表示进行处理,利用RGB-D传感器获取的3D坐标信息,在两帧图像之间实现精确匹配,有效减少了光度误差,提升了系统的鲁棒性和稳定性。 ... [详细]
author-avatar
手机用户2602927935
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有