GNU/Linux >> Belajar Linux >  >> Linux

Cara Memverifikasi apakah Disk/Partisi Digunakan oleh Oracle ASM, digunakan oleh Oracle ASM atau tidak pernah digunakan oleh Oracle ASM

Program C kecil di bawah ini akan membantu kita untuk mengidentifikasi apakah Disk/Partisi masih digunakan oleh ASM, telah digunakan oleh ASM atau belum digunakan oleh ASM pada platform Unix atau Linux.

1. Pertama-tama, kita perlu mengkompilasi kode C di bawah ini:

#include <stdio.h>
#include <fcntl.h> 
#define BLOCK_SIZE 4096 
int main(int argc, char *argv[]) 
{ 
    char buf[BLOCK_SIZE]; 
    char *fname; 
    int  fd; 
    int  count; 

    if (argc != 2) 
    { 
      fprintf(stderr, "Exactly one argument required\n"); 
      return (-1); 
    } 

    fname = argv[1]; 
    fd = open(fname, O_RDONLY); 
    if (fd < 0) 
    { 
      perror(fname); 
      return (-1); 
    } 

    count = read(fd, buf, sizeof(buf)); 
    if (count < 0) 
    { 
      perror(fname); 
      return (-1); 
    } 
    if (count < sizeof(buf)) 
    {  
      return (1); 
    } 

    if ( buf[32] == 'O' && buf[33] == 'R' && buf[34] == 'C' && buf[35] == 'L' 
      && buf[36] == 'D' && buf[37] == 'I' && buf[38] == 'S' && buf[39] == 'K') 
    {  

      if (buf[71] != 4) { 
        printf("This disk %s still used by ASM\n",argv[1]); 
        return (0);                                      
      } 
      else 
      printf("This disk %s has been used by ASM\n",argv[1]); 

      return (0);         
     } 

    printf("This disk %s has not been used by ASM\n",argv[1]); 
    return (1); 
}

2. Simpan kode di atas sebagai file ASCII , kemudian menggunakan Kompilator C kompilasi sebagai berikut:

$ ls  
-rw-r--r--  1 oracle oinstall 2014 Jun 16 15:57 checkasmdisk.c
$ cc checkasmdisk.c -o checkasmdisk
$ ls  
-rwxr-xr-x  1 oracle oinstall 5670 Jun 16 15:57 checkasmdisk 
-rw-r--r--  1 oracle oinstall 2014 Jun 16 15:57 checkasmdisk.c

3. Periksa disk yang diinginkan dengan skrip yang dikompilasi. kita dapat memperoleh 4 status seperti yang ditunjukkan di bawah ini sebagai hasil dari skrip:

1. Disk belum digunakan oleh ASM

Connected to: 
Oracle Database 11g Enterprise Edition Release 11.1.0.6.0 - Production 
With the Partitioning, OLAP, Data Mining and Real Application Testing options 

SQL> !dd if=/dev/zero of=/dev/sda14 bs=8192 count=12800 
12800+0 records in 
12800+0 records out 

SQL> !checkasmdisk /dev/sda14 

This disk /dev/sda14 has not been used by ASM

2. Disk masih digunakan oleh ASM

SQL> create diskgroup DATADG external redundancy disk '/dev/sda14'; 

Diskgroup created. 

SQL> !checkasmdisk /dev/sda14 

This disk /dev/sda14 still used by ASM 

3. Disk telah digunakan oleh ASM

SQL> drop diskgroup DATADG; 

Diskgroup dropped. 

SQL> !checkasmdisk /dev/sda14 

This disk /dev/sda14 has been used by ASM

4. Disk tidak dapat diakses

# ls -l /dev/sda14 

brw-rw---- 1 oracle dba 8, 14 Jun 11 19:12 /dev/sda14 

# chown root:disk /dev/sda14 

# ls -l /dev/sda14 
brw-rw---- 1 root disk 8, 14 Jun 11 19:12 /dev/sda14 

SQL> !checkasmdisk /dev/sda14 

/dev/sda14: Permission denied 

brw-rw---- 1 root disk 8, 14 Jun 11 19:12 /dev/sda14 
Oracle ASM :Skrip shell untuk memetakan perangkat disk fisik ke disk ASMLIB


Linux
  1. Cara membuat kata sandi acak di linux menggunakan /dev/random

  2. Bagaimana Linux Menangani Beberapa Pemisah Jalur Berturut-turut (/home////username///file)?

  3. Seberapa Portabel /dev/stdin, /dev/stdout Dan /dev/stderr?

  1. Kapan Menggunakan /dev/random Vs /dev/urandom?

  2. Bagaimana Membungkam Sepenuhnya Cronjob Ke /dev/null/?

  3. Bagaimana Cara Memasang Disk Ini?

  1. Bagaimana cara mengganti harddisk yang gagal di RAID perangkat lunak Linux

  2. Linux:Perbedaan Antara /dev/console , /dev/tty Dan /dev/tty0?

  3. Bagaimana Linux menggunakan /dev/tty dan /dev/tty0