Ceph入门到精通-红帽 Ceph 存储 RGW 部署策略和规模调整指南

news2025/1/15 7:40:25

从红帽 Ceph 存储 3.0 开始,红帽增加了对 容器化存储守护进程 (CSD),允许软件定义的存储组件(Ceph MON、OSD、MGR、RGW 等)在容器内运行。CSD 避免了存储服务专用节点的需要,从而通过共置存储容器化守护程序来降低资本支出和运营支出。

Ceph-Ansible 提供了将资源屏蔽到每个存储容器所需的机制,这对于在一个物理节点上运行多个存储守护程序容器非常有用。在这篇博文中,我们将介绍部署 RGW 容器的策略及其资源大小调整指南。在我们深入研究性能之前,让我们了解部署 RGW 的不同方法。

共址 RGW

  • RGW不需要专用节点(可以降低资本支出和运营支出)。

  • Ceph RGW 容器的单个实例放置在与其他存储容器共同驻留的存储节点上。

  • 从 Ceph Storage 3.0 开始,这是部署 RGW 的首选方法。

图 1:共存 RGW 部署策略

多址 RGW

  • 不需要RGW的专用节点(可以帮助降低资本支出和运营支出)。

  • 多个 Ceph RGW 实例(当前测试的每个存储节点 2 个实例)与其他存储容器共同驻留。

  • 我们的测试表明,此选项可提供最高的性能,而不会产生额外费用。

图 2:多个共存(2 x RGW 实例)部署策略

独立 RGW

  • 需要 RGW 的专用节点。

  • Ceph RGW 组件部署在专用的物理/虚拟节点上。

  • 从 Ceph Storage 3.0 开始,这不再是部署 RGW 的首选方法。

图 3:独立 RGW 部署策略

性能摘要

(I) RGW 部署和大小调整准则

在上一节中,我们研究了部署 Ceph RGW 的不同方法。我们将比较每种方法之间的性能差异。为了衡量性能,我们通过调整 RGW 部署策略以及大小写入和读取工作负载的 RGW CPU 内核数来执行多项测试。结果如下。

100% 写入工作负载

如图1和图2所示

  • 共置 (1x) RGW 实例在小型和大型对象大小方面均优于独立 RGW 部署。

  • 同样,多个共同驻留 (2x) RGW 实例的性能优于共同驻留 (1x) RGW 实例部署。因此,多个共驻 (2x) RGW 实例分别为小型和大型对象大小提供了 2328 Ops 和 1879 MBps 的性能。

  • 在多个测试中,发现 4 个 CPU 核心/RGW 实例是 CPU 资源与 RGW 实例之间的最佳比率。为 RGW 实例分配更多 CPU 内核并未提供更高的性能。

图 1:小对象 100% 写入测试

图表 2:大型对象 100% 写入测试

100% 读取工作负载性能

有趣的是,对于读取工作负载,增加每个 RGW 实例的 CPU 内核并不能提高小型和大型对象大小的性能。因此,每个 RGW 实例 1 个 CPU 内核的结果与每个 RGW 实例 10 个 CPU 内核的结果几乎相似。

事实上,根据我们之前的测试,我们观察到类似的结果,读取工作负载不会消耗大量 CPU,这可能是因为 Ceph 利用了系统的纠删码,并且在读取过程中不需要解码块。因此,我们发现,如果 RGW 工作负载是读取密集型的,则过度分配 CPU 无济于事。

将独立 RGW 与共存 (1x) RGW 测试的结果进行比较发现非常相似。然而,只要再添加一个同地RGW(2x),在小物体的情况下,性能提高了~200%,在大物体尺寸的情况下提高了~90%。

因此,如果工作负载是读取密集型的,则运行多个共存 (2x) RGW 实例可以显著提高整体读取性能。

图表 3:小物体 100% 读取测试

图表 4:大型对象 100% 读取测试

(二)RGW线程池大小调整准则

在决定 RGW 实例的 CPU 核心分配时,RGW 调整参数之一非常相关,它负责 Beast 生成的与 HTTP 请求对应的线程数。这有效地限制了 Beast 前端可以服务的并发连接数。rgw_thread_pool_size

为了确定此可调参数的最合适值,我们通过改变 RGW 实例之前的 CPU 核心计数来运行测试。如图表 5 和图表 6 所示,我们发现 设置为 512 可在 4 个 CPU 核心预 RGW 实例上提供最大性能。增加 CPU 内核数量并没有 做得更好。 rgw_thread_pool_sizergw_thread_pool_sizergw_thread_pool_size

我们确实承认,如果我们再进行几轮低于 512 的测试,这个测试可能会更好 。我们的假设是,由于Beast Web服务器基于异步c10k Web服务器,因此它不需要每个连接一个线程,因此在较低线程下应该表现良好。不幸的是,我们无法测试,但将来会尝试解决这个问题。rgw_thread_pool_size

As such multi-collocated (2x) RGW instance with 4 CPU Core per RGW instance and of 512 delivers the maximum performance.rgw_thread_pool_size

Chart 5: Small Object 100% Write test

图表 6:大型对象 100% 写入测试

摘要和下一个

在这篇文章中,我们了解到,多地并置 (2x) RGW 实例,每个 RGW 实例有 4 个 CPU 核心,512 个,可在不增加整体硬件成本的情况下提供最大性能。在下一篇文章中,我们将学习如何从固定大小的集群实现最大的对象存储性能。rgw_thread_pool_size

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/471118.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Anaconda安装nbextensions

nbextensions 是 Jupyter 非常好的插件,它是将一系列 js 脚本嵌入到 Jupyter 中,增强 Jupyter 的交互式体验,可以让你的 Jupyter 变得非常强大。 Unofficial Jupyter Notebook Extensions 安装nbextensions 以管理员身份运行Anaconda Promp…

【Git 入门教程】第四节、Git冲突:如何解决版本控制的矛盾

Git是目前最流行的版本控制系统之一,它为团队协作开发提供了方便和高效的方式。然而,在多人同时修改同一个文件时,可能会出现代码冲突(conflict),导致代码无法正确合并。那么,如何解决Git冲突呢…

Imagination时昕:异构人工智能IP如何赋能数字化转型

4月26-28日,民生证券人工智能高峰论坛在北京举办,Imagination中国区战略市场及生态副总时昕博士受邀出席,并分享了“异构人工智能IP赋能数字化转型”的主题演讲。 全社会数字化转型大势所趋 毫无疑问,AI 已经渗透经济生产各个方面…

电赛校赛总结----一维板球系统【代码开源】

2022/4/21 搭建了整体的机械结构,最后因为经费问题,选择了用去年风力摆的架子去搭摄像头【openmv】,看当年的国赛题,选择的是ov7670,但我们讨论后觉得还是openmv的识别比较好,,下面的小球选用的是外径为3.2cm的水管&a…

设计模式——七大原则

目录 一、通过经典面试题掌握重点 二、设计模式的目的和核心原则 三、设计模式七大原则 3.1 单一职责原则(Single Responsibility Principle) 3.2 接口隔离原则(Interface Segregation Principle) 3.3 依赖倒转原则&#xf…

Mysql表索引(普通索引)

文章目录 一、创建表时定义索引二、已存在的表上创建索引 1.指向create语句2.指向alter table 语句三、查看索引执行情况总结 前言 所谓普通索引,就是在创建索引时,不附加任何限制条件(唯一、非空等限制)。该类型的索引可以创建…

C plus plus ——【面向对象编程】

系列文章目录 C plus plus 面向对象编程 文章目录 系列文章目录前言一、编程语言概述1.1低级语言概述1.2高级语言概述1.3面向过程、面向对象概述 二、面向过程编程的特性三、面向对象编程的特性四、类和对象4.1 类的概述4.2 类的声明与定义4.3 类的实现4.4 对象的生命 五、构造…

数字化转型导师坚鹏:BLM企业数字化转型战略

BLM企业数字化转型战略 ——以BLM模型为核心,实现知行果合一 课程背景: 很多企业存在以下问题: 不知道企业如何制定数字化转型战略? 不清楚其它企业数字化转型战略是如何制定的? 不知道其它企业数字化转型战略…

Spring-boot集成swagger以及MapStruct简单使用

1&#xff09;添加依赖&#xff0c;我使用3.0.0版本时会出现swagger-ui页面404的问题&#xff0c;所以改成2.9.2&#xff0c;使用默认版本swagger-model会出现判空异常。 <!-- swagger--><dependency><groupId>io.springfox</groupId><arti…

python+nodejs+php+springboot+vue 社区小区报修 -社区信息管理

客户可以对社区信息进行添加&#xff0c;修改&#xff0c;删除以及查询操作。界面如下图所示: 四、客户模块的实现 4.1车位租买支付 客户可以对车位信息进行租买后可以在个人后台进行支付操作。界面如下图所示: 4.2前台车位信息 客户登录之后&#xff0c;可以查看前台车位…

