CentOS5での設定

Presented by 非武装エリア
最終更新日:2012年7月9日

CentOSはRedhat Linux互換のOSで、ここではRedhat Linux ES5互換であるCentOS 5でのLDAP連携について示します。
CentOSはすでにインストールされている物として以下の説明は行います。 なお、CentOSのインストール時には「Server」と「Server GUI」をパッケージグループとして選択してあるののとします。

■必要なパッケージ

LDAPを利用する上で必要なパッケージは次の通りとなります。
現在のパッケージの状況を見たいなら
# LANG=C; yum list | grep ldap
を実行して、表示されたパッケージ情報のステータスが、「installed」 になっていればインストール済みです。 もし、インストールが完了していないものがあれば、
# yum install パッケージ名 (ex. # yum install openldap-clients.x86_64)
を実行してインストールを実施してください。

■設定

authconfig の実施

CentOSでは、ログイン認証の方式を簡単に変更できる authconfig というツールが用意されているのそれを利用してLDAPのための基本的な設定を実施します。 なお、authconfig はGUI(X Window: authconfig-gui)用とCUI(テキストコンソール: authconfig-tui)用の2つが用意されているで、実行環境に合わせて選択してください。
ここでは、 authconfig-tui を使った設定を説明します。
コンソール画面を起動したら
# LANG=C; authconfig-tui
を実行します。 すると以下のような画面が表示されます。
ここで、次の項目を有効にします。
LDAP利用項目 パラメータ 状態 意味
User Information Cache Information 有効 情報をLDAPキャッシュを経由して検索する
Use LDAP 有効 ユーザ情報の取得をLDAPから取得する
Authentication Use MD5 Passwords 有効 パスワードにMD5暗号を利用する
Use Shadow Passwords 有効 シャドーパスワードを利用する
Use LDAP Authntication 有効 LDAPを使った認証を有効にする
[Next]をクリックすると次の画面が常時されます。
ここで入力するのは次のような内容になります。
パラメータ 意味
Use TLS SSL暗号でLDAPサーバと通信する場合に有効にします。 ただしActive Directoryとの間ではSSLは使えないので無効にしておきます。
Server LDAPサーバのアドレスを 指定します。サーバアドレスは、DNSなどに障害があった場合でも認証が受けられるようにする為に、IPアドレスで指定するほうが良いと思われます。
Base DN LDAPの検索を行う場合にどのDN名をベースにするかを選択します。 ベースの範囲を狭めることで検索に必要な時間が短縮可能です。例えば、ADの標準ユーザ情報コンテナである「CN=Users,DC=xxx,DC=xxx)を指定すれば、LDAP情報はこのコンテナに登録されているものだけを検索します。また、自分でADに専用のオブジェクトコンテナを作成した場合には、それを使うようにすることも可能です。(ex. OU=Users,OU=Unix,DC=xxx,DC=xxx)
ADのLDAPにどんなコンテナがあるかは、AD上にてmmcを起動して"ADSI Editスナップイン"を追加してドメインの情報に接続すれば、内容を表示・編集が可能になります。
以上設定したら[OK]をクリックして処理を終了します。 これらの設定を行った結果は、/etc/openldap.conf と /etc/ldap.conf、/etc/pam.d/system-auth といったファイルに反映されます。

/etc/openldap/ldap.conf の確認

/etc/openldap/ldap.conf は、LDAPクライアント(ex. ldapsearchなど)で使用されるファイルで、LDAPサーバの情報を定義しています。 このファイルが上記で設定した内容となっていることを確認してください。
・/etc/openldap/ldap.conf
#
# LDAP Defaults
#

# See ldap.conf(5) for details
# This file should be world readable but not world writable.

#BASE dc=example, dc=com
#URI ldap://ldap.example.com ldap://ldap-master.example.com:666

#SIZELIMIT 12
#TIMELIMIT 15
#DEREF never
URI ldap://192.168.100.30/
BASE dc=robata,dc=org
TLS_CACERTDIR /etc/openldap/cacerts

これらの設定は、authconfig ツールを使うと書き換えられてしまいますのでご注意ください。LDAPクライアントツールを使って設定した内容で正しくActiveDirectoryの情報が検索できるかLinux上で確認します。 使うツールは ldapsearch で、次のように入力します。
# ldapsearch -x -s base -b "" "(objectclass=*)" または、# ldapsearch -x でも良い
このコマンドの結果として以下のような情報が表示されてきます。(実際の表示内容は環境によって違ってきます)
# extended LDIF
#
# LDAPv3
# base <> with scope base
# filter: (objectclass=*)
# requesting: ALL
#

