Title | date | Authors | Slug | Category | Tags | keywords | Status |
---|---|---|---|---|---|---|---|
Ceph - utiliser le reste d'un disque partitionné | 2019-02-26 06:53 | Victor | ceph-utiliser-disque-restant | Système | ceph, astuces | ceph, astuces | published |
[TOC]
Parfois sur un serveur, on se retrouve avec un disque de grande capacité qui ne vous sert à rien, parce que par exemple vous avez juste besoin de quelques centaines de Go pour installer un système.
Si vous utilisez en outre un système de stockage distribué (ici ceph), cela rend cette perte encore plus dommage, puisque la tentation est grande d'utiliser le reste du disque pour l'intégrer au cluster.
Avec ceph, c'est possible !
En effet comme il se sert de partitions toute simple et non d'un disque entier, il est possible de le nourrir avec ce qu'il reste d'espace sur votre disque.
Il y a bien sûr des contraintes que l'on va détailler dans les disclaimers suivants.
Mieux vaut que la taille restante de votre disque soit proche de celle des autres disques du cluster.
Ajouter 100Go de disque à un cluster utilisant des disques de 3To n'a au mieux aucun intérêt et au pire peut être risqué !
GROS DISCLAIMER
Utiliser le disque où il y a votre système installé va partager les IO du disque entre ceph et l'OS !
Ceph peut être un très gros consommateur de lecture/écriture, il est donc important de ne faire ça que si votre système a besoin de peu d'io.
L'idée est simple. On va formater le disque à la main et s'en servir pour l'intégrer dans ceph.
Comme toute idée simple, le potentiel de ratage est important, je vais donc volontairement détailler les choses auxquelles faire attention.
Ouais je sais je suis un peu chiant, que voulez vous, c'est l'apprentissage de la vie en production qui parle :-D
À lire
Je pars ici du principe que les binaires ceph sont déjà installés sur votre système (si par exemple vous utilisez un autre disque du serveur pour ceph)
Si ce n'est pas le cas, commencez par attaquer la documentation :-)
Je vais également prendre un exemple de partitionnement existant pour la numérotation des partitions.
Adaptez cet exemple avec votre situation pour éviter d'écraser des partitions existantes !
Dans cet exemple on va se baser sur un disque de 3To qui possède déjà 4 partitions :
# fdisk -l /dev/sda
Disk /dev/sda: 2.7 TiB, 3000592982016 bytes, 5860533168 sectors
Device Start End Sectors Size Type
/dev/sda1 4096 67112959 67108864 32G Linux swap
/dev/sda2 67112960 68161535 1048576 512M Linux filesystem
/dev/sda3 68161536 277876735 209715200 100G Linux filesystem
/dev/sda4 2048 4095 2048 1M BIOS boot
Comme vous le voyez on utilise déjà environ 132Go, on va donc s'occuper de récupérer les 2,8To restant.
Là encore, pensez à adapter les numéros de partitions dans la suite !
On va également utiliser sgdisk car c'est l'outil de configuration qu'utilise ceph lui-même quand il doit préparer un disque complet, et il fait le taf exactement comme les binaires ceph s'attendent à le voir fait.
Ceph a besoin d'une partition de type Ceph OSD
d'une centaine de Mo pour ses méta données, qui doit porter le nom ceph data
.
On va donc lui créer une 5eme partition nommée ceph data
de type 4fbd7e29-9d25-41b8-afd0-062c0ceff05d
. (cf wikipedia)
Ici modifiez les 5:
pour coller avec votre propre numéro de partition. Il y a quatre 5:
à changer.
sgdisk --new=5:0:+100M --change-name="5:ceph data" --partition-guid=5:$(uuidgen -r) --typecode=5:4fbd7e29-9d25-41b8-afd0-062c0ceff05d -- /dev/sda
partprobe # partprobe nous permet ici de relire à chaud les partitions d'un disque en cours d'utilisation.
On va ensuite créer une 6ème partition utilisant tout le reste du disque.
Celle-ci doit s'appeler ceph block
et être de type CAFECAFE-9B03-4F30-B4C6-B4B80CEFF106
(oui oui cafe cafe, là encore confer wikipedia)
Là encore modifiez les numéros 6:
pour coller à votre partition. Il y a trois 6:
à changer cette fois.
sgdisk --largest-new=6 --change-name="6:ceph block" --typecode=6:CAFECAFE-9B03-4F30-B4C6-B4B80CEFF106 -- /dev/sda
partprobe
Une fois le partitionnement terminé, il ne nous reste plus qu'à dire à ceph d'utiliser le disque :
Comme toujours, modifiez vos partitions pour coller à votre cas ! Ici sda5
représente la partition ceph-osd, sda6
le reste du disque.
ceph-disk prepare --bluestore /dev/sda5 /dev/sda5 /dev/sda6
ceph-disk activate /dev/sda5
Et voila, une fois le ceph-disk activate
terminé, votre nouvel osd est prêt et intégré au cluster ceph !
Enjoy :-)