Association Générale des Utilisateurs de logiciels libres en Côte-d'Or
Rubriques
Notre ami Tux en rodéo sur l'escargot de Bourgogne :-) |
Intégrer un poste Debian dans un domaine Windows
But de ce documentCe document me sert de mémo pour intégrer un poste bureautique sous Debian Testing dans un domaine contrôlé par un serveur Windows NT. Le but de ce document est d’arriver à se connecter sur le poste Debian avec un utilisateur quelconque du domaine. De plus, il est prévu de monter automatiquement les dossiers partagés par les serveurs du domaine en fonction des droits de l’utilisateur qui se connecte. Pré-requisAvoir installé une Debian de Base : http://www.coagul.org/article.php3 ?id_article=158 Avoir installé KDE : http://www.coagul.org/article.php3 ?id_article=159 Installation de WinbindWinbind permet d’intégrer les utilisateurs et les groupes du domaine au poste Linux. Paquet à installer :
Si samba n’est pas installé, Winbind demandera son installation. La configuration de Winbind se fait avec le fichier de configuration de samba (smb.conf). Remarque : Pour ce mémo, Il n’est pas obligatoire d’installer la partie serveur de Samba (le paquet « samba-client » suffit). Si des questions sont posées lors de l’installation des paquets, il faut laisser les réponses par défaut. Configuration de /etc/nsswitch.confCe fichier permet d’indiquer le programme qui s’occupe de la gestion des utilisateurs : Il faut simplement ajouter winbind et wins comme indiqué dans l’exemple ci-dessous : passwd: compat winbindConfiguration de /etc/samba/smb.confLe fichier « smb.conf » est utilisé pour configurer Samba mais également Winbind. A chaque modification du fichier smb.conf, il faut recharger la configuration de Samba :
Si la partie concernant Winbind est modifiée, il faut redémarrer Winbind :
Même si le poste Linux ne propose pas de dossier partagé, il est nécessaire de configurer Samba pour pouvoir joindre le domaine Windows, récupérer les utilisateurs et se connecter avec un utilisateur du domaine. Voici le début de mon fichier smb.conf : [global]La suite du fichier smb.conf permet de configurer Winbind. Il faut donc redémarrer Winbind à chaque modification de cette partie :
Le premier paramètre permet d’indiquer le caractère à utiliser comme séparateur entre le nom du domaine et le nom de l’utilisateur (J’ai choisi / car c’est le caractère utilisé par Windows) :
Les deux paramètres suivants permettent d’indiquer la plage des numéro à utiliser pour les utilisateurs ou les groupes. Ces deux lignes sont obligatoires au bon fonctionnement de Winbind. ATTENTION : Une fois que le poste Linux sera connecté au domaine, il ne faudra surtout pas changer la plage des numéro, car cela peut poser de gros problèmes de connexion. winbind uid = 10000-20000Pour pouvoir se connecter sur le poste Linux avec un compte du domaine Windows, il est obligatoire d’indiquer l’adresse du shell à utiliser :
La ligne suivante permet d’indiquer le chemin où seront enregistrés les profils des utilisateurs du domaine (%D = Nom du domaine et %U = Login de l’utilisateur). Le dossier et le profil seront créés automatiquement lors de la première connexion. Attention : Il faut créer manuellement le dossier racine correspondant au nom du domaine (%D). Car s’il est créé automatiquement lors de la connexion du premier utilisateur, les autres utilisateurs ne pourront plus se connecter pour des problèmes de droits sur ce dossier. En cas de problème, il faut regarder les logs dans auth.log
La ligne suivante permet d’éviter de saisir le nom du domaine devant le nom de l’utilisateur pour pouvoir se connecter. Sans cette ligne, il faut utiliser le login « NomDuDomaine/NomDuLogin » et avec cette ligne il suffit juste de saisir comme login « NomDuLogin ». La commande « wbinfo -u » permet de voir l’influence de cette ligne une fois que tout est correctement configuré. De plus, cette ligne est obligatoire pour arriver à faire fonctionner libpam-mount pour monter automatiquement des partitions avec des utilisateurs du domaine.
Voici un exemple complet et fonctionnel de fichier smb.conf : [global]Remarque : Cet exemple de configuration ne contient aucun dossier partagé, car la partie serveur de Samba n’est pas installée et n’est pas nécessaire. Ajouter le serveur Samba au contrôleur de domaine WindowsIl faut commencer par arrêter le serveur Samba et éventuellement Winbind : /etc/init.d/samba stopVoici la commande pour ajouter le serveur Samba au gestionnaire de serveurs du contrôleur de domaine Windows (l’utilisateur root, doit avoir l’autorisation d’ajouter des serveurs au domaine) :
Et si tout se passe bien, le message suivant doit apparaître :
Ensuite, il faut redémarrer le serveur Winbind et le serveur Samba : /etc/init.d/winbind startQuelques commandes pour vérifier que tout fonctionneRemarque : Avant de saisir les commandes suivantes, il faut vérifier que le serveur Samba est correctement ajouté dans la liste des serveurs du « gestionnaire de serveurs » du contrôleur de domaine Windows. Si ce n’est pas le cas, il faut peut-être attendre quelques minutes pour que la mise à jour se fasse. La commande suivante doit donner la liste des utilisateurs du domaine :
Celle-ci la liste des groupes du domaine :
Celle-ci permet de vérifier que les utilisateurs du domaine sont ajoutés à la liste des utilisateurs du serveur Linux avec les bons uid :
La même chose avec les groupes d’utilisateurs :
Cette commande permet de vérifier qu’un utilisateur particulier est correctement reconnu
La commande suivante permet d’afficher les ressources partagées par le serveur Samba « pgdebian » pour l’utilisateur « tony » :
Montage des partitions automatiquement en fonction de l’utilisateurLe paquet « libpam-mount », permet de monter et démonter des partitions automatiquement en fonction du login de l’utilisateur. Paquet à installer :
Autres paquets à installer pour monter des partitions samba :
Le fichier « /etc/security/pam_mount.conf » est le principal fichier de configuration de « libpam-mount ». A la fin de ce fichier, il faut insérer une ligne du type :
Remarque : Si « * » est utilisé pour le paramètre Voici un exemple pour monter le dossier partagé « Utilisateurs » du serveur « pglinux » sur le point de montage « /Reseau/pglinux » pour tous les utilisateurs (Le signe correspond au répertoire home de l’utilisateur) :
Voici le même exemple avec des options de montage :
Voici le même exemple valable uniquement pour l’utilisateur tony (Dans ce cas, le signe « & » n’est plus utilisable) :
Débugage : La première ligne de ce fichier permet également d’activer le débugage pour comprendre ce qui ne fonctionne pas :
Si vous ne souhaitez pas que les points de montage soient créés automatiquement s’ils n’existent pas, il faut modifier la ligne suivante :
Pour faire fonctionner « libpam-mount », il faut également configurer « pam » comme indiqué au chapitre suivant. Configuration de pamPam est un système très complet et très modulaire permettant de gérer les connexions et les autorisations sur un poste Linux. Pam permet de gérer les connexions locales ou peux utiliser une base de données LDAP ou encore les utilisateurs d’un domaine Windows. ATTENTION : Avant de modifier la configuration de pam, il est vivement conseillé d’ouvrir une console sous root (ALT+F1) et de ne pas la fermer tant que tout ne fonctionne pas correctement. Une mauvaise configuration de pam peut empêcher toute connexion même sous root. Pam se configure à l’aide des différents fichiers du dossier « /etc/pam.d/ ». Chaque application peux avoir sa propre méthode d’authentification et c’est pour cela que nous retrouvons dans ce dossier un fichier pour chaque type de programme nécessitant une authentification (cron, cupsys, kdm, login, su, ssh,...) Dans le cadre de ce mémo, nous allons modifier uniquement le fichier « kdm », car je souhaite me connecter avec un utilisateur du domaine uniquement avec kdm et pas en ssh ou en console. Donc, il suffit d’ouvrir le fichier « /etc/pam.d/kdm », de commenter toutes le lignes existantes et d’ajouter les lignes suivantes : auth required pam_mount.soL’explication détaillée du fonctionnement de pam, dépasse très largement le cadre de ce mémo, mais voici quelques explications :
Test de fonctionnementPour tester le fonctionnement, il faut se connecter avec kdm avec un utilisateur existant en locale et faire un autre test avec un utilisateur du domaine. Il faut vérifier que les partitions sont correctement montés lors de la connexion et démontés lors de la déconnexion. Si ça ne fonctionne pas, il faut penser à regarder les logs :
Il faut peut-être aussi redémarrer kdm :
Problèmes rencontrésProblème de localisation -> Créer .xsession et choisir « Default » dans kdm.
Il ne faut pas utiliser de majuscule pour se connecter avec un utilisateur du domaine. Autres articles sur le même sujetInstallation de Winbind pour intégrer Samba dans un Domaine Windows :
Monter automatiquement des partitions en fonction du login de connexion avec libpam-mount :
Historique des modifications
Article précédent : Sous Debian, comment activer la configuration du réseau seulement s’il est disponible.
Article suivant : Mise en place d’une passerelle sous Debian avec iptables
Forum
| ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||