Aller au contenu

Active Directory Authentication avec Samba

Prérequis

  • Connaissances de base de Active Directory
  • Connaissances de base de LDAP

Introduction

Active Directory (AD) de Microsoft est, dans la plupart des entreprises, le système d'authentification standard pour les systèmes Windows et pour les applications externes connectées à LDAP. Il permet de configurer les utilisateurs et les groupes, le contrôle d'accès, les permissions, le montage automatique, etc.

Alors que la connexion de Linux à un cluster AD ne peut pas prendre en charge toutes les fonctionnalités mentionnées, elle peut gérer les utilisateurs, les groupes et le contrôle d'accès. Il est même possible (grâce à quelques ajustements de configuration du côté Linux et à certaines options côté AD) de distribuer des clés SSH à l'aide d'Active Directory.

La manière par défaut d'utiliser Active Directory sur Rocky Linux utilise SSSD mais Samba offre une alternative plus complète. Par exemple, le partage de fichiers peut se faire avec Samba mais pas avec SSSD. Ce guide, cependant, couvrira uniquement la configuration de l'authentification sur Active Directory à l'aide de Samba et n'inclura aucune configuration supplémentaire du côté Windows.

Découvrir et joindre AD en utilisant Samba

Remarque

Le nom de domaine `ad.company.local` dans ce guide représentera le domaine Active Directory. Pour suivre ce guide, remplacez-le par le nom de votre domaine AD.

La première étape pour relier un système GNU/Linux à AD consiste à connecter votre Cluster AD, pour s'assurer que la configuration réseau est correcte des deux côtés.

Préparations

  • Assurez-vous que les ports suivants sont ouverts sur votre hôte GNU/Linux dans le contrôleur de domaine :
ServicePort(s)Notes
DNS53 (TCP+UDP)
Kerberos88, 464 (TCP+UDP)Utilisé par kadmin pour définir et mettre à jour les mots de passe
LDAP389 (TCP+UDP)
LDAP-GC3268 (TCP)Catalogue global LDAP - vous permet de trouver des identifiants d'utilisateur à partir d'Active Directory
  • Assurez-vous d'avoir configuré votre contrôleur de domaine AD en tant que serveur DNS sur votre hôte Rocky Linux :

Avec NetworkManager :

# where your primary NetworkManager connection is 'System eth0' and your AD
# server is accessible on the IP address 10.0.0.2.
[root@host ~]$ nmcli con mod 'System eth0' ipv4.dns 10.0.0.2
  • Assurez-vous que les horloges sont synchronisées des deux côtés (hôte AD et système GNU/Linux)

Vérifier l'heure sur Rocky Linux :

[user@host ~]$ date
Wed 22 Sep 17:11:35 BST 2021
  • Installez les paquets nécessaires pour la connexion à AD côté GNU/Linux :
[user@host ~]$ sudo dnf install samba samba-winbind samba-client

Connexion automatique

Maintenant, vous devriez être en mesure de vous connecter avec succès à votre ou vos serveur(s) AD à partir de votre hôte Linux.

[user@host ~]$ realm discover ad.company.local
ad.company.local
  type: kerberos
  realm-name: AD.COMPANY.LOCAL
  domain-name: ad.company.local
  configured: no
  server-software: active-directory
  client-software: sssd
  required-package: oddjob
  required-package: oddjob-mkhomedir
  required-package: sssd
  required-package: adcli
  required-package: samba-common

Cela sera découvert à l'aide des enregistrements SRV pertinents stockés dans votre service DNS d'Active Directory.

Connexion

Une fois que vous avez découvert avec succès votre installation Active Directory à partir de l'hôte Linux, vous devriez pouvoir utiliser realmd pour rejoindre le domaine, qui orchestrera la configuration de Samba à l'aide de adcli et d'autres outils similaires.

[user@host ~]$ sudo realm join -v --membership-software=samba --client-software=winbind ad.company.local

Vous serez invité à saisir le mot de passe administrateur de votre domaine, alors tapez-le.

Si ce processus affiche un problème de chiffrement comme KDC has no support for encryption type, essayez de mettre à jour la stratégie de chiffrement globale pour autoriser les algorithmes de chiffrement plus anciens :

[user@host ~]$ sudo update-crypto-policies --set DEFAULT:AD-SUPPORT

Si ce processus réussit, vous devriez maintenant pouvoir extraire les informations passwd pour un utilisateur Active Directory.

[user@host ~]$ sudo getent passwd administrator@ad.company.local
AD\administrator:*:1450400500:1450400513:Administrator:/home/administrator@ad.company.local:/bin/bash

Remarque

`getent` récupère les entrées des bibliothèques Name Service Switch (NSS). Cela signifie que, contrairement à `passwd` ou `dig` par exemple, il interrogera différentes bases de données, y compris `/etc/hosts` pour `getent hosts` ou depuis `samba` dans le cas `getent passwd`.

realm propose quelques options intéressantes que vous pouvez utiliser :

OptionObservation
--computer-ou='OU=LINUX,OU=SERVERS,dc=ad,dc=company.local'Le OU où stocker le compte du serveur
--os-name='rocky'Spécifie le nom du système d'exploitation stocké dans Active Directory
--os-version='8'Indique la version de l'OS stockée dans Active Directory
-U admin_usernameIndique un compte administrateur

Tentative d'Authentification

Now your users should be able to authenticate to your Linux host against Active Directory.

Sous Windows 10 : (qui fournit sa propre copie d'OpenSSH)

C:\Users\John.Doe> ssh -l john.doe@ad.company.local linux.host
Password for john.doe@ad.company.local:

Activate the web console with: systemctl enable --now cockpit.socket

Last login: Wed Sep 15 17:37:03 2021 from 10.0.10.241
[john.doe@ad.company.local@host ~]$

If this succeeds, you have successfully configured Linux to use Active Directory as an authentication source.

Suppression du nom de domaine dans les noms d'utilisateurs

Dans une configuration complètement par défaut, vous devrez vous connecter avec votre compte AD en spécifiant le domaine dans votre nom d'utilisateur (par exemple, « john.doe@ad.company.local »). Si ce n'est pas le comportement souhaité et que vous souhaitez plutôt pouvoir omettre le nom de domaine par défaut au moment de l'authentification, vous pouvez configurer Samba pour qu'il utilise par défaut un domaine spécifique.

This is a relatively straightforward process, requiring a configuration tweak in your SSSD configuration file.

[user@host ~]$ sudo vi /etc/samba/smb.conf
[global]
...
winbind use default domain = yes

En ajoutant le winbind use default domain, vous demandez à Samba de déduire que l'utilisateur tente de s'authentifier en tant qu'utilisateur du domaine « ad.company.local ». This allows you to authenticate as something like john.doe instead of john.doe@ad.company.local.

Pour que cette modification de configuration prenne effet, vous devez redémarrer les services smb et winbind avec systemctl.

[user@host ~]$ sudo systemctl restart smb winbind

De la même manière, si vous ne souhaitez pas que vos répertoires personnels soient suffixés avec le nom de domaine, vous pouvez ajouter ces options dans votre fichier de configuration /etc/samba/smb.conf :

[global]
template homedir = /home/%U

N'oubliez pas de redémarrer les services smb et winbind.

Author: Neel Chauhan

Contributors: Steven Spencer, Ganna Zhyrnova