#
dn:
currentTime: 20060101151537.0Z
subschemaSubentry: CN=Aggregate,CN=Schema,CN=Configuration,DC=robata,DC=org
dsServiceName: CN=NTDS Settings,CN=LDAP,CN=Servers,CN=Default-First-Site-Name,
CN=Sites,CN=Configuration,DC=robata,DC=org
namingContexts: DC=robata,DC=org
::
::
::
ation,DC=robata,DC=org
supportedCapabilities: 1.2.840.113556.1.4.800
supportedCapabilities: 1.2.840.113556.1.4.1670
supportedCapabilities: 1.2.840.113556.1.4.1791
isSynchronized: TRUE
isGlobalCatalogReady: TRUE
domainFunctionality: 0
forestFunctionality: 0
domainControllerFunctionality: 2

# search result
search: 2
result: 0 Success

# numResponses: 2
# numEntries: 1
もしこのような情報が表示されなかったなら、DNSの設定が違うかここまでの設定のどこかにミスがないかを確認してみてください。

/etc/ldap.conf の編集

/etc/ldap.conf は、LDAPを使ったユーザ認証を利用する際に必要な情報が設定されます。ここには、ADを使っての認証を行う場合に必要なパラメータがあるので、それを編集します。編集箇所は、色つきになっている箇所となります。
・/etc/ldap.conf
# @(#)$Id: ldap.conf,v 1.38 2006/05/15 08:13:31 lukeh Exp $
#
# This is the configuration file for the LDAP nameservice
# switch library and the LDAP PAM module.
#
# The man pages for this file are nss_ldap(5) and pam_ldap(5)
#
# PADL Software
# http://www.padl.com
#

# Your LDAP server. Must be resolvable without using LDAP.
# Multiple hosts may be specified, each separated by a
# space. How long nss_ldap takes to failover depends on
# whether your LDAP client library supports configurable
# network or connect timeouts (see bind_timelimit).
#host 127.0.0.1

# The distinguished name of the search base.
base dc=robata,dc=org

# Another way to specify your LDAP server is to provide an
# uri with the server name. This allows to use
# Unix Domain Sockets to connect to a local LDAP Server.
#uri ldap://127.0.0.1/
#uri ldaps://127.0.0.1/
#uri ldapi://%2fvar%2frun%2fldapi_sock/
# Note: %2f encodes the '/' used as directory separator

# The LDAP version to use (defaults to 3
# if supported by client library)
#ldap_version 3

# The distinguished name to bind to the server with.
# Optional: default is to bind anonymously.
#binddn cn=proxyuser,dc=example,dc=com

# The credentials to bind with.
# Optional: default is no credential.
#bindpw secret

# The distinguished name to bind to the server with
# if the effective user ID is root. Password is
# stored in /etc/ldap.secret (mode 600)
#rootbinddn cn=manager,dc=example,dc=com

# The port.
# Optional: default is 389.
#port 389

# The search scope.
#scope sub
#scope one
#scope base

# Search timelimit
#timelimit 30
timelimit 120

# Bind/connect timelimit
#bind_timelimit 30
bind_timelimit 120

# Reconnect policy: hard (default) will retry connecting to
# the software with exponential backoff, soft will fail
# immediately.
#bind_policy hard

# Idle timelimit; client will close connections
# (nss_ldap only) if the server has not been contacted
# for the number of seconds specified below.
#idle_timelimit 3600
idle_timelimit 3600

# Filter to AND with uid=%s
#pam_filter objectclass=account

# The user ID attribute (defaults to uid)
#pam_login_attribute uid

# Search the root DSE for the password policy (works
# with Netscape Directory Server)
#pam_lookup_policy yes

# Check the 'host' attribute for access control
# Default is no; if set to yes, and user has no
# value for the host attribute, and pam_ldap is
# configured for account management (authorization)
# then the user will not be allowed to login.
#pam_check_host_attr yes

# Check the 'authorizedService' attribute for access
# control
# Default is no; if set to yes, and the user has no
# value for the authorizedService attribute, and
# pam_ldap is configured for account management
# (authorization) then the user will not be allowed
# to login.
#pam_check_service_attr yes

# Group to enforce membership of
#pam_groupdn cn=PAM,ou=Groups,dc=example,dc=com

# Group member attribute
#pam_member_attribute uniquemember

# Specify a minium or maximum UID number allowed
#pam_min_uid 0
#pam_max_uid 0

# Template login attribute, default template user
# (can be overriden by value of former attribute
# in user's entry)
#pam_login_attribute userPrincipalName
#pam_template_login_attribute uid
#pam_template_login nobody

# HEADS UP: the pam_crypt, pam_nds_passwd,
# and pam_ad_passwd options are no
# longer supported.
#
# Do not hash the password at all; presume
# the directory server will do it, if
# necessary. This is the default.
#pam_password clear

# Hash password locally; required for University of
# Michigan LDAP server, and works with Netscape
# Directory Server if you're using the UNIX-Crypt
# hash mechanism and not using the NT Synchronization
# service.
#pam_password crypt

# Remove old password first, then update in
# cleartext. Necessary for use with Novell
# Directory Services (NDS)
#pam_password clear_remove_old
#pam_password nds

# RACF is an alias for the above. For use with
# IBM RACF
#pam_password racf

# Update Active Directory password, by
# creating Unicode password and updating
# unicodePwd attribute.
#pam_password ad

# Use the OpenLDAP password change
# extended operation to update the password.
#pam_password exop

# Redirect users to a URL or somesuch on password
# changes.
#pam_password_prohibit_message Please visit http://internal to change your password.

# RFC2307bis naming contexts
# Syntax:
# nss_base_XXX base?scope?filter
# where scope is {base,one,sub}
# and filter is a filter to be &'d with the
# default filter.
# You can omit the suffix eg:
# nss_base_passwd ou=People,
# to append the default base DN but this
# may incur a small performance impact.
#nss_base_passwd ou=People,dc=example,dc=com?one
#nss_base_shadow ou=People,dc=example,dc=com?one
#nss_base_group ou=Group,dc=example,dc=com?one
#nss_base_hosts ou=Hosts,dc=example,dc=com?one
#nss_base_services ou=Services,dc=example,dc=com?one
#nss_base_networks ou=Networks,dc=example,dc=com?one
#nss_base_protocols ou=Protocols,dc=example,dc=com?one
#nss_base_rpc ou=Rpc,dc=example,dc=com?one
#nss_base_ethers ou=Ethers,dc=example,dc=com?one
#nss_base_netmasks ou=Networks,dc=example,dc=com?ne
#nss_base_bootparams ou=Ethers,dc=example,dc=com?one
#nss_base_aliases ou=Aliases,dc=example,dc=com?one
#nss_base_netgroup ou=Netgroup,dc=example,dc=com?one

# Just assume that there are no supplemental groups for these named users
nss_initgroups_ignoreusers root,ldap,named,avahi,haldaemon,dbus,radvd,tomcat,radiusd,news,mailman,nscd,gdm

# attribute/objectclass mapping
# Syntax:
#nss_map_attribute rfc2307attribute mapped_attribute
#nss_map_objectclass rfc2307objectclass mapped_objectclass

# configure --enable-nds is no longer supported.
# NDS mappings
#nss_map_attribute uniqueMember member

# Services for UNIX 3.5 mappings
#nss_map_objectclass posixAccount User
#nss_map_objectclass shadowAccount User
#nss_map_attribute uid msSFU30Name
#nss_map_attribute uniqueMember msSFU30PosixMember
#nss_map_attribute userPassword msSFU30Password
#nss_map_attribute homeDirectory msSFU30HomeDirectory
#nss_map_attribute homeDirectory msSFUHomeDirectory
#nss_map_objectclass posixGroup Group
#pam_login_attribute msSFU30Name
#pam_filter objectclass=User
#pam_password ad

# -
# configure --enable-mssfu-schema is no longer supported.
# Services for UNIX 3.5 mappings
nss_map_objectclass posixAccount User
nss_map_objectclass shadowAccount User
nss_map_attribute uid msSFU30Name
# nss_map_attribute uniqueMember msSFU30PosixMember
# nss_map_attribute uniqueMember member
#
# - nss_map_attribute userPassword msSFU30Password
nss_map_attribute homeDirectory msSFU30HomeDirectory
#nss_map_attribute homeDirectory msSFUHomeDirectory
nss_map_objectclass posixGroup Group
#
nss_map_attribute cn sAMAccountName
nss_map_attribute uidNumber msSFU30UidNumber
nss_map_attribute gidNumber msSFU30GidNumber
nss_map_attribute loginShell msSFU30LoginShell
nss_map_attribute gecos name

pam_login_attribute msSFU30Name
pam_filter objectclass=User
pam_password ad


# configure --enable-mssfu-schema is no longer supported.
# Services for UNIX 2.0 mappings
#nss_map_objectclass posixAccount User
#nss_map_objectclass shadowAccount user
#nss_map_attribute uid msSFUName
#nss_map_attribute uniqueMember posixMember
#nss_map_attribute userPassword msSFUPassword
#nss_map_attribute homeDirectory msSFUHomeDirectory
#nss_map_attribute shadowLastChange pwdLastSet
#nss_map_objectclass posixGroup Group
#nss_map_attribute cn msSFUName
#pam_login_attribute msSFUName
#pam_filter objectclass=User
#pam_password ad

# 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

# configure --enable-authpassword is no longer supported
# AuthPassword mappings
#nss_map_attribute userPassword authPassword

# AIX SecureWay mappings
#nss_map_objectclass posixAccount aixAccount
#nss_base_passwd ou=aixaccount,?one
#nss_map_attribute uid userName
#nss_map_attribute gidNumber gid
#nss_map_attribute uidNumber uid
#nss_map_attribute userPassword passwordChar
#nss_map_objectclass posixGroup aixAccessGroup
#nss_base_group ou=aixgroup,?one
#nss_map_attribute cn groupName
#nss_map_attribute uniqueMember member
#pam_login_attribute userName
#pam_filter objectclass=aixAccount
#pam_password clear

# Netscape SDK LDAPS
#ssl on

# Netscape SDK SSL options
#sslpath /etc/ssl/certs

# OpenLDAP SSL mechanism
# start_tls mechanism uses the normal LDAP port, LDAPS typically 636
#ssl start_tls
#ssl on

# OpenLDAP SSL options
# Require and verify server certificate (yes/no)
# Default is to use libldap's default behavior, which can be configured in
# /etc/openldap/ldap.conf using the TLS_REQCERT setting. The default for
# OpenLDAP 2.0 and earlier is "no", for 2.1 and later is "yes".
#tls_checkpeer yes

# CA certificates for server certificate verification
# At least one of these are required if tls_checkpeer is "yes"
#tls_cacertfile /etc/ssl/ca.cert
#tls_cacertdir /etc/ssl/certs

# Seed the PRNG if /dev/urandom is not provided
#tls_randfile /var/run/egd-pool

# SSL cipher suite
# See man ciphers for syntax
#tls_ciphers TLSv1

# Client certificate and key
# Use these, if your server requires client authentication.
#tls_cert
#tls_key

# Disable SASL security layers. This is needed for AD.
#sasl_secprops maxssf=0

# Override the default Kerberos ticket cache location.
#krb5_ccname FILE:/etc/.ldapcache

# SASL mechanism for PAM authentication - use is experimental
# at present and does not support password policy control
#pam_sasl_mech DIGEST-MD5
uri ldap://192.168.100.30/
ssl no
tls_cacertdir /etc/openldap/cacerts
# - pam_password md5


/etc/pam.d/system-auth の編集

/etc/pam.d/system-auth の編集は authconfig ツールで自動的に行われているので、原則不要です。ただし、Active Directoryに登録されているユーザのホームディレクトリがLinux上に存在しない場合、その状態でユーザがログインしてしまうとエラーとなってしまいます。
そこで、ホームディレクトリが存在しなかった場合に、自動的にホームディレクトリを作成するようにCentOS上で設定を行っておきます。
設定はsystem-auth 内の session セクションの最後に1行追加します。
・/etc/pam.d/system-auth
#%PAM-1.0
# This file is auto-generated.
# User changes will be destroyed the next time authconfig is run.
auth required pam_env.so
auth sufficient pam_unix.so nullok try_first_pass
auth requisite pam_succeed_if.so uid >= 500 quiet
auth sufficient pam_ldap.so use_first_pass
auth required pam_deny.so

account required pam_unix.so broken_shadow
::
::
::
password required pam_deny.so

session optional pam_keyinit.so revoke
session required pam_limits.so
session [success=1 default=ignore] pam_succeed_if.so service in crond quiet use_uid
session required pam_unix.so
session optional pam_ldap.so
session required pam_mkhomedir.so skel=/etc/skel umask=0022
これで、存在しないユーザでログインが実施されたときには、/etc/skel ディレクトリの内容をテンプレートにしてホームディレクトリが自動生成されます。


設定が終わったらLDAPのキャッシュ情報をクリアするために nscd をリスタートします。
# /etc/init.d/nscd restart
以上で、LDAPの情報を使ってCentOSにログインできるようになります。 ただし、まだActive Directoryのユーザ情報にUnix用の情報が登録されていないので、すぐには利用できません。
Active Directoryのユーザ情報にUnix情報を付加する」を実施して、ADのユーザ情報にUnix情報を付加しておいてください。

Copyright© 1998-2012 ROBATA.ORG