ASM 翻译系列第三弹:基础知识 About ASM disk groups, disks and files

原作者:Bane Radulovic

译者: 赵恩东

审核: 魏兴华

DBGeeK社群联合出品

Oracle ASM使用磁盘组来存放数据文件,每一个ASM的磁盘组由一些ASM磁盘组成,每一个ASM磁盘组本身是一个独立的存储单元,是自描述的,对于ASM磁盘组中数据库文件,ASM提供一个文件系统的接口,方便DBA做管理。存放在ASM磁盘组中的文件被均匀的分布在磁盘组中的所有磁盘上,通过这种方式,每一块磁盘都可以提供一致的性能,同时ASM的性能可以比得上裸设备的性能。【摘录自11GR2版本的ASM官方文档】

ASM Disk Groups

一个ASM磁盘组是由一个或多个ASM磁盘组成的,每个ASM磁盘组也是自包含的,有它自己的ASM元数据,这些元数据由ASM实例进行维护和管理。

一般情况下ASM只需要有非常少的磁盘组就可以了,在ASM 11.2版本之前,两个磁盘组一般就足够了,一个用来存放数据文件,另一个存放备份/归档日志文件,在11.2版本,你可能还想单独创建一个磁盘组存放ASM的spfile,OCR和voting盘,当然前提是你计划把这些文件存放到ASM中。

ASM Disks

ASM使用到的磁盘,需要提前由OS/存储管理工程师安装、配置好,这些盘可以是本地的物理设备(IDE, SATA, SCSI,等等),也可以是基于SAN网络输出的LUNs(iSCSI, FC, FCoE, 等等),也可以是通过NAS/NFS网络输出的盘。建议给ASM使用的盘都做分区,即使是计划把一整个盘提供给ASM使用,也建议做成一个单一的分区。

在Exadata环境下,ASM会使用通过LIBCELL接口创建的grid disk,这些盘来自于Exadata的存储节点。

ASM磁盘组可以有最多10000个磁盘,每一个ASM磁盘最大可以有2TB,由于BUG 6453944的存在,往磁盘组中添加大于2TB大小的磁盘有可能会成功,这个BUG在10.2.0.4、11.1.0.7、11.2版本被修复,更多的内容可以参考MOS Doc ID 736891.1 。

译者注:12C的ASM版本在磁盘组的各种限制上进一步得到了释放,具体请参照本系列的【ASM 12C新特性】篇

ASM looks for disks in the OS location specified by ASM_DISKSTRING initialization parameter. All platforms have the default value, so this parameter does not have to be specified. In a cluster, ASM disks can have different OS names on different nodes. In fact, ASM does not care about the OS disk names, as those are not kept in ASM metadata.

ASM Files

任何一个ASM文件只能存放在一个ASM磁盘组中,但是,一个磁盘组可以包含多个数据库的文件,一个数据库里的相关文件也可以存放在多个磁盘组中。

ASM磁盘组可以存储所有类型的数据库文件-数据文件、控制文件、REDO日志、备份集、数据泵文件等等,但是二进制文件和文本文件不能被直接存储。此外ASM也会存储它自身的元数据文件到磁盘组中,元数据文件有它自己的编号机制,与数据文件的编号是独立的,ASM 256以下的编号都是为ASM元数据文件预留的。

ACFS集群文件系统在11.2版本被引入,它进一步扩展了ASM能够支持的文件类型,支持数据库和应用程序的二进制文件、文本文件、日志文件,trace文件,几乎任何传统文件系统能够存放的文件。最为重要的,它是一个集群文件系统。

关于译者

赵恩东,沃趣科技数据库技术工程师,主要参与公司产品实施、测试、维护以及优化。

原文发布于微信公众号 - 沃趣科技(woqutech)

原文发表时间:2016-06-15

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏jiajia_deng

使用七牛云对象储存缓存 wordpress 静态文件加速网站

16560
来自专栏架构师之路

假如让你来设计数据库中间件

13年底负责数据库中间件设计时的设计文档,拿出来和大家分享: 可以了解下数据库中间件技术 可以了解下架构师系统设计的思路 一、总体目标 数据库中间层项目背景不再...

53070
来自专栏惨绿少年

Grafana数据可视化

一个类似Kibana的东西,也是对后端的数据进行实时展示,那么Grafana和Kibana有什么区别?在我看来区别不大,不过在大家的日常使用中Kibana是跟着...

7.7K20
来自专栏Danny的专栏

Navicat备份远程Oracle数据库到本地

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/huyuyang6688/article/...

24020
来自专栏散尽浮华

Linux下selinux简单梳理

在linux环境下执行某些程序时,偶尔会遇到来一个关于selinux的强制模式不可执行的情况,这种情况下需要关闭selinux或者将enforcing改为per...

32060
来自专栏不忘初心

基于zookeeper的daemon框架方案——支持容灾和心跳监控

在线上项目中,很多时候需要起一个daemon做守护进程,用于不停地或以一定间隔地执行工作,比如每隔20s把内存中的数据做快照写磁盘。

24150
来自专栏python3

diango使用数据库

之前写的页面,虽然和用户交互得很好,但并没有保存任何数据,页面一旦关闭,或服务器重启,一切都将回到原始状态。

16030
来自专栏安恒信息

安全漏洞公告

1 Linux Kernel 'linux-image-3.2.0-4-5kc-malta'软件包拒绝服务漏洞Linux Kernel 'linux-image...

33570
来自专栏不想当开发的产品不是好测试

mysql-proxy 简介

# 背景 今天同事分享的主题就是mysql-proxy,于是下来自己了解下,不求精通,只求知道这个玩意 # 简介 mysql-proxy是mysql官方提供的m...

45850
来自专栏我的博客

Collectd介绍

collectd是一个守护(daemon)进程,用来收集系统性能和提供各种存储方式来存储不同值的机制。它会在系统运行和存储信息时周期性的统计系统的相关统计信息。...

39560

扫码关注云+社区

领取腾讯云代金券