Ajout de disques à ASM dans les systèmes de fichiers

Dans cet article, nous allons vous montrer comment ajouter des disques manuellement dans le système d'exploitation Linux. Il explique également comment les présenter comme étant les disques que nous utilisons pour stocker les données de notre base de données Oracle.

Tout d'abord, nous allons dresser la liste des disques que nous avons dans notre machine virtuelle.

Il existe deux façons de procéder, l'une manuelle et l'autre à l'aide d'un formulaire graphique, comme indiqué ci-dessous.

Dans ce document, nous n'allons pas effectuer les actions graphiquement, car elles sont assez intuitives. Vous pouvez vous fier à la documentation pour effectuer les actions graphiquement. Il existe d'autres alternatives graphiques et largement utilisées, telles que gparted, que nous présenterons dans des articles ultérieurs. Dans le cas présent, nous allons donc procéder manuellement.

Etapes pour partitionner manuellement un disque Linux

Étape 1 - Partitionner le disque

Nous dressons la liste des disques dont nous disposons avec lsblk. Dans ce cas, nous avons trois disques de 25G à partitionner (sdb,sdc,sdd).

Vous pouvez faire la même chose avec fdisk -l

Nous allons partitionner les périphériques. Pour ce faire, nous utilisons la commande fdisk (en tant que root) et le périphérique à partitionner.

fdisk /dev/sdb

[root@oracle-21 ~]# fdisk /dev/sdb
Welcome to fdisk (util-linux 2.32.1).
Changes will remain in memory only, until you decide to write them.
Be careful before using the write command.

Device does not contain a recognized partition table.
Created a new DOS disklabel with disk identifier 0xf8f72c85.

Command (m for help): n
Partition type
p   primary (0 primary, 0 extended, 4 free)
e   extended (container for logical partitions)T
Select (default p): p
Partition number (1-4, default 1): 1
First sector (2048-52428799, default 2048):
Last sector, +sectors or +size{K,M,G,T,P} (2048-52428799, default 52428799):
<enter>

Created a new partition 1 of type ‘Linux’ and of size 25 GiB.

Command (m for help): t
Selected partition 1
Hex code (type L to list all codes): L

