这带来了很多好处,但是也要求学习一些新的概念、命令、使用和管理任务。所以在投入你的生产系统之前,看看它解决什么、管理什么,以及对它的正反面评价。
为什么创建它?
回答这个问题的最好方式是直接追溯源头,Bill Bridge——自动存储管理的最初架构师。在Oracle Press标题中的Oracle ASM,Bill提供了一个链接,他在那里讨论了使用供应商特定操作系统的文件系统来管理Oracle数据文件放置所遇到的问题:
1. 对于归档日志和备份,操作系统供应商不提供共享磁盘文件系统。
2. 逻辑卷管理器隐藏了文件的位置,使得很难管理磁盘I/O和提供良好的统计。
3. 当磁盘数超过100时,现有的lvm不能工作得很好。
4. 当数据库有1000以上的数据文件时,操作系统和Oracle不能很好地处理数据库。
5. 当有大量数据文件时命名就变得很困难了。
6. 特性和文件系统限制随操作系统的不同而不同。
7. 操作系统级的用户可以通过标准使用接触到Oracle文件,而Oracle并不知道。
所以,他通过建立Oracle自己的文件系统开始解决这些问题。他的目标是提供这些特性:
1. 与Oracle紧密集成,并与集群一起使用(并行服务器)。
2. 自动使用新的存储,作为磁盘单元或磁盘组来管理。
3. 支持成千上万的磁盘。
4. 文件不会名字,并会在操作系统中隐藏起来。
谁需要它?
现在快速浏览一下上面那些问题和解决方案会帮助你确定谁需要ASM。起初,它是用来处理现在很大型的联机数据库。所以如果它包括你的商店,那么你可能已经在关注它了,或者开始执行ASM。如果你的数据库较小,数据文件也不多,那么你可能需要再一些理由使你考虑采用它。
1. 你将要熟悉一些新技术,并且应该从在你的开发环境中建立它开始,并测试几个月。
2. 如果你想从你现有的磁盘子系统中获得更高的性能,并获得更好的统计用于预测磁盘I/O。
3. 如果你正在使用RAC,那么就需要考虑ASM了。
开始
ASM是由一个实例管理,非常类似于Oracle数据库。但是初始参数是非常有限的,而且启动过程也简单得多。
a. 将你的ORACLE_SID设置为+ASM1
b. 编辑init.ora
<div class="codetitle"><a style="CURSOR: pointer" data="12395" class="copybut" id="copybut12395" onclick="doCopy('code12395')"> 代码如下: