第3回、
第2回で説明したように、
今回は、
なお、
パッケージのインストールと設定
各ディストリビューションで必要なパッケージの名称を表1に示します。まずは、
CentOS | nss_ |
---|---|
Ubuntu | libnss-ldap |
Ubuntuの場合、
CentOS 7.3における設定
CentOS 7.
# authconfig --enableldap --enableldapauth --ldapserver=172.16.2.10 --ldapbasedn=DC=ADDOM11,DC=AD,DC=LOCAL --update
具体的には/etc/
前述したとおり、
# The distinguished name of the search base.
base DC=ADDOM11,DC=AD,DC=LOCAL
# The distinguished name to bind to the server with.
# Optional: default is to bind anonymously.
#binddn cn=proxyuser,dc=example,dc=com
binddn cn=ldap proxy,cn=users,dc=addom11,dc=ad,dc=local ←ADを参照する際に用いるユーザのDN
# The credentials to bind with.
# Optional: default is no credentials.
# Note that if you set a bindpw you should check the permissions of this file.
#bindpw secret
bindpw (上記ユーザのパスワード)
なお、
さらに、
# Mappings for Active Directory
pagesize 1000
referrals off
idle_timelimit 800
filter passwd (&(objectClass=user)(!(objectClass=computer))(uidNumber=*)(unixHomeDirectory=*))
map passwd uid sAMAccountName
map passwd homeDirectory unixHomeDirectory
map passwd gecos displayName
filter shadow (&(objectClass=user)(!(objectClass=computer))(uidNumber=*)(unixHomeDirectory=*))
map shadow uid sAMAccountName
map shadow shadowLastChange pwdLastSet
filter group (objectClass=group)
これでCentOSでの設定は完了です。
Ubuntu 16.04における設定
Ubuntuの場合はnslcdを使わないため、
……
# The distinguished name of the search base.
#base dc=example,dc=net
base dc=ADDOM11,dc=AD,dc=LOCAL
……
# Another way to specify your LDAP server is to provide an
#uri ldapi:///
uri ldap://172.16.2.10/ ←ADサーバのIPアドレスを指定
……
# The distinguished name to bind to the server with.
# Optional: default is to bind anonymously.
binddn cn=ldap proxy,cn=users,dc=ADDOM11,dc=AD,dc=LOCAL ← LDAPサーバに検索を行うときに用いるユーザのDN
# The credentials to bind with.
# Optional: default is no credential.
bindpw (上記ユーザのパスワード)
……
# RFC 2307 (AD) mappings ←これ以下の行について、コメントを外す
nss_map_objectclass posixAccount user
nss_map_objectclass shadowAccount user
nss_map_attribute uid sAMAccountName
nss_map_attribute homeDirectory unixHomeDirectory
nss_map_attribute shadowLastChange pwdLastSet
nss_map_objectclass posixGroup group
nss_map_attribute uniqueMember member
pam_login_attribute sAMAccountName
pam_filter objectclass=User
pam_password ad
binddnやbindpwといったキーワードの意味はCentOSと同様です。
前述の通り、
引き続き、
# /etc/nsswitch.conf
#
# Example configuration of GNU Name Service Switch functionality.
# If you have the `glibc-doc-reference' and `info' packages installed, try:
# `info libc "Name Service Switch"' for information about this file.
passwd: compat ldap
group: compat ldap
shadow: compat ldap
(以下略)
これでUbuntuでの設定は完了です。
Active Directoryでの設定
引き続き、
ADアクセス用ユーザの作成
まずは冒頭で説明したADアクセス用ユーザを作成します。Usersコンテナの下に図1のようにしてフルネーム
data:image/s3,"s3://crabby-images/f8ccc/f8ccc97a0a3eda7463d02c31a2d4d457e2ea107c" alt="図1 ADアクセス用ユーザの作成 図1 ADアクセス用ユーザの作成"
各ユーザに対するUNIX属性の追加
ここまでの設定を行った状態でgetent passwdやgetent groupを行っても、
Oct 9 17:23:31 centos73-01 nslcd[2094]: [495cff] <group(all)> CN=Domain Users,CN=Users,DC=ADDOM11,DC=AD,DC=LOCAL: gidNumber: missing
Oct 9 17:23:31 centos73-01 nslcd[2094]: [495cff] <group(all)> CN=Domain Guests,CN=Users,DC=ADDOM11,DC=AD,DC=LOCAL: gidNumber: missing
これは、
Windows Server 2012 R2までのWindowsサーバでは、
data:image/s3,"s3://crabby-images/66a70/66a7002c398cb35776205028a31dba15f76b765d" alt="図2 UNIX属性(Windows Server 2008 R2) 図2 UNIX属性(Windows Server 2008 R2)"
そのため、
data:image/s3,"s3://crabby-images/346e6/346e6a508357ac7806d17197d61062002e62f4da" alt="図3 属性エディタによる属性の修正 図3 属性エディタによる属性の修正"
ユーザについては、
さらにLinuxサーバへのログオンを可能とするためには、
属性名 | 意味 | 設定例 | 必須or任意 |
---|---|---|---|
gidNumber | 所属グループのGID | 100 | 必須 |
loginShell | シェル | /bin/ | 任意 |
uidNumber | UID | 10001 | 必須 |
unixHomeDirectory | ホームディレクトリのパス | /home/ | 任意 |
※ CentOSでのデフォルト設定では必須
グループの場合はgidNumber属性の設定のみが必須となります。
ここまでの設定を行うことで、
$ getent passwd ldap01 ldap01:*:10011:100:ldap 01.:/home/ldap01:/bin/bash $ id ldap01 uid=10011(ldap01) gid=100(users) groups=100(users)
認証連携の動作確認
ここまでの設定を適切に行うことで、
$ ssh ubuntu1604-01 -l ldap01 Password: Last login: Mon Oct 9 18:27:08 2017 Could not chdir to home directory /home/ldap01: No such file or directory
ホームディレクトリの自動作成
上記では指定したホームディレクトリを作成していないためエラーが発生していますが、
# authconfig --enablemkhomedir --update
Ubuntuの場合は、
LDAP認証の通信と問題点
ここでは、
data:image/s3,"s3://crabby-images/4481f/4481f3bc30dbc809e2cbd7b7077c9a777b540511" alt="図4 LDAP認証によるログイン時の通信 図4 LDAP認証によるログイン時の通信"
大量のLDAPのやりとりが行われていますが、
実は、
なお、
$ passwd Changing password for user ldap01. (current) LDAP Password: New password: Retype new password: password change failed: Protocol error passwd: Authentication token manipulation error
これは、
data:image/s3,"s3://crabby-images/44994/449941bda0e11f3ce42565bed2de4efcd01acd3f" alt="図5 LDAP認証によるパスワード変更時(失敗)の通信 図5 LDAP認証によるパスワード変更時(失敗)の通信"
パケット528以降でパスワード変更の通信が行われています。ここではパケットの詳細を示していませんが、
ADで匿名認証を有効化する
冒頭で紹介したように、
data:image/s3,"s3://crabby-images/c2766/c2766acc58886241eb5dfa658b0364122e684824" alt="図6 dSHeuristics属性の変更 図6 dSHeuristics属性の変更"
詳細についてはMicrosoft サポートの
匿名認証を許可したら、
ここではLDAPという名前のOUに適切な設定を行う際の例を説明します。
data:image/s3,"s3://crabby-images/94cec/94cecba1ef0b349a8f626954e585eaaf15d6bbb8" alt="図7 匿名アクセスの追加 図7 匿名アクセスの追加"
さらに
これで、
まとめ
今回は、
次回以降ではこれを解決する対策について紹介していきます。