传输层 — UDP协议

目录 一、传输层 1.1 端口号 1.2 关于端口的常见问题 1.3 netstat && pidof 二、UDP协议 2.1 UDP协议格式 2.2 UDP协议特点 2.3 UDP缓冲区 2.4 基于UDP的应用层协议 一、传输层 在进行网络传输时&#xff0c;应用层需先将数据交给传输层&#xff0c;由传输层…

基于matlab仿真混合波束成形在多用户MIMO-OFDM系统中的使用

一、前言 本 例 说明 了 如何 在 大规模 MIMO 通信 系统 的 发射 端 采用 混合 波束 成形&#xff0c; 同时 使用 多 用户 和 单 用户 系统 的 技术。该示例采用全通道探测来确定发射机的通道状态信息。它将所需的预编码划分为数字基带和模拟RF组件&#xff0c;对多用户和单用户…

智能的PHP开发工具PhpStorm v2023.1全新发布——集成3v4l.org

PhpStorm是一个轻量级且便捷的PHP IDE&#xff0c;其旨在提高用户效率&#xff0c;可深刻理解用户的编码&#xff0c;提供智能代码补全&#xff0c;快速导航以及即时错误检查。可随时帮助用户对其编码进行调整&#xff0c;运行单元测试或者提供可视化debug功能。 PhpStorm v20…

商城订单模块实战 - 数据库设计、ABA问题处理、读写分离分库分表

引言 订单系统可以说是整个电商系统中最重要的一个子系统&#xff0c;因此订单数据可以算作电商企业最重要的数据资产。这篇文章我们来看看在我们的商城系统中订单服务是如何实现的&#xff0c;特别是在设计和实现一个订单系统的过程中有哪些问题是需要特别考虑的。 业务分析…

逾 200 家港企参与! GoGBA大湾区发展日(广州)圆满举行

2023年4月26日 – 由香港特别行政区政府政制及内地事务局粤港澳大湾区发展办公室、香港特别行政区政府驻粤经济贸易办事处&#xff08;驻粤办&#xff09;、香港贸易发展局&#xff08;香港贸发局&#xff09;广州办事处&#xff0c;以及香港贸发局GoGBA商贸支援合办的GoGBA大湾…

BSN-DDC基础网络详解(十):官方DDC应用SDK

官方 SDK 是 BSN 联盟为平台方推出的可快速接入 DDC 网络的工具包&#xff0c;目前 DID 和各个开放联盟链的官方 DDC SDK 都使用 Java 语言开发&#xff0c;其它主流语言的 SDK 根据市场反馈我们将陆续增加。如果算力中心方和平台方的业务系统的开发语言与 SDK 不匹配&#xff…

基于DSP+FPGA+ADS1282支持31Bit高精度数据采集方案(一)

3.1 系统需求分析 3.1.1 系统功能设计要求 本硬件处理平台的主要任务有三类&#xff0c;一是数据采集&#xff0c;包括采集惯性测量元件 的输出信号&#xff0c;接收外部系统校正信息&#xff0c;如 GPS 信息等&#xff1b;二是数据处理与计算&#xff0c;包 括惯性测量…

如何实现自动化按图片搜索淘宝商品(拍立淘)功能?拍立淘API接口item_search_img

我们都知道淘宝平台推出了拍立淘功能&#xff0c;如果大家遇到了自己喜欢的商品&#xff0c;就可以拍一张照片&#xff0c;在淘宝用拍立淘搜索就能够出现相似的同款&#xff0c;这样就不用再去找别人要链接了。淘宝拍立淘主要是通过图片识别来找相似主图的宝贝&#xff0c;那么…

基于JavaSpringmvc+myabtis+html的鲜花商城系统设计和实现

基于JavaSpringmvcmyabtishtml的鲜花商城系统设计和实现 博主介绍&#xff1a;5年java开发经验&#xff0c;专注Java开发、定制、远程、指导等,csdn特邀作者、专注于Java技术领域 作者主页 超级帅帅吴 Java项目精品实战案例《500套》 欢迎点赞 收藏 ⭐留言 文末获取源码联系方式…

分布式的流处理平台Kafka

目录&#xff1a; 一、简介二、基本概念三、生产者使用详解四、发送消息五、消费者代码示例 一、简介 ApacheKafka 是一个分布式的流处理平台。它具有以下特点&#xff1a; 支持消息的发布和订阅&#xff0c;类似于 RabbtMQ、ActiveMQ 等消息队列&#xff1b;支持数据实时处理…