Dans cet article, nous allons vous expliquer comment ajouter manuellement des disques dans le système d'exploitation Linux. Nous vous expliquerons également comment les configurer afin qu'ils puissent être utilisés pour stocker les données de notre base de données Oracle.
En primer lugar vamos a listar los discos que tenemos en nuestra máquina virtual.
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.
Étapes Linux 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 SSO qu'il s'agit d'une nouvelle partition (n), qu'il s'agit d'une partition primaire (p), le numéro de partition (1), puis nous appuyons sur Entrée, ce qui indique au SSOO nous voulons que tout le disque soit sur une seule partition. Nous appuyons ensuite sur la touche (t) pour indiquer le type de partition, (83) pour indiquer qu'il s'agit d'une partition Linux puis (w). Lorsque nous appuyons sur w, le SSOO réellement à effectuer les modifications sur le disque.
Por lo tanto la secuencia sería: n,p,1,<INTRO>,<INTRO>,w
En ce qui concerne les types de partitions disponibles, il est possible de visualiser toutes les options disponibles avant de choisir le type de partition, dans ce cas Linux, en appuyant sur la touche L, comme indiqué dans la sortie d'écran précédente.
Avec l'une des options indiquées ci-dessus, nous pouvons voir comment se trouvent les périphériques et nous pouvons voir la partition récemment créée.

Étape 2 - Créer un système de fichiers
Nous devons maintenant créer le système de fichiers, ou filesystem, pour cela nous utiliserons la commande mkfs. La commande mkfs a plusieurs variantes, mais ce blog n'a pas pour but d'étudier 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 précédemment, qui dans notre cas est la partition primaire 1 (sdb1). N'oubliez pas que le périphérique /dev/sdb correspond au disque dur lui-même.
Nous allons donc maintenant formater la partition de type Linux. Ce type de partition peut être formaté en ext2, ext3 et ext4. Par défaut, si la partition n'est pas spécifiée, elle est créée par défaut en ext2. L'utilisation de ext2 n'est plus très recommandée, la plupart des systèmes Linux ext4. Dans ce cas, nous allons donc la formater en ext4, qui est le format actuellement utilisé.
Vous pouvez utiliser l'une de ces deux options (en tant que root).
#> 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)
Discarding device blocks: 4096/6553344
done
Creating filesystem with 6553344 4k blocks and 1638400 inodes
Filesystem UUID: acb407b4-8572-447d-aeed-fb0f2c630daf
Sauvegardes de superblocs stockées sur les blocs :
32768, 98304, 163840, 229376, 294912, 819200, 884736, 1605632, 2654208,
4096000
Allocation des tables de groupe : terminée
Écriture des tables d'inodes : terminée
Création du journal (32768 blocs) : terminée
Écriture des superblocs et des informations comptables du système de fichiers : terminée
Nous vérifions que la commande a été exécutée correctement :
[root@oracle-21 ~]# file -sL /dev/sdb1
/dev/sdb1 : données du système de fichiers ext4 Linux rev 1.0, UUID=acb407b4-8572-447d-aeed-fb0f2c630daf (extensions) (64 bits) (fichiers volumineux) (huge files)
[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
À ce stade, il faut monter la partition. Pour cela, il suffit d'indiquer au SSOO quelle partition nous voulons monter et comment nous voulons la voir représentée au niveau du SSOO, au niveau du répertoire. Dans notre cas, la partition /dev/sdb1 est montée comme /oradata.
root@oracle-21 ~]# df -h
Système de fichiers Taille Utilisé Disponible Utilisation % Monté sur
devtmpfs 3,9 Go 0 3,9 Go 0 % /dev
tmpfs 3,9 Go 0 3,9 Go 0 % /dev/shm
tmpfs 3,9 Go 9,4 Mo 3,9 Go 1 % /run
tmpfs 3,9 Go 0 3,9 Go 0 % /sys/fs/cgroup
/dev/mapper/ol-root 26 Go 5,4 Go 21 Go 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
Système de fichiers Taille Utilisé Disponible Utilisation % Monté sur
devtmpfs 3,9 Go 0 3,9 Go 0 % /dev
tmpfs 3,9 Go 0 3,9 Go 0 % /dev/shm
tmpfs 3,9 Go 0 3,9 Go 0 % /sys/fs/cgroup
/dev/mapper/ol-root 26 Go 5,4 Go 21 Go 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 ~]#
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, tandis que pendant tout ce temps, il sera évidemment impossible 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 unités de l'équipement doivent être montées. 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 désormais lancer la création de la base de données. Les données doivent être réparties entre les répertoires récemment créés. Avec l'apparition de l'ASM, cette configuration est pratiquement obsolète pour les installations plus ou moins grandes. Pour que l'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 autorisations spécifiques. Cela peut être réalisé (sous Linux) à l'aide d'ASMLib ou d'Udev. Dans cet exemple, nous ajouterons les disques avec le gestionnaire de périphériques Linux, UDEV. Dans un prochain article, nous décrirons comment effectuer les configurations nécessaires pour que les disques soient gérés via UDEV ou ASMlib.