0  Empty           24  NEC DOS         81  Minix / old Lin bf  Solaris       
1  FAT12           27  Hidden NTFS Win 82  Linux swap / So c1  DRDOS/sec (FAT-
2  XENIX root      39  Plan 9          83  Linux           c4  DRDOS/sec (FAT-
3  XENIX usr       3c  PartitionMagic  84  OS/2 hidden or  c6  DRDOS/sec (FAT-
4  FAT16 <32M      40  Venix 80286     85  Linux extended  c7  Syrinx
5  Extended        41  PPC PReP Boot   86  NTFS volume set da  Non-FS data  
6  FAT16           42  SFS             87  NTFS volume set db  CP/M / CTOS / .
7  HPFS/NTFS/exFAT 4d  QNX4.x          88  Linux plaintext de  Dell Utility  
8  AIX             4e  QNX4.x 2nd part 8e  Linux LVM       df  BootIt 
9  AIX bootable    4f  QNX4.x 3rd part 93  Amoeba          e1  DOS access
a  OS/2 Boot Manag 50  OnTrack DM      94  Amoeba BBT      e3  DOS R/O      
b  W95 FAT32       51  OnTrack DM6 Aux 9f  BSD/OS          e4  SpeedStor    
 
c  W95 FAT32 (LBA) 52  CP/M            a0  IBM Thinkpad hi ea  Rufus alignment
e  W95 FAT16 (LBA) 53  OnTrack DM6 Aux a5  FreeBSD         eb  BeOS fs
f  W95 Ext’d (LBA) 54  OnTrackDM6      a6  OpenBSD         ee  GPT
10  OPUS            55  EZ-Drive        a7  NeXTSTEP        ef  EFI (FAT-12/16/
11  Hidden FAT12    56  Golden Bow      a8  Darwin UFS      f0  Linux/PA-RISC b
12  Compaq diagnost 5c  Priam Edisk     a9  NetBSD          f1  SpeedStor
14  Hidden FAT16 <3 61  SpeedStor       ab  Darwin boot     f4  SpeedStor
16  Hidden FAT16    63  GNU HURD or Sys af  HFS / HFS+      f2  DOS secondary 
17  Hidden HPFS/NTF 64  Novell Netware  b7  BSDI fs         fb  VMware VMFS   
18  AST SmartSleep  65  Novell Netware  b8  BSDI swap       fc  VMware VMKCORE
1b  Hidden W95 FAT3 70  DiskSecure Mult bb  Boot Wizard hid fd  Linux raid auto
1c  Hidden W95 FAT3 75  PC/IX           bc  Acronis FAT32 L fe  LANstep
1e  Hidden W95 FAT1 80  Old Minix       be  Solaris boot    ff  BBT           


Hex code (type L to list all codes): 83
The partition table has been altered.

Calling ioctl() to re-read partition table.
Syncing disks.

La séquence est la suivante :

n,p,1,<INTRO>,<INTRO>,w

Si nous voulons voir les options que nous allons utiliser avant le partitionnement :

n,p,1,<INTRO>, <INTRO>,t,83,w

Nous indiquons ainsi au SSOO qu'il s'agit d'une nouvelle partition (n), qu'il s'agit d'une partition primaire (p), le numéro de la partition (1), nous appuyons sur Entrée, ce qui indique au SSOO que nous voulons que l'ensemble du disque soit dans une seule partition. Ensuite, nous appuyons sur la touche (t) pour lui indiquer le type de partition, (83) pour lui indiquer qu'il s'agit d'une partition Linux, puis (w). Lorsque nous appuyons sur w, le SSOO commence à apporter des modifications au disque.

Por lo tanto la secuencia sería: n,p,1,<INTRO>,<INTRO>,w

En ce qui concerne les types de partition disponibles, il est possible d'afficher toutes les options disponibles avant de choisir le type de partition, dans ce cas Linux, en appuyant sur la touche L, comme le montre la sortie d'écran ci-dessus.

Avec n'importe laquelle des options ci-dessus, nous pouvons voir comment les périphériques sont situés, et nous pouvons voir les partitions nouvellement créées.

Étape 2 - Créer un système de fichiers

Nous devons maintenant créer le système de fichiers, ou filesystem, à l'aide de la commande mkfs. La commande mkfs a de multiples variantes, ce blog n'est pas destiné à examiner cette commande en détail, nous nous concentrons spécifiquement sur la création du stockage nécessaire pour stocker nos bases de données.
Nous allons formater la partition que nous avons créée plus tôt, qui dans notre cas est la partition primaire 1 (sdb1), rappelez-vous que le périphérique /dev/sdb est le disque dur lui-même.
Nous allons maintenant formater la partition de type Linux. Ce type de partition peut être formaté en ext2, ext3 et ext4. Par défaut, si elle n'est pas spécifiée, la partition est créée en tant que ext2. L'utilisation de ext2 n'est plus conseillée, la plupart des systèmes Linux utilisent ext4, donc dans ce cas, nous allons la formater en tant que ext4, qui est le format actuellement utilisé.

Vous pouvez utiliser l'une ou l'autre de ces deux options (en tant que super-utilisateur).

#> mkfs -t ext4 /dev/sdb1
#> mkfs.ext4 /dev/sdb1
(Vous pouvez ajouter -V pour "verbose" pour voir plus d'informations pendant l'exécution de la commande)

[root@oracle-21 ~]# mkfs.ext4 /dev/sdb1
mke2fs 1.45.6 (20-Mar-2020)
Rejet des blocs du périphérique : 4096/6553344
done
Création d'un système de fichiers avec 6553344 blocs de 4k et 1638400 inodes
UUID du système de fichiers : acb407b4-8572-447d-aeed-fb0f2c630daf
Sauvegardes de superblocs stockées sur des blocs :
32768, 98304, 163840, 229376, 294912, 819200, 884736, 1605632, 2654208,
4096000

Allocation des tables de groupes : effectuée
Écriture des tables d'inodes : effectuée
Création d'un journal (32768 blocs) : effectuée
Écriture des superblocs et des informations de comptabilité du système de fichiers : effectuée

Nous vérifions que la commande a été exécutée correctement :

[root@oracle-21 ~]# file -sL /dev/sdb1
/dev/sdb1 : Linux rev 1.0 ext4 filesystem data, UUID=acb407b4-8572-447d-aeed-fb0f2c630daf (extents) (64bit) (large files) (huge files)
[root@oracle-21 ~]# file -sL /dev/sdb1 [root@oracle-21 ~]# file -sL /dev/sdb1 [root@oracle-21 ~]#

Étape 3 - Créer le point de montage

Una vez hemos realizado los pasos anteriores, simplemente tenemos que crear el directorio en el sistema operativo con el nombre que queremos darle a la partición creada anteriormente, que será el nombre al que nos referiremos posteriormente a nivel de almacenamiento.

Para ello simplemente creamos el directorio con mkdir <nombre directorio>.

En este caso como va a ser el espacio que almacenará datos para nuestra BBDD, lo llamaremos p.eje. oradata.

[root@oracle-21 ~]# mkdir /oradata

Étape 4 - Créer le point de montage, monter la partition

Il suffit pour cela d'indiquer au SSOO quelle partition nous voulons monter et comment nous voulons la voir représentée au niveau du SSOO, au niveau des répertoires. Dans notre cas, la partition /dev/sdb1 est montée en tant que /oradata.

root@oracle-21 ~]# df -h
Taille du système de fichiers utilisée Utilisation disponible% Monté sur
devtmpfs 3.9G 0 3.9G 0% /dev
tmpfs 3.9G 0 3.9G 0% /dev/shm
tmpfs 3.9G 9.4M 3.9G 1% /run
tmpfs 3.9G 0 3.9G 0% /sys/fs/cgroup
/dev/mapper/ol-root 26G 5.4G 21G 21% /
/dev/sda1 1014M 318M 697M 32% /boot
tmpfs 796M 28K 796M 1% /run/user/1000
/dev/sr0 10G 10G 0 100% /run/media/oracle/OL-8-5-0-BaseOS-x86_64

[root@oracle-21 ~]# mount /dev/sdb1 /oradata
[root@oracle-21 ~]# df -h
Taille du système de fichiers Utilisé Avail Use% Monté sur
devtmpfs 3.9G 0 3.9G 0% /dev
tmpfs 3.9G 0 3.9G 0% /dev/shm
tmpfs 3.9G 0 3.9G 0% /sys/fs/cgroup
/dev/mapper/ol-root 26G 5.4G 21G 21% /
/dev/sda1 1014M 318M 697M 32% /boot
tmpfs 796M 28K 796M 1% /run/user/1000
/dev/sr0 10G 10G 0 100% /run/media/oracle/OL-8-5-0-BaseOS-x86_64
/dev/sdb1 25G 45M 24G 1% /oradata
[root@oracle-21 ~]# /run/user/1000 /dev/sr0 10G 10G 0 100% /run/media/oracle/OL-8-5-0-BaseOS-x86_6 4 /dev/sdb1 25G 45M 24G 1% /oradata [root@oracle-21 ~]#

La configuration de cette partition disparaîtra au prochain redémarrage, où il faudra remonter manuellement chacun des points de montage auxquels nous devons accéder au niveau du SSOO, alors que pendant tout ce temps, comme il est évident, il ne sera pas possible d'accéder aux données stockées dans ce répertoire. Pour éviter cela, il est nécessaire de configurer le fichier fstab, situé dans le chemin /etc. Le fichier /etc/fstab contient la configuration qui indique au système comment les lecteurs de l'ordinateur doivent être montés. Il s'agit d'un fichier comportant 6 colonnes à configurer.

Comme nous l'avons indiqué précédemment avec la commande mkfs, les paramètres du point de montage varient en fonction des besoins, dans notre cas, ces paramètres sont suffisants.

/dev/sdb1 /oradata ext4 defaults 0 0

En dernier lieu, il ne reste plus qu'à l'assembler.

monter /oradata

Répétons les étapes suivantes avec les périphériques (sdc, sdd) afin d'avoir /oradata /oradata1 /oradata2

L'image finale ressemblerait à ce qui suit :

Avec ce stockage vous pouvez maintenant lancer la création de la base de données, les données doivent être réparties dans les répertoires nouvellement créés. Cette configuration avec l'apparition d'ASM, est pratiquement obsolète pour ces installations plus ou moins grandes, pour qu'Oracle Automatic Storage Manager (ASM) puisse identifier les disques, ceux-ci doivent être identifiés de manière cohérente avec des propriétés et des permissions spécifiques, cela peut être fait (sous Linux) en utilisant ASMLib ou Udev, dans cet exemple nous ajouterons les disques avec le gestionnaire de périphériques de Linux, UDEV. Dans un article ultérieur, nous décrirons comment effectuer les configurations nécessaires pour que les disques soient gérés via UDEV ou ASMlib.

Défiler vers le haut