[Cinder] 存储 Qos
目录
前言
Cinder 支持 front-end
和 back-end
两种类型的存储 QoS,前者由 Hypervisor 端实现(e.g. 通过 Libvirt 设置虚拟机的存储 QoS),后者指存储设备上设置的 QoS,需要存储设备支持。 一般的物理存储设备都会支持 QoS,但 SDS 的 Ceph RBD 不支持,所以使用 Ceph 存储方案的用户一般只能使用 front-end Qos 来限制虚拟机对数据盘的 Qos。
QoS 项目:
- total_bytes_sec - the total allowed bandwidth for the guest per second
- read_bytes_sec - sequential read limitation
- write_bytes_sec - sequential write limitation
- total_iops_sec - the total allowed IOPS for the guest per second
- read_iops_sec - random read limitation
- write_iops_sec - random write limitation
操作步骤
通过 openstackclient 创建具有 QoS Policy 的 Volume Type:
[stack@manager ~]$ openstack volume type create VolumeType1
+---------------------------------+--------------------------------------+
| Field | Value |
+---------------------------------+--------------------------------------+
| description | None |
| id | ae5359b3-0bbc-4104-88ca-3749eab07cc8 |
| is_public | True |
| name | VolumeType1 |
| os-volume-type-access:is_public | True |
+---------------------------------+--------------------------------------+
[stack@manager ~]$ openstack volume type show VolumeType1
+---------------------------------+--------------------------------------+
| Field | Value |
+---------------------------------+--------------------------------------+
| access_project_ids | None |
| description | None |
| id | ae5359b3-0bbc-4104-88ca-3749eab07cc8 |
| is_public | True |
| name | VolumeType1 |
| os-volume-type-access:is_public | True |
| properties | |
| qos_specs_id | None |
+---------------------------------+--------------------------------------+
[stack@manager ~]$ openstack volume qos create qos1 --consumer front-end --property total_iops_sec=200
+----------+--------------------------------------+
| Field | Value |
+----------+--------------------------------------+
| consumer | front-end |
| id | 05ab9096-3a0f-45d8-acb8-f0cac172ae8c |
| name | qos1 |
| specs | {u'total_iops_sec': u'200'} |
+----------+--------------------------------------+
[stack@manager ~]$ openstack volume qos set --property total_bytes_sec=2048000 qos1
[stack@manager ~]$ openstack volume qos associate qos1 VolumeType1
指定 VolumeType 创建 Volume:
[stack@manager ~]$ openstack volume create --type VolumeType1 --size 1 volume1
+---------------------+--------------------------------------+
| Field | Value |
+---------------------+--------------------------------------+
| attachments | [] |
| availability_zone | nova |
| bootable | false |
| consistencygroup_id | None |
| created_at | 2018-12-26T13:51:22.597699 |
| description | None |
| encrypted | False |
| id | c24e2a9e-1792-4951-a040-434b87409558 |
| migration_status | None |
| multiattach | False |
| name | volume1 |
| properties | |
| replication_status | disabled |
| size | 1 |
| snapshot_id | None |
| source_volid | None |
| status | creating |
| type | VolumeType1 |
| updated_at | None |
| user_id | 11b816e454384d038472c7c89d2544f4 |
+---------------------+--------------------------------------+
[stack@manager ~]$ openstack volume list
+--------------------------------------+--------------+-----------+------+-------------+
| ID | Display Name | Status | Size | Attached to |
+--------------------------------------+--------------+-----------+------+-------------+
| c24e2a9e-1792-4951-a040-434b87409558 | volume1 | available | 1 | |
+--------------------------------------+--------------+-----------+------+-------------+
查看 Libvirt 虚拟机的 XML 文件内容,disk 标签具有 QoS 属性 <iotune>
:
[root@overcloud-compute-0 ~]# virsh dumpxml 1
...
<disk type='block' device='disk'>
<driver name='qemu' type='raw' cache='none' io='native'/>
<source dev='/dev/sdd'/>
<backingStore/>
<target dev='vdb' bus='virtio'/>
<iotune>
<total_iops_sec>200</total_iops_sec>
<total_bytes_sec>2048000</total_bytes_sec>
</iotune>
<serial>c24e2a9e-1792-4951-a040-434b87409558</serial>
<alias name='virtio-disk1'/>
<address type='pci' domain='0x0000' bus='0x00' slot='0x06' function='0x0'/>
</disk>
通过 virsh 设定 Libvirt 虚拟机的 QoS 属性:
[root@overcloud-compute-0 ~]# virsh blkdeviotune 1 vdb --total_iops_sec 100
[root@overcloud-compute-0 ~]# virsh blkdeviotune 1 vdb --total-bytes-sec 1024000
[root@overcloud-compute-0 ~]# virsh dumpxml 1
...
<disk type='block' device='disk'>
<driver name='qemu' type='raw' cache='none' io='native'/>
<source dev='/dev/sdd'/>
<backingStore/>
<target dev='vdb' bus='virtio'/>
<iotune>
<total_bytes_sec>1024000</total_bytes_sec>
<total_iops_sec>100</total_iops_sec>
</iotune>
<serial>c24e2a9e-1792-4951-a040-434b87409558</serial>
<alias name='virtio-disk1'/>
<address type='pci' domain='0x0000' bus='0x00' slot='0x06' function='0x0'/>
</disk>
NOTE:Qos 一般来说都是在一个建议值上下浮动的,所以可以通过指定 --total-iops-sec-max
来固定上限。
参考文章
Capacity based quality of service
https://blog.csdn.net/LL_JCB/article/details/80412362
[Cinder] 存储 Qos的更多相关文章
- cinder存储节点 后端采用lvm、nfs安装配置
#cinder存储节点 openstack pike 部署 目录汇总 http://www.cnblogs.com/elvi/p/7613861.html #cinder存储节点 #cinder后端采 ...
- OpenStack 存储服务 Cinder存储节点部署NFS(十七)
Cinder存储节点部署 1.安装软件包 yum install -y nfs-utils rpcbind 提示:早期版本安装portmap nfs-utils :包括基本的NFS命令与监控程序 rp ...
- OpenStack 存储服务 Cinder存储节点部署LVM(十六)
Cinder存储节点部署 部署在192.168.137.12主机 1.安装lvm2软件包 yum install lvm2 -y 2.启动LVM的metadata服务并且设置该服务随系统启动 syst ...
- CentOS7安装OpenStack(Rocky版)-09.安装Cinder存储服务组件(控制节点)
本文分享openstack的Cinder存储服务组件,cinder服务可以提供云磁盘(卷),类似阿里云云盘 ----------------------- 完美的分隔线 -------------- ...
- openstack核心组件——cinder存储服务(11)
一.cinder 介绍: 理解 Block Storage 操作系统获得存储空间的方式一般有两种: 通过某种协议(SAS,SCSI,SAN,iSCSI 等)挂接裸硬盘,然后分区.格式化.创建文件系 ...
- OpenStack 存储服务 Cinder存储节点部署LVM (十四)
部署在block(10.0.0.103)主机 一)配置lvm 1.安装lvm2软件包 yum install lvm2 -y 2.启动LVM的metadata服务并且设置该服务随系统启动 system ...
- cinder存储服务
一.cinder 介绍: 理解 Block Storage 操作系统获得存储空间的方式一般有两种: 1.通过某种协议(SAS,SCSI,SAN,iSCSI 等)挂接裸硬盘,然后分区.格式化.创建文件系 ...
- OpenStack核心组件-cinder存储服务
1. cinder 介绍 Block Storage 操作系统获得存储空间的方式一般有两种: 1) 通过某种协议(SAS,SCSI,SAN,iSCSI 等)挂接裸硬盘,然后分区.格式化.创建文 ...
- S1_搭建分布式OpenStack集群_10 cinder 存储节点配置
一.安装配置lvm2安装LVM包:# yum install -y lvm2 启动LVM元数据服务,并将其配置为在系统启动时启动:# systemctl enable lvm2-lvmetad.ser ...
随机推荐
- apache笔记
apache笔记 一)两种工作模式 Prefork和worker prefork模式: 一个进程响应一个请求 主进程生成多个工作进程,由工作进程一对一的去响应客户端的请求 过程: 1)用户空间有个具有 ...
- vim简明教程--半小时从入门到精通
https://download.csdn.net/download/qccz123456/10567716 vim三种模式:命令模式.插入模式.底行模式.使用ESC.i.:切换模式. vim [路径 ...
- zencart网站上线前,邮件模板默认网址修改
涉及到的文件 includes\languages\语言包\模板\email_extras.php 后台\includes\languages\语言包\email_extras.php 后台\incl ...
- 可执行程序加一个dl
add_executable(forwarder app/main.cxx) TARGET_LINK_LIBRARIES(forwarder dl)
- OCP协议_电信特殊协议
OCP(Online Charging Protocol)协议——在线计费协议(也称为AAA协议),是中国电信(文中以中国电信为主)充分研究国内外在线计费协议,基于中国电信自己在线计费的需求,参考3G ...
- C#线程中LOCK的意义
学习心得,为的是让新人能理解,高手直接绕~ lock 确保当一个线程位于代码的临界区时,另一个线程不进入临界区.如果其他线程试图进入锁定的代码,则它将一直等待(即被阻止),直到该对象被释放. 引用一句 ...
- CUDA warning C4819的消除
问题描述:在使用VS2010编译CUDA程序时,有很多C4819警告: warning C4819:The file contains a character that cannot be repre ...
- 我说CMMI之一:CMMI是什么--转载
我说CMMI之一:CMMI是什么 有些朋友没有接触过CMMI,正在学习CMMI,CMMI本身的描述比较抽象,所以,读起来有些费劲.有些朋友实施过CMMI,但是可能存在对CMMI的一些误解,因此我想说说 ...
- Five minutes to understand async and defer
Script tag When we want to insert a script into a web page, the standard way is to use the script ta ...
- DevExpress ASP.NET Core v19.1版本亮点:数据网格和树列表
行业领先的.NET界面控件DevExpress 发布了v19.1版本,本文将以系列文章的方式为大家介绍DevExpress ASP.NET Core Controls v19.1中新增的一些控件及增强 ...