1.5. Samba を AD ドメインメンバーサーバーとして設定
AD または NT4 のドメインを実行している場合は、Samba を使用して Red Hat Enterprise Linux サーバーをメンバーとしてドメインに追加し、以下を取得します。
- その他のドメインメンバーのドメインリソースにアクセスする
-
sshdなどのローカルサービスに対してドメインユーザーを認証する - サーバーにホストされているディレクトリーおよびプリンターを共有して、ファイルサーバーおよびプリントサーバーとして動作する
1.5.1. RHEL システムの AD ドメインへの参加 リンクのコピーリンクがクリップボードにコピーされました!
Samba Winbind は、Red Hat Enterprise Linux (RHEL) システムを Active Directory (AD) に接続するための System Security Services Daemon (SSSD) の代替手段です。realmd を使用して Samba Winbind を設定することで、RHEL システムを AD ドメインに参加させることができます。
前提条件
- ホストは、AD ドメインを解決できる DNS サーバーを使用している。
- ホストの時刻は AD の時刻と同期され、タイムゾーン設定が適切である。
手順
AD で Kerberos 認証に非推奨の RC4 暗号化タイプが必要な場合は、RHEL でこの暗号のサポートを有効にします。
# update-crypto-policies --set DEFAULT:AD-SUPPORT以下のパッケージをインストールします。
# dnf install realmd oddjob-mkhomedir oddjob samba-winbind-clients \ samba-winbind samba-common-tools samba-winbind-krb5-locator krb5-workstationドメインメンバーでディレクトリーまたはプリンターを共有するには、
sambaパッケージをインストールします。# dnf install samba既存の Samba 設定ファイル
/etc/samba/smb.confをバックアップします。# mv /etc/samba/smb.conf /etc/samba/smb.conf.bakドメインに参加します。たとえば、ドメイン
ad.example.comに参加するには、以下のコマンドを実行します。# realm join --membership-software=samba --client-software=winbind ad.example.com上記のコマンドを使用すると、
realmユーティリティーが自動的に以下を実行します。-
ad.example.comドメインのメンバーシップに/etc/samba/smb.confファイルを作成します。 -
ユーザーおよびグループの検索用の
winbindモジュールを、/etc/nsswitch.confファイルに追加します。 -
/etc/pam.d/ディレクトリーの PAM (プラグ可能な認証モジュール) 設定ファイルを更新します。 -
winbindサービスを起動し、システムの起動時にサービスを起動できるようにします。
-
-
オプション:
/etc/samba/smb.confファイルで、別の ID マッピングバックエンドまたはカスタマイズした ID マッピング設定を指定します。
詳細は、Samba ID マッピングの理解と設定 を参照してください。
winbindサービスが稼働していることを確認します。# systemctl status winbind ... Active: active (running) since Tue 2018-11-06 19:10:40 CET; 15s ago重要Samba がドメインのユーザーおよびグループの情報をクエリーできるようにするには、
smbを起動する前にwinbindサービスを実行する必要があります。sambaパッケージをインストールしてディレクトリーおよびプリンターを共有している場合は、smbサービスを有効化して開始します。# systemctl enable --now smb-
必要に応じて、Active Directory へのローカルログインを認証する場合は、
winbind_krb5_localauthプラグインを有効にします。MIT Kerberos 用のローカル承認プラグインの使用
検証
AD ドメインの AD 管理者アカウントなど、AD ユーザーの詳細を表示します。
# getent passwd "AD\administrator" AD\administrator:*:10000:10000::/home/administrator@AD:/bin/bashAD ドメイン内のドメインユーザーグループのメンバーをクエリーします。
# getent group "AD\Domain Users" AD\domain users:x:10000:user1,user2オプション: ファイルとディレクトリーの権限を設定するときに、ドメインのユーザーおよびグループを使用できることを確認します。たとえば、
/srv/samba/example.txtファイルの所有者をAD\administratorに設定し、グループをAD\Domain Usersに設定するには、以下のコマンドを実行します。# chown "AD\administrator":"AD\Domain Users" /srv/samba/example.txtKerberos 認証が期待どおりに機能することを確認します。
AD ドメインメンバーで、
administrator@AD.EXAMPLE.COMプリンシパルのチケットを取得します。# kinit administrator@AD.EXAMPLE.COMキャッシュされた Kerberos チケットを表示します。
# klist Ticket cache: KCM:0 Default principal: administrator@AD.EXAMPLE.COM Valid starting Expires Service principal 01.11.2018 10:00:00 01.11.2018 20:00:00 krbtgt/AD.EXAMPLE.COM@AD.EXAMPLE.COM renew until 08.11.2018 05:00:00
利用可能なドメインの表示:
# wbinfo --all-domains BUILTIN SAMBA-SERVER AD
1.5.2. MIT Kerberos 用のローカル承認プラグインの使用 リンクのコピーリンクがクリップボードにコピーされました!
winbind サービスは、Active Directory ユーザーをドメインメンバーに提供します。特定の状況では、管理者が、ドメインメンバーで実行している SSH サーバーなどのローカルサービスに対して、ドメインユーザーが認証を行えるようにします。Kerberos を使用してドメインユーザーを認証している場合は、winbind サービスを介して、winbind_krb5_localauth プラグインが Kerberos プリンシパルを Active Directory アカウントに正しくマッピングできるようにします。
たとえば、Active Directory ユーザーの sAMAccountName 属性を EXAMPLE に設定し、小文字のユーザー名でユーザーがログインしようとすると、Kerberos はユーザー名を大文字で返します。その結果、エントリーは認証の失敗に一致しません。
winbind_krb5_localauth プラグインを使用すると、アカウント名が正しくマッピングされます。これは GSSAPI 認証にのみ適用され、初期のチケット付与チケット (TGT) の取得には該当しません。
前提条件
- Samba が Active Directory のメンバーとして設定されている。
- Red Hat Enterprise Linux が、Active Directory に対してログイン試行を認証している。
-
winbindサービスが実行している。
手順
/etc/krb5.conf ファイルを編集し、以下のセクションを追加します。
[plugins]
localauth = {
module = winbind:/usr/lib64/samba/krb5/winbind_krb5_localauth.so
enable_only = winbind
}
1.5.3. Samba クライアントで証明書の自動登録を有効にする リンクのコピーリンクがクリップボードにコピーされました!
証明書の自動登録は、Active Directory (AD) 証明書サービスの機能です。この機能を使用することで、ユーザーが介入しなくてもユーザーとデバイスは証明書を登録できます。管理者は、手動で証明書を監視および更新することなく、ローカルサービスで AD 認証局 (CA) によって発行された証明書を使用できるため、中断を防ぐことができます。
AD が認証局 (CA) を提供し、RHEL ホストが AD のメンバーである場合は、RHEL ホストで証明書の自動登録を有効にできます。その後、Samba は AD からの自動登録グループポリシーを適用し、証明書を要求および管理するように certmonger サービスを設定します。
前提条件
- Samba が AD のメンバーとして設定されている。
AD 内の Windows サーバーに、次のサービスがインストールされた Active Directory 証明書サービス サーバーロールがある。
- 認証局
- 証明書登録
- ポリシー Web サービス
- インターネットインフォメーションサービス (ISS) は、HTTPS 経由で証明書の自動登録機能を提供するように設定されています。
- ISS は AD CA が発行した証明書を使用します。
- 証明書登録サービスは Kerberos 認証をサポートしています。
- 証明書の自動登録用のグループポリシーオブジェクト (GPO) が AD で設定されます。
手順
samba-gpupdateパッケージをインストールします。# dnf install samba-gpupdate/etc/samba/smb.confファイルに次の設定を追加します。kerberos method = secrets and keytab sync machine password to keytab = "/etc/krb5.keytab:account_name:sync_spns:spn_prefixes=host:sync_kvno:machine_password", "/etc/samba/cepces.keytab:account_name:machine_password" apply group policies = yesSamba 設定で指定される設定には、次の設定が含まれます。
kerberos method = secrets and keytab-
最初に
/var/lib/samba/private/secrets.tdbファイルを使用して Kerberos チケットを検証し、次に/etc/krb5.keytabファイルを使用するように Samba を設定します。 sync machine password to keytab = <list_of_keytab_files_and_their_principals>-
Samba が管理するキータブファイルへのパスと、これらのファイル内の Kerberos プリンシパルを定義します。示された値を使用すると、Samba は
/etc/krb5.keytabシステムキータブを維持し、さらに、certmongerのcepces-submit送信ヘルパーが CA への認証に使用する/etc/samba/cepces.keytabファイルも維持します。 apply group policies = yes-
一定間隔で
gpupdateコマンドを実行するようにwinbindサービスを設定します。更新間隔は 90 分で、これに 0 - 30 分の間のランダムオフセットが加算されます。
/etc/samba/cepces.keytabファイルを作成します。# net ads keytab create/etc/cepces/cepces.confファイルを編集し、次の変更を加えます。[global]セクションで、server変数を、CA サービスを実行する Windows サーバーの完全修飾ドメイン名 (FQDN) にします。[global] server=win-server.ad.example.com[kerberos]セクションで、keytab変数を/etc/samba/cepces.keytabに設定します。[kerberos] keytab=/etc/samba/cepces.keytab
certmongerサービスを有効にして起動します。# systemctl enable --now certmongercertmongerサービスは CA からの証明書を要求し、有効期限が切れる前に自動的に更新します。samba-gpupdateを手動で実行して、グループポリシーが AD からロードされていることを確認します。# samba-gpupdatecertmongerサービスは、キーと証明書を次のディレクトリーに保存します。-
秘密鍵:
/var/lib/samba/private/certs/ 発行された証明書:
/var/lib/samba/certs/これで、同じホスト上のサービスでキーと証明書の使用を開始できます。
-
秘密鍵:
オプション:
certmongerが管理する証明書を表示します。# getcert list Number of certificates and requests being tracked: 1. Request ID 'AD-ROOT-CA.Machine': status: MONITORING stuck: no key pair storage: type=FILE,location='/var/lib/samba/private/certs/AD-ROOT-CA.Machine.key' certificate: type=FILE,location='/var/lib/samba/certs/AD-ROOT-CA.Machine.crt' CA: AD-ROOT-CA issuer: CN=AD-ROOT-CA,DC=ad,DC=example,DC=com subject: CN=rhel9.ad.example.com issued: 2025-03-25 14:22:07 CET expires: 2026-03-25 14:22:07 CET dns: rhel9.ad.example.com key usage: digitalSignature,keyEncipherment eku: id-kp-clientAuth,id-kp-serverAuth certificate template/profile: Machine profile: Machine pre-save command: post-save command: track: yes auto-renew: yesデフォルトでは、Windows CA は
Machine証明書テンプレートのみを使用して証明書を発行します。Windows CA でこのホストに適用する追加のテンプレートを設定した場合、certmongerはこれらのテンプレートの証明書も要求し、getcert list出力にはそれらのエントリーも含まれます。