GNU/Linux >> Linux Esercitazione >  >> Linux

Come verificare se un disco/partizione è in uso da Oracle ASM, è stato utilizzato da Oracle ASM o non è mai stato utilizzato da Oracle ASM

Il piccolo programma C riportato di seguito ci aiuterà a identificare se un disco/partizione è ancora utilizzato da ASM, è stato utilizzato da ASM o non è stato utilizzato da ASM su piattaforme Unix o Linux.

1. Prima di tutto, dobbiamo compilare il seguente codice C:

#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. Salva il codice sopra come file ASCII , quindi utilizzando un compilatore C compilalo come segue:

$ 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. Controllare i dischi desiderati con lo script compilato. possiamo ottenere 4 stati come mostrato di seguito come risultato dello script:

1. Il disco non è stato utilizzato da 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. Il disco è ancora utilizzato da 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. Il disco è stato utilizzato da ASM

SQL> drop diskgroup DATADG; 

Diskgroup dropped. 

SQL> !checkasmdisk /dev/sda14 

This disk /dev/sda14 has been used by ASM

4. Impossibile accedere al disco

# 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:script Shell per mappare i dispositivi del disco fisico sui dischi ASMLIB


Linux
  1. Come sostituire un disco rigido guasto nel software RAID Linux

  2. In che modo Linux gestisce più separatori di percorsi consecutivi (/home////nomeutente///file)?

  3. Linux:differenza tra /dev/console , /dev/tty e /dev/tty0?

  4. Quanto sono portatili /dev/stdin, /dev/stdout e /dev/stderr?

  5. Come silenziare completamente un Cronjob in /dev/null/?

Come codificare in base64 /dev/random o /dev/urandom?

Come si scambia /dev/sda con /dev/sdb?

Come Linux usa /dev/tty e /dev/tty0

Come ottenere il nome del disco che contiene una partizione specifica

echo o print /dev/stdin /dev/stdout /dev/stderr

Perché sono necessari < o > per usare /dev/tcp