热门标签 | HotTags
当前位置:  开发笔记 > 程序员 > 正文

DB2和磁盘存储虚拟化如此重要的原因

从传统上讲,大型机的存储配置流程一直缓慢而又复杂。除了采购和硬件安装外,该流程还包含大量针对输入输出定义文件(IODF)、SMS存储组和自动类选择(ACS)例程的主机活动。IBM创建了zDAC来帮助系统程序员匹配IODF与存储控制器,但这只是配置流程的一

从传统上讲,大型机的存储配置流程一直缓慢而又复杂。除了采购和硬件安装外,该流程还包含大量针对输入/输出定义文件 (IODF)、SMS 存储组和自动类选择 (ACS) 例程的主机活动。IBM 创建了 zDAC 来帮助系统程序员匹配 IODF 与存储控制器,但这只是配置流程的一

从传统上讲,大型机的存储配置流程一直缓慢而又复杂。除了采购和硬件安装外,该流程还包含大量针对输入/输出定义文件 (IODF)、SMS 存储组和自动类选择 (ACS) 例程的主机活动。IBM 创建了 zDAC 来帮助系统程序员匹配 IODF 与存储控制器,但这只是配置流程的一个方面。当采用 DB2 基于时间点的系统恢复技术的时候,或者利用 Symmetrix Remote Data Facility (SRDF) 和对等远程拷贝 (PPRC) 来实现基于阵列的长距离复制的时候,有一些注意事项。可以将整个过程都融入变更控制中,这种做法虽然是必要的,但可能既枯燥又费时。

这种痛苦而又漫长的过程不可避免地会导致最终用户频繁地要求获取超过当时所需空间的存储空间,以便减少空间不足所带来的困扰。有时候,此种额外空间并未得到使用,或者更糟糕,已经分配但从未使用,这是一种隐式浪费。例如,如果使用 8 GB PRIQTY 创建 DB2 线性,即使 DB2 仅写入一小部分所分配的数据集,而所有正常的容量规划和评估工具仍然认定该空间已被利用。

完全配置完存储空间之后,仍有一些挑战可能会导致应用程序性能不良。某些光纤通道驱动器容量可能高达 600 GB。试想一下,有多少 MOD-9 才能构建一个 600 GB 的光纤通道驱动器。

存储管理

存储管理员必须思考下列一些问题:
 如何管理控制器中的大型磁盘?
 满足应用程序 SLA 的最佳方式是什么?
 如何区分重要的生产应用程序,例如测试应用程序和 QA 应用程序?
 性能需求(IOPS 或 MB/秒)是什么?
 可用性需求(RAID 保护和远程复制)是什么?

促使这项活动更加复杂的关键因素之一是:光纤通道驱动器的 IOPS 密度最近有所降低。旋转磁盘容量大大提升,但速度却未显著加快,因此 IOPS 提供的速度与数年前大致相同。图 1 就这一趋势进行了说明。

DB2和磁盘存储虚拟化如此重要的原因

图 1. 随着旋转磁盘容量逐渐变大,每 GB 的 I/O 能力以惊人的速度大幅下降。

IOPS 密度的计算方法:驱动器 I/O 能力(每秒 I/O)除以驱动器大小(单位:GB)。从图 1 中可以明显看出,四个 146 GB 的光纤通道驱动器实现的 I/O 可达一个 600 GB 光纤通道驱动器的四倍。然而,问题在于,随着高密度替代品的面世,146 GB(或者更小的)驱动器将会很快绝迹。过去的 15 年一直在延续这种趋势,低容量磁盘逐渐被高容量磁盘所代替,迫使您对这些超大型传动装置部署 DB2 系统,这放大了共享相同物理驱动器的工作负载之间的争用现象。

图 1 显示,当前的 600 GB 光纤通道驱动器的性能为 0.25 IOPS/GB,远低于图表第一栏呈现的慢速 9 GB 驱动器。这种 IOPS 密度降低是一种不太好的趋势,如果应用程序能够实现自身的 SLA,就能阻止这一趋势再继续。但这需要进行一场量子变革。

固态硬盘打破了 IOPS 密度的螺旋下降趋势

这场量子变革以固态硬盘 (SSD) 的方式存在已久。200 GB SSD 可以实现的 IOPS 密度约为 25 IOPS/GB,是 600 GB 旋转硬盘的 100 倍。

虽然依然十分昂贵,但是,因为众多供应商之间的竞争以及企业就绪 MLC 驱动器的推出,SSD 的价格开始持续下降。随着 IOPS 密度的逐渐下降,人们很难想象,如果未来没有这些 SSD 应该如何部署企业级阵列。然后,惟一的挑战在于如何对它们进行有效利用。

我们很难按照 z/OS 的方式将卷映射至实际的后端存储阵列实例;也就是说,在 z/OS 中显示为两个独立物理卷的内容实际上可能呈现在同一物理磁盘上。任何企图通过区分表及其索引来提升性能的尝试,都可能会在不知不觉中将它们置于同一磁盘上,因此会导致争用现象。现今的阵列中并未提供解决这一问题的简便解决方案。

推荐阅读
  • 本文讨论了同事工资打听的话题,包括同工不同酬现象、打探工资的途径、为什么打听别人的工资、职业的本质、商业价值与工资的关系,以及如何面对同事工资比自己高的情况和凸显自己的商业价值。故事中的阿巧发现同事的工资比自己高后感到不满,通过与老公、闺蜜交流和搜索相关关键词来寻求解决办法。 ... [详细]
  • 本文是一位90后程序员分享的职业发展经验,从年薪3w到30w的薪资增长过程。文章回顾了自己的青春时光,包括与朋友一起玩DOTA的回忆,并附上了一段纪念DOTA青春的视频链接。作者还提到了一些与程序员相关的名词和团队,如Pis、蛛丝马迹、B神、LGD、EHOME等。通过分享自己的经验,作者希望能够给其他程序员提供一些职业发展的思路和启示。 ... [详细]
  • 本文介绍了Python版Protobuf的安装和使用方法,包括版本选择、编译配置、示例代码等内容。通过学习本教程,您将了解如何在Python中使用Protobuf进行数据序列化和反序列化操作,以及相关的注意事项和技巧。 ... [详细]
  • sklearn数据集库中的常用数据集类型介绍
    本文介绍了sklearn数据集库中常用的数据集类型,包括玩具数据集和样本生成器。其中详细介绍了波士顿房价数据集,包含了波士顿506处房屋的13种不同特征以及房屋价格,适用于回归任务。 ... [详细]
  • 本文介绍了2019年上半年内蒙古计算机软考考试的报名通知和考试时间。考试报名时间为3月1日至3月23日,考试时间为2019年5月25日。考试分为高级、中级和初级三个级别,涵盖了多个专业资格。报名采取网上报名和网上缴费的方式进行,报考人员可登录内蒙古人事考试信息网进行报名。详细内容请点击查看。 ... [详细]
  • 拥抱Android Design Support Library新变化(导航视图、悬浮ActionBar)
    转载请注明明桑AndroidAndroid5.0Loollipop作为Android最重要的版本之一,为我们带来了全新的界面风格和设计语言。看起来很受欢迎࿰ ... [详细]
  • 从零学Java(10)之方法详解,喷打野你真的没我6!
    本文介绍了从零学Java系列中的第10篇文章,详解了Java中的方法。同时讨论了打野过程中喷打野的影响,以及金色打野刀对经济的增加和线上队友经济的影响。指出喷打野会导致线上经济的消减和影响队伍的团结。 ... [详细]
  • 闭包一直是Java社区中争论不断的话题,很多语言都支持闭包这个语言特性,闭包定义了一个依赖于外部环境的自由变量的函数,这个函数能够访问外部环境的变量。本文以JavaScript的一个闭包为例,介绍了闭包的定义和特性。 ... [详细]
  • Android源码深入理解JNI技术的概述和应用
    本文介绍了Android源码中的JNI技术,包括概述和应用。JNI是Java Native Interface的缩写,是一种技术,可以实现Java程序调用Native语言写的函数,以及Native程序调用Java层的函数。在Android平台上,JNI充当了连接Java世界和Native世界的桥梁。本文通过分析Android源码中的相关文件和位置,深入探讨了JNI技术在Android开发中的重要性和应用场景。 ... [详细]
  • Go GUIlxn/walk 学习3.菜单栏和工具栏的具体实现
    本文介绍了使用Go语言的GUI库lxn/walk实现菜单栏和工具栏的具体方法,包括消息窗口的产生、文件放置动作响应和提示框的应用。部分代码来自上一篇博客和lxn/walk官方示例。文章提供了学习GUI开发的实际案例和代码示例。 ... [详细]
  • 本文介绍了程序员最美的情人节礼物,即使用JS渲染的3D玫瑰,通过在QQ空间和人人网上分享这个特殊的礼物,可以给情人带来惊喜和喜悦。 ... [详细]
  • 海马s5近光灯能否直接更换为H7?
    本文主要介绍了海马s5车型的近光灯是否可以直接更换为H7灯泡,并提供了完整的教程下载地址。此外,还详细讲解了DSP功能函数中的数据拷贝、数据填充和浮点数转换为定点数的相关内容。 ... [详细]
  • 本文介绍了一种处理AJAX操作授权过期的全局方式,以解决Asp.net MVC中Session过期异常的问题。同时还介绍了基于WebImage的图片上传工具类。详细内容请参考链接:https://www.cnblogs.com/starluck/p/8284949.html ... [详细]
  • 本文介绍了在Mac上安装Xamarin并使用Windows上的VS开发iOS app的方法,包括所需的安装环境和软件,以及使用Xamarin.iOS进行开发的步骤。通过这种方法,即使没有Mac或者安装苹果系统,程序员们也能轻松开发iOS app。 ... [详细]
  • 如何在跨函数中使用内存?
    本文介绍了在跨函数中使用内存的方法,包括使用指针变量、动态分配内存和静态分配内存的区别。通过示例代码说明了如何正确地在不同函数中使用内存,并提醒程序员在使用动态分配内存时要手动释放内存,以防止内存泄漏。 ... [详细]
author-avatar
U曹宸prideX_J
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有