{{tag> matériel réseau}} ---- ====== ISCSI ====== Cette configuration a été effectuée sous un serveur local disposant d'[[:Precise|ubuntu 12.04.1 LTS]], il se peut qu'elle diffère pour des versions antérieures Un SAN, qu'est ce que c'est ? :-P Un SAN, tout comme un NAS usant des protocoles NFS ou SAMBA, vous permet de partager de l'espace disque via une image disque simulant un disque dur ou d'un disque complet, via le protocole ISCSI.\\ La nette différence résulte dans le fait que c'est le système client qui prend en charge le formatage et le système de fichiers de ce dernier, sans compter que les performances seront généralement meilleures que sous les deux autres protocoles, notamment sur de multiples petits fichiers. ;-) Selon [[http://blog.gaetan-grigis.eu/systeme/administration/mise-en-place-discsi-pour-le-partage-de-donnees/|cet article]], l'accès en écriture serait amélioré de 20% par rapport en NFS, et de 400% (théorique, dépend de votre configuration réseau) en lecture. ^_^ Autres points importants, cette technique vous permet de soulager votre serveur en terme de ressources demandées (au détriment du poste client toutefois), mais surtout de mapper en dur cet espace disque comme s'il faisait partie intégrante de la machine client.\\ Ainsi certains logiciels comme le client [[:Steam]] sous Windows, développé pour empêcher l'utilisateur de faire fonctionner ce client logiciel de jeux, sous un disque réseau (m(), n'y verra plus que du feu. LOL\\ Cette technique est aussi valable pour d'autres logiciels n'autorisant leur utilisation que sur des disques locaux. ;-) ===== Configuration du serveur et de ses disques ===== La configuration est également assez simple une fois le concept saisi, deux choix s'offrent à vous, dédier un disque complet à l'utilisation de ISCSI pour un partage réseau en dur, ou bien dédier un espace choisi via la création d'un fichier image d'un disque dur. ==== Installation du service ==== L'installation est très simple, et se résume par l'[[:tutoriel:comment_installer_un_paquet|installation des paquets]] **[[apt>iscsitarget,iscsitarget-source,iscsitarget-dkms|iscsitarget iscsitarget-source iscsitarget-dkms]]**.\\ Ce qui peut se résumer avec l'outil [[:apt-get]] dans un [[:terminal]] par la [[:commande_shell|commande]] : sudo apt-get install iscsitarget iscsitarget-source iscsitarget-dkms ==== Cas d'un disque émulé ==== Voici la commande nécessaire à la création d'un disque virtuel de 40Go, vous devrez modifier fs.iscsi.disk par le chemin et le nom du fichier que vous aurez choisi, et la valeur 40000 correspondra à la taille du disque choisie. dd if=/dev/zero of=fs.iscsi.disk bs=1M count=40000 [[:tutoriel:comment_modifier_un_fichier|Éditer avec les droits d'administration]] le fichier de configuration **/etc/iet/ietd.conf** pour y ajouter: Target nom-libre:fs.iscsi.disk Lun 0 Path=/chemin/du/disque/virtuel/fs.iscsi.disk,Type=fileio ==== Cas pour un disque dur ou une partition en dur ==== [[:tutoriel:comment_modifier_un_fichier|Éditer avec les droits d'administration]] le fichier de configuration **/etc/iet/ietd.conf** pour y ajouter: Target nom-libre:sdb2 Lun 0 Path=/dev/sdb2,Type=fileio En adaptant la partition ///dev/sdb2// à votre cas. ==== Configuration finale ==== Enfin, [[:tutoriel:comment_modifier_un_fichier|éditer avec les droits d'administration]] le fichier de configuration **/etc/default/iscsitarget** et remplacez la valeur "false" par "true" : ISCSITARGET_ENABLE=false deviendra ainsi ISCSITARGET_ENABLE=true Il ne reste plus qu'à redémarrer le [[:services|service]] pour prendre en compte les modifications : sudo service iscsitarget restart Devra vous indiquer : * Removing iSCSI enterprise target devices: [ OK ] * Starting iSCSI enterprise target service [ OK ] [ OK ] Enfin, vous pouvez vérifier que votre disque a bien été pris en compte via cette commande : cat /proc/net/iet/volume Si votre serveur est protégé par un [[:pare-feu]], ouvrez le port 3260 vers votre réseau local\\ Par exemple : sudo ufw allow to any port 3260 from 192.168.1.0/24 ===== Configuration du poste client GNU/Linux ===== ==== Installation manuelle ==== Sur le poste client, [[:tutoriel:comment_installer_un_paquet|installez le paquet]] **[[apt>open-iscsi]]**, puis lancez une détection (192.168.0.1 étant à remplacer par l'[[:tutoriel:connaitre_son_adresse_ip|ip du serveur]]): sudo iscsiadm --mode discovery --type sendtargets --portal 192.168.0.1 Par exemple, sur un disque virtuel étant dédié à [[:Steam]], cela peut donner le résultat : 192.168.0.1:3260,1 steam:fs.iscsi.steam Ensuite pour lier le disque virtuel au couple machine/client (en adaptant selon vos valeurs) : sudo iscsiadm --mode node --targetname steam:fs.iscsi.steam \ --portal 192.168.0.1 --login Si l'opération s'est bien déroulée, toujours avec l'exemple du disque virtuel dédié à Steam, s'affiche alors quelque chose comme : Logging in to [iface: default, target: steam:fs.iscsi.steam, portal: 192.168.0.1,3260] (multiple) Remarquez le jeu de mot... (Steam/Valve/Portal ! m( ) Voilà, votre disque virtuel distant SCSI est disponible en tant que périphérique (dans /dev) sur votre machine cliente Linux ! ==== Montage automatique au démarrage ==== Si vous voulez que les disques distants soient automatiquement montés au démarrage de votre système, il faut [[:tutoriel:comment_modifier_un_fichier|éditer avec les droits d'administration]] le fichier **/etc/iscsi/iscsid.conf** et dé-commenter ((enlever le dièse "#")) node.startup = automatic ==== Script automatique pour PC diskless (PXE boot en Live) ==== Lors d'un démarrage en mode [[:netboot_live|Netboot Live]], votre PC client est totalement dénudé.\\ Ce script va vous permettre de réaliser l'installation de 'open-iscsi', d'interroger le serveur et de pouvoir choisir le disque à connecter. Il permet aussi de déconnecter un disque. === Version terminal === #! /bin/sh # gestion automatique iSCSI if [ x$1 = x ]; then echo "You have to give the server (IP or URL) or -u to disconnect disks" exit fi installed=`dpkg -l "open-iscsi*" | grep ii | cut -d ' ' -f 1` if [ "x$installed" = "x" ]; then apt-get install -y open-iscsi open-iscsi-utils fi if [ "$1" != "-u" ]; then info=`iscsiadm --mode discovery --type sendtargets --portal $1` pos=2 while [ 1 ]; do volume=`echo $info | cut -d ' ' -f $pos` if [ "$volume" = "" ]; then break;fi echo "`expr $pos / 2` - $volume" pos=`expr $pos + 2` done echo -n "\nChoose the disk number : "; read n bon=`echo "123456789" | grep $n` if [ "$bon" = "" ]; then echo "Error, you do type a number"; exit;fi n=`expr $n + $n` if [ $n -ge $pos ]; then echo "Error, bad disks number"; exit;fi disk=`echo $info | cut -d ' ' -f $n` session=`iscsiadm -m session | grep $disk` if [ "$session" != "" ]; then echo "Error, iSCSI disk already connected"; exit;fi iscsiadm --mode node --targetname $disk \ --portal $1 --login iscsiadm -m session else sion=`iscsiadm -m session` if [ "$sion" = "" ]; then exit;fi sion=`iscsiadm -m session | cut -d ' ' -f 4` pos=1 for i in $sion; do echo "$pos - $i" pos=`expr $pos + 1` done echo -n "\nChoose the disk number : "; read n bon=`echo "123456789" | grep $n` if [ "$bon" = "" ]; then echo "Error, you do type a number"; exit;fi if [ $n -ge $pos ]; then echo "Error, bad disks number"; exit;fi name=`echo $sion | cut -d ' ' -f $n` iscsiadm -m node -u -T $name fi Copier tout ce code dans un fichier, la syntaxe de lancement est très simple : * sudo sh