ASM数据库自动存储管理浅析

关于自动存储管理(ASM)的讨论很多,但是到底什么是ASM?ASM是一个有效的抽象层,使你的Oracle数据库可以与叫做diskgroups的抽象空间一起使用,而不是直接使用datafiles。这带来了很多好处,但是也要求学习一些新的概念、命令、使用和管理任务。所以在投入你的生产系统之前,看看它解决什么、管理什么,以及对它的正反面评价。

为什么创建它?

回答这个问题的***方式是直接追溯源头,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

# as opposed to RDBMS for a normal Oracle instance

INSTANCE_TYPE=ASM

# these names will be used in place of datafile names when you create tablespaces

ASM_DISKGROUPS=SEAN, AARON

processes=100

# this parameter is platform specific and is the path to the raw disk device

ASM_DISKSTRING=’/dev/cciss/c0d0p1′

# on 11g you should use diagnostic_dest instead of these

background_dump_dest=/opt/oracle/admin/+ASM/bdump’

core_dump_dest=/opt/oracle/admin/+ASM/cdump’

user_dump_dest=/opt/oracle/admin/+ASM/udump’

c. 启动ASM实例

$ sqlplus / as sysdba

SQL> startup

d. 创建磁盘组

SQL> create diskgroup SEAN disk ‘/dev/cciss/c0d0p1’;

e. 检查表空间的创建

你可能会猜测,创建一个表空间会有轻微的改变。默认方法如下所示:

SQL> create tablespace sean_space datafile ‘+SEAN’ size 1GB;

不过想一下这个很好的特性。如果在你的数据库中init.ora文件你设置参数为:

db_create_file_dest=+SEAN

那么你可以这样做:

SQL> create tablespace sean_space;

然后让Oracle做其余的工作。在这两种情形下,你将发现在v$datafile中列出的文件路径是和抽象的+SEAN 磁盘组有关,而不是与一个实际的操作系统数据文件。

f. 更多的

当然简化文件名称和表空间的创建只是ASM可以为你做的工作的冰山一角。它还可以提供一个冗余级别。

在数据库方面,外部冗余能力主要是当你在硬件级别(RAID)上或Oracle可以看到的其它外部方法中具有冗余。换句话说,如果asm_diskstring设备是它们自己的逻辑,隐藏物理磁盘于一些冗余的硬件层后面,那么你就会有外部冗余能力。

但是,如果你没有这个冗余能力,那么ASM可以提供。你可以指定冗余、失败组和一组其它的选项来防止损失一个或多个磁盘、控制器或甚至是整个SAM失效。ASM还提供了在磁盘组中均匀分布的I/O。因为ASM很好的了解背后发生了什么,所以Oracle可以自动的为你提供I/O到磁盘的一个更好的平衡。

使用ASM遇到的挑战

ASM当然是一个具有很大潜能的强大技术。但是对于每一个技术解决方案,都会有很多的挑战。对于ASM,它潜在地破坏了Unix系统管理组和数据库/数据库管理员组间力量的普通平衡。以前的组管理磁盘、硬件和操作系统级别,使数据库管理员与它们协作获取新的资源。这将在某种程度上挑战这个平衡,而这会引起一些来自于这个组的阻力。

***,应该是业务需求促使了它的采用。还要注意到ASM仍然是处于企业计算认识阶段,相对还比较新。有一些供应商他们的核心业务已经放在逻辑空间管理器/文件系统空间中很多年了。一般来说,对于软件系统和可靠性来说成熟是很重要的。

总结

自动存储管理很强大,它为目前部署的不断发展的大型数据库系统提供了解决方案。它还可以为较小数据库安装或者那些使用集群的数据库提供解决方案。如同对于任何新技术一样,评估、测试,然后更多的测试。

【编辑推荐】

  1. 步骤:Oracle 10g ASM On SLES9
  2. 对即将上线的Oracle10g ASM生产数据库进行备份恢复测试

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/244927.html<

(0)
运维的头像运维
上一篇2025-04-25 23:06
下一篇 2025-04-25 23:07

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注