IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 系统运维 -> oracle RAC asm管理 -> 正文阅读

[系统运维]oracle RAC asm管理

参考链接:

  • https://blog.csdn.net/qq_34556414/article/details/79716566
  • https://www.cnblogs.com/zhangshengdong/p/11935035.html
  • https://blog.csdn.net/weixin_33699914/article/details/91963556 (主)
  • https://blog.csdn.net/weixin_34077371/article/details/92543318

一,ASM查看磁盘组状态

SQL> select group_number,name, state,total_mb,free_mb from v$asm_diskgroup;

SQL> select group_number,name,path,failgroup,STATE,TOTAL_MB,FREE_MB from v$asm_disk;

二,ASMCMD工具

asmcmd是一个命令行实用程序,可用于轻松地查看和操纵ASM 磁盘组中的文件和目录。该实用程序可以列出磁盘组
内容、执行搜索、创建和删除目录以及显示空间使用情况等等,grid用户下调用asmcmd,可用rm 命令删除磁盘里
的文件等。

  • asmcmd -p 在命令行前显示当前路径
  • du 显示指定的ASM目录下ASM文件占用的所有磁盘空间
  • lsdg 列出所有磁盘组及其属性
  • lsdsk 列出此ASM实例可见的所有磁盘
  • rm 删除ASM文件或目录
  • remap 修理磁盘上遭到破坏或损坏的一系列物理块
[grid@rac1 ~]$ asmcmd lsdsk -k
Total_MB  Free_MB  OS_MB  Name           Failgroup      Failgroup_Type  Library  Label  UDID  Product  Redund   Path
    2048     1740   2048  OCR_VOTE_0000  OCR_VOTE_0000  REGULAR         System                         UNKNOWN  /dev/asm-diskb
    2048     1739   2048  OCR_VOTE_0001  OCR_VOTE_0001  REGULAR         System                         UNKNOWN  /dev/asm-diskc
    2048     1739   2048  OCR_VOTE_0002  OCR_VOTE_0002  REGULAR         System                         UNKNOWN  /dev/asm-diskd
   40960    38212  40960  DATA_0000      DATA_0000      REGULAR         System                         UNKNOWN  /dev/asm-diske
   30720    30390  30720  FRA_0000       FRA_0000       REGULAR         System                         UNKNOWN  /dev/asm-diskf
[grid@rac1 ~]$ 
[grid@rac1 ~]$ 
[grid@rac1 ~]$ asmcmd lsdsk
Path
/dev/asm-diskb
/dev/asm-diskc
/dev/asm-diskd
/dev/asm-diske
/dev/asm-diskf

ASMCMD> lsdg
State    Type    Rebal  Sector  Block       AU  Total_MB  Free_MB  Req_mir_free_MB  Usable_file_MB  Offline_disks  Voting_files  Name
MOUNTED  EXTERN  N         512   4096  1048576     40960    38212                0           38212              0             N  DATA/
MOUNTED  EXTERN  N         512   4096  1048576     30720    30390                0           30390              0             N  FRA/
MOUNTED  NORMAL  N         512   4096  1048576      6144     5218             2048            1585              0             Y  OCR_VOTE/


ASMCMD> ls   
DATA/
FRA/
OCR_VOTE/
ASMCMD> cd fra
ASMCMD> ls
RACDB/
ASMCMD> cd racdb
ASMCMD> ls
CONTROLFILE/
ONLINELOG/
ASMCMD> cd onlinelog
ASMCMD> ls
group_1.257.1080862029
group_2.258.1080862031
group_3.259.1080865393
group_4.260.1080865395

三,操作实例

1, 创建ASM磁盘组

切换至grid用户,使用sqlplus命令来登录ASM实例:sqlplus ‘/as sysasm’,输入如下语句:

create diskgroup data external redundancy disk '/dev/asm-diske','/dev/asm-diskg';

创建normal冗余磁盘组:

CREATE DISKGROUP test NORMAL REDUNDANCY
FAILGROUP F1 DISK '/dev/asm-diskm' NAME D1 SIZE 1024 M ,
                                     '/dev/asm-diskn' NAME D2 SIZE 1024 M
FAILGROUP F2 DISK '/dev/asm-disko' SIZE 1024 M ,
                                    '/dev/asm-diskp' SIZE 1024 M;

2, 添加磁盘

SQL> select group_number,name, state,total_mb,free_mb from v$asm_diskgroup;

GROUP_NUMBER NAME				                   STATE				       TOTAL_MB	FREE_MB

	   1 DATA											MOUNTED 			       40960	  38212
	   2 FRA											MOUNTED 			       30720	  30390
	   3 OCR_VOTE											MOUNTED 				4096	   3304



SQL>  select group_number,name,path from v$asm_disk;               

GROUP_NUMBER NAME											PATH
	   0												/dev/asm-diskb
	   2 FRA_0000											/dev/asm-diskf
	   1 DATA_0000											/dev/asm-diske
	   3 OCR_VOTE_0001										/dev/asm-diskc
	   3 OCR_VOTE_0002										/dev/asm-diskd
# 清除磁盘头信息
[root@rac1 ~]#  dd if=/dev/zero of=/dev/asm-diskb bs=8k count=256 

SQL> alter diskgroup OCR_VOTE add disk '/dev/asm-diskb';

SQL> select group_number,name,path from v$asm_disk;

GROUP_NUMBER NAME											PATH
	   2 FRA_0000											/dev/asm-diskf
	   1 DATA_0000											/dev/asm-diske
	   3 OCR_VOTE_0001										/dev/asm-diskc
	   3 OCR_VOTE_0002										/dev/asm-diskd
	   3 OCR_VOTE_0000										/dev/asm-diskb


SQL> select group_number,name, state,total_mb,free_mb from v$asm_diskgroup; 

GROUP_NUMBER NAME									STATE				    TOTAL_MB	FREE_MB
	   1 DATA											MOUNTED 			       40960	  38212
	   2 FRA											MOUNTED 			       30720	  30390
	   3 OCR_VOTE											MOUNTED 				6144	   5218

3, 挂载与卸载磁盘组

ASM磁盘组只有在当前节点的ASM实例上挂载,才能被该节点的数据库实例访问:

alter diskgroup data mount;

卸载ASM磁盘组:

alter diskgroup data dismount;

4,删除磁盘

从ASM磁盘组删除磁盘,需事先查得删除的ASM磁盘的名称,而非其操作系统设备名,建议登录grid用户,使用asmcmd命令获取磁盘名:

asmcmd lsdsk -k

将需删除磁盘对应的name列替换如下命令中的OCR_VOTE_0000即可:

alter diskgroup data drop disk OCR_VOTE_0000;

通过alter diskgroup dgname undrop disks语句来取消删除的操作。

删除磁盘以后,ASM磁盘组会自动进行一次rebalance操作,添加磁盘后,还会进行一次rebalance。如果我们需要更换磁盘,那么建议将删除和添加磁盘的操作放在一起执行:
实际生产中,先拔下损坏的磁盘,再插入新的磁盘以后,执行下面的语句(假设DgroupB的Disk3损坏,现在使用raw4去替换)

alter diskgroup DgroupB drop disk Disk3 add failgroup fg1 disk ‘/dev/raw/raw4’  name Disk4;

5,其他补充

添加故障组
    alter diskgroup dgn  add failgroup fgn3 disk  'ORCL:DISKD01';
删除磁盘组中的磁盘(用磁盘名)
    alter diskgroup dgn  drop disk ASMDISKB02;
删除磁盘时同时添加磁盘,可减少重平衡次数
    alter diskgroup dge drop disk DISKC01 add disk 'ORCL:DISKC02';
删除故障组
    alter diskgroup dgn drop disks in failgroup fgn3;
删除故障组同时添加故障组
    alter diskgroup dgn  drop disks in failgroup fg3 add failgroup fg4 disk 'ORCL:DISKD01';
停止磁盘从一个磁盘组中删除
    alter diskgroup dg1 undrop disks;
平衡磁盘数据
    alter diskgroup dg1 rebalance;
    alter diskgroup dg1 rebalance wait;     --wait即等到数据平衡结束才在命令行提示结束
    alter diskgroup dg1 rebalance power 11;  --加快平衡速度
修改加快同步
    alter system set asm_power_limit=10;
停止平衡磁盘数据
    alter diskgroup dg1 rebalance power 0;
挂载和卸载磁盘组
    alter diskgroup dgn mount;
    alter diskgroup dgn dismount;
    alter diskgroup dg1 dismount force;
检测磁盘组一致性
    ALTER DISKGROUP dgn CHECK ALL;
删除ASM磁盘组
    drop diskgroup  dgd;
    drop diskgroup  dgc including contents;
  系统运维 最新文章
配置小型公司网络WLAN基本业务(AC通过三层
如何在交付运维过程中建立风险底线意识,提
快速传输大文件,怎么通过网络传大文件给对
从游戏服务端角度分析移动同步(状态同步)
MySQL使用MyCat实现分库分表
如何用DWDM射频光纤技术实现200公里外的站点
国内顺畅下载k8s.gcr.io的镜像
自动化测试appium
ctfshow ssrf
Linux操作系统学习之实用指令(Centos7/8均
上一篇文章      下一篇文章      查看所有文章
加:2021-08-20 15:29:39  更:2021-08-20 15:31:50 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/15 9:45:15-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码