1999-10-01 00:57:45 +08:00
|
|
|
# $OpenLDAP$
|
2000-07-23 02:59:40 +08:00
|
|
|
# Copyright 1999-2000, The OpenLDAP Foundation, All Rights Reserved.
|
1999-04-24 07:41:45 +08:00
|
|
|
# COPYING RESTRICTIONS APPLY, see COPYRIGHT.
|
1999-04-24 07:00:44 +08:00
|
|
|
|
|
|
|
H1: A Quick-Start Guide to Running slapd
|
|
|
|
|
2000-07-30 23:20:14 +08:00
|
|
|
This chapter provides a quick step-by-step guide to building,
|
|
|
|
installing and running {{slapd}}(8). It is intended to provide
|
|
|
|
users with a simple and quick way to get started only.
|
|
|
|
If you intend to run slapd seriously, you should read the rest
|
|
|
|
of this guide.
|
|
|
|
|
|
|
|
|
|
|
|
Note: This guide does not use strong authentication nor any
|
|
|
|
privacy and integrity protection services. These services are
|
|
|
|
described in detail in later chapters. This guide should
|
|
|
|
only be used in isolated environments (such as on a single
|
|
|
|
host protected by a firewall).
|
1999-04-24 07:00:44 +08:00
|
|
|
|
|
|
|
|
2000-07-23 04:55:47 +08:00
|
|
|
^{{B:Get the software}}.
|
1999-05-03 09:19:22 +08:00
|
|
|
|
2000-07-30 23:20:14 +08:00
|
|
|
.{{slapd}} is part of the {{PRD:OpenLDAP}} distribution, which
|
2000-07-23 04:55:47 +08:00
|
|
|
you can retrieve from {{URL: http://www.openldap.org/software/download/}}
|
|
|
|
or {{URL: ftp://ftp.openldap.org/pub/OpenLDAP/openldap-release.tgz}}.
|
|
|
|
If you are reading this guide, you have probably already done this.
|
1999-05-03 09:19:22 +08:00
|
|
|
|
2000-07-23 15:35:40 +08:00
|
|
|
.{{S: }}
|
2000-07-23 04:55:47 +08:00
|
|
|
+{{B:Unpack the distribution}}.
|
1999-04-24 07:00:44 +08:00
|
|
|
|
2000-07-23 04:55:47 +08:00
|
|
|
.Pick a directory for the LDAP source to live under and change
|
|
|
|
directory there, and untar it. For example:
|
1999-05-03 09:19:22 +08:00
|
|
|
|
2000-07-23 03:23:03 +08:00
|
|
|
..{{EX:cd /usr/local/src}}
|
|
|
|
..{{EX:gunzip -c openldap-release.tgz | tar xvfB -}}
|
2000-07-23 04:55:47 +08:00
|
|
|
..{{EX:cd openldap-release}}
|
1999-05-03 09:19:22 +08:00
|
|
|
|
2000-07-23 09:43:12 +08:00
|
|
|
. You'll have to replace {{F:openldap-release}} with the full
|
2000-07-23 04:55:47 +08:00
|
|
|
name of the release.
|
|
|
|
|
|
|
|
|
2000-07-23 15:35:40 +08:00
|
|
|
.{{S: }}
|
2000-07-23 04:55:47 +08:00
|
|
|
+{{B: Configure the software}}.
|
|
|
|
|
2000-07-30 23:20:14 +08:00
|
|
|
.You will need to run the {{EX:configure}} script to configure slapd.
|
1999-05-03 09:19:22 +08:00
|
|
|
|
2000-07-23 03:23:03 +08:00
|
|
|
..{{EX:./configure}}
|
1999-04-24 07:00:44 +08:00
|
|
|
|
2000-07-30 23:20:14 +08:00
|
|
|
. The {{EX:configure}} accepts many command line options that enable
|
|
|
|
or disable optional software features. Usually the defaults are okay,
|
|
|
|
but you may want to change them. To get a complete list of options
|
|
|
|
that {{EX:configure}} accepts, use the {{EX:--help}} option.
|
1999-05-03 09:19:22 +08:00
|
|
|
|
2000-07-23 03:23:03 +08:00
|
|
|
..{{EX:./configure --help}}
|
1999-05-03 09:19:22 +08:00
|
|
|
|
2000-07-20 07:12:15 +08:00
|
|
|
. Once OpenLDAP has been configured, it needs to be compiled.
|
2000-07-30 23:20:14 +08:00
|
|
|
You'll need to construct dependencies and then compile the software
|
|
|
|
using {{make}}(1) utility.
|
2000-07-20 07:12:15 +08:00
|
|
|
For example:
|
1999-04-24 07:00:44 +08:00
|
|
|
|
2000-07-23 03:23:03 +08:00
|
|
|
..{{EX:make depend}}
|
|
|
|
..{{EX:make}}
|
1999-04-24 07:00:44 +08:00
|
|
|
|
2000-07-20 07:12:15 +08:00
|
|
|
. Once OpenLDAP is compiled you need to install it. By default OpenLDAP
|
2000-07-23 09:43:12 +08:00
|
|
|
is installed into {{F:/usr/local}}. This is typically done as root.
|
1999-05-03 09:19:22 +08:00
|
|
|
|
2000-07-30 23:20:14 +08:00
|
|
|
..{{EX:su root -c 'make install'}}
|
1999-05-03 09:19:22 +08:00
|
|
|
|
2000-07-23 15:35:40 +08:00
|
|
|
|
|
|
|
.{{S: }}
|
2000-07-23 04:55:47 +08:00
|
|
|
+{{B:Edit the configuration file}}.
|
|
|
|
|
2000-07-30 23:20:14 +08:00
|
|
|
.Use this chapter as a brief tutorial. For more details on the
|
|
|
|
configuration file, see slapd.conf(5) and chapter 5.
|
1999-04-24 07:00:44 +08:00
|
|
|
|
2000-07-23 04:55:47 +08:00
|
|
|
.Now we need to edit the default configuration file that was
|
2000-07-30 23:20:14 +08:00
|
|
|
installed earlier. The {{slapd}} configuration file {{slapd.conf}}(5)
|
2000-07-23 15:35:40 +08:00
|
|
|
for is normally located at {{F:/usr/local/etc/openldap/slapd.conf}}.
|
2000-07-30 23:20:14 +08:00
|
|
|
If you specified the {{EX:--prefix}} option when you ran {{EX:configure}},
|
2000-07-23 09:43:12 +08:00
|
|
|
then replace {{F:/usr/local}} with the value you gave as the
|
2000-07-30 23:20:14 +08:00
|
|
|
prefix. For example, if you ran {{EX:configure}} as
|
1999-05-03 09:19:22 +08:00
|
|
|
|
2000-07-23 03:23:03 +08:00
|
|
|
..{{EX:./configure --prefix=/opt/ldap}}
|
2000-07-20 07:12:15 +08:00
|
|
|
|
2000-07-23 04:55:47 +08:00
|
|
|
.You would find your configuration file in
|
2000-07-23 09:43:12 +08:00
|
|
|
{{F:/opt/ldap/etc/openldap/slapd.conf}}.
|
2000-07-23 04:55:47 +08:00
|
|
|
Now look in the configuration file for a line that begins with
|
2000-07-20 07:12:15 +08:00
|
|
|
|
2000-07-23 04:55:47 +08:00
|
|
|
..{{EX:database ldbm}}
|
2000-07-20 07:12:15 +08:00
|
|
|
|
2000-07-30 23:20:14 +08:00
|
|
|
.This marks the begining of the database configuration for {{slapd}}.
|
2000-07-23 15:35:40 +08:00
|
|
|
Everything you will need to change for this example is located
|
|
|
|
after this line.
|
2000-07-23 04:55:47 +08:00
|
|
|
|
|
|
|
.Listed below are the default settings for the database in
|
2000-07-30 23:20:14 +08:00
|
|
|
{{F:slapd.conf}}(5). Lines that begin with a sharp sign ('{{EX:#}}')
|
2000-07-23 15:35:40 +08:00
|
|
|
are considered to be comments by slapd, they have been removed
|
|
|
|
from the listing below to save space. If a line starts with
|
|
|
|
white space it is considered a continuation of the preceeding
|
|
|
|
line.
|
2000-07-20 07:12:15 +08:00
|
|
|
|
2000-07-23 03:23:03 +08:00
|
|
|
..{{EX:suffix "dc=my-domain, dc=com"}}
|
|
|
|
..{{EX:rootdn "cn=Manager, dc=my-domain, dc=com"}}
|
|
|
|
..{{EX:rootpw secret}}
|
|
|
|
..{{EX:directory /usr/local/var/openldap-ldbm}}
|
2000-07-20 07:12:15 +08:00
|
|
|
|
2000-07-23 04:55:47 +08:00
|
|
|
. Now we need to replace all of the references to {{EX:my-domain}}
|
|
|
|
and {{EX:com}} with the correct value. For example, if your domain
|
|
|
|
is {{EX:example.net}} we might use the following.
|
2000-07-20 07:12:15 +08:00
|
|
|
|
2000-07-23 03:23:03 +08:00
|
|
|
..{{EX:suffix "dc=example, dc=net"}}
|
|
|
|
..{{EX:rootdn "cn=Manager, dc=example, dc=net"}}
|
|
|
|
..{{EX:rootpw secret}}
|
|
|
|
..{{EX:directory /usr/local/var/openldap-ldbm}}
|
1999-04-24 07:00:44 +08:00
|
|
|
|
2000-07-23 04:55:47 +08:00
|
|
|
. By default, the database files will be created in
|
2000-07-23 09:43:12 +08:00
|
|
|
{{F:/usr/local/var/openldap-ldbm}}.
|
2000-07-23 04:55:47 +08:00
|
|
|
You may specify an alternate directory via the directory option
|
2000-07-23 09:43:12 +08:00
|
|
|
in the {{F:slapd.conf}} file. The directory must exist before
|
2000-07-23 04:55:47 +08:00
|
|
|
you start the server.
|
|
|
|
|
2000-07-30 23:20:14 +08:00
|
|
|
Note: Use of rootpw is deprecated in favor of strong authentication
|
|
|
|
mechanisms. These are described in later chapters.
|
2000-07-23 15:35:40 +08:00
|
|
|
|
|
|
|
.{{S: }}
|
2000-07-23 04:55:47 +08:00
|
|
|
+{{B:Starting the server}}.
|
|
|
|
|
|
|
|
.You are now ready to start the server by running the command
|
2000-07-30 23:20:14 +08:00
|
|
|
{{slapd}}(8):
|
2000-07-23 04:55:47 +08:00
|
|
|
|
|
|
|
..{{EX:/usr/local/libexec/slapd}}
|
|
|
|
|
|
|
|
. At this point the LDAP server is up and running, but there isn't
|
|
|
|
any data in the directory. You can check to see if the server is
|
|
|
|
running and your naming context (the {{EX:suffix}} you specified above)
|
2000-07-30 23:20:14 +08:00
|
|
|
by searching it with {{ldapsearch}}(1). By default ldapsearch is
|
2000-07-23 09:43:12 +08:00
|
|
|
installed as {{F:/usr/local/bin/ldapsearch}}.
|
2000-07-23 04:55:47 +08:00
|
|
|
|
|
|
|
..{{EX:ldapsearch -x -b '' -s base '(objectclass=*)' namingContexts}}
|
|
|
|
|
2000-07-30 23:20:14 +08:00
|
|
|
. Note the use of single quotes around command parameters to prevent
|
2000-07-23 04:55:47 +08:00
|
|
|
special characters from interpreted by the shell. This should return:
|
|
|
|
|
|
|
|
..{{EX:dn:}}
|
|
|
|
..{{EX:namingContexts: dc=example, dc=net}}
|
|
|
|
|
2000-07-23 15:35:40 +08:00
|
|
|
|
|
|
|
.{{S: }}
|
2000-07-23 04:55:47 +08:00
|
|
|
+{{B:Create a database}}.
|
|
|
|
|
|
|
|
. This is a two-step process. The first step is to create a file
|
2000-07-23 09:43:12 +08:00
|
|
|
(we'll call it {{F:example.ldif}}) containing the entries you
|
2000-07-23 04:55:47 +08:00
|
|
|
want your database to contain. Use the following example as a
|
|
|
|
guide, or see Section 7.3 for more details.
|
1999-04-24 07:00:44 +08:00
|
|
|
|
2000-07-23 03:23:03 +08:00
|
|
|
..{{EX:dn: dc=example, dc=net}}
|
|
|
|
..{{EX:objectclass: dcObject}}
|
|
|
|
..{{EX:objectclass: organization}}
|
2000-07-23 04:55:47 +08:00
|
|
|
..{{EX:o: Example Network}}
|
2000-07-23 03:23:03 +08:00
|
|
|
..{{EX:dc: example}}
|
2000-07-23 04:55:47 +08:00
|
|
|
..{{EX: }}
|
2000-07-23 03:23:03 +08:00
|
|
|
..{{EX:dn: cn=Bob Smith, dc=example, dc=net}}
|
|
|
|
..{{EX:objectclass: person}}
|
|
|
|
..{{EX:cn: Bob Smith}}
|
|
|
|
..{{EX:sn: Smith}}
|
2000-07-20 07:12:15 +08:00
|
|
|
|
2000-07-23 04:55:47 +08:00
|
|
|
.Remember to replace {{EX:dc=example, dc=net}} with the correct
|
|
|
|
values for your site, and to put your name instead of Bob's. You can
|
|
|
|
include additional entries and attributes in this file if you want,
|
1999-05-03 09:19:22 +08:00
|
|
|
or add them later via LDAP.
|
|
|
|
|
2000-07-23 04:55:47 +08:00
|
|
|
.The second step is to run a tool to add the contents of this file to the
|
2000-07-30 23:20:14 +08:00
|
|
|
your directory. We use the tool {{ldapadd}}(1) to populate the directory.
|
2000-07-23 04:55:47 +08:00
|
|
|
Again remember to replace {{EX:dc=example, dc=net}} with the correct values
|
|
|
|
for your site. By default ldapadd is installed as
|
2000-07-23 09:43:12 +08:00
|
|
|
{{F:/usr/local/bin/ldapadd}}.
|
2000-07-20 07:22:34 +08:00
|
|
|
|
2000-07-23 04:55:47 +08:00
|
|
|
..{{EX:ldapadd -x -D 'cn=Manager,dc=example,dc=net' -w secret -f example.ldif}}
|
2000-07-20 07:22:34 +08:00
|
|
|
|
2000-07-23 09:43:12 +08:00
|
|
|
.Where {{F:example.ldif}} is the file you created above.
|
2000-07-20 07:22:34 +08:00
|
|
|
|
2000-07-30 23:20:14 +08:00
|
|
|
Note: Use of transport security services is recommended when updating
|
|
|
|
the directory. These services are described in later chapters.
|
|
|
|
|
|
|
|
|
2000-07-23 15:35:40 +08:00
|
|
|
.{{S: }}
|
2000-07-23 04:55:47 +08:00
|
|
|
+{{B:See if it works}}.
|
2000-07-20 07:12:15 +08:00
|
|
|
|
2000-07-23 04:55:47 +08:00
|
|
|
.Now we're ready to verify the added entries are in your directory.
|
|
|
|
You can use any LDAP client to do this, but our example uses the
|
2000-07-30 23:20:14 +08:00
|
|
|
{{ldapsearch}}(1) tool. Remember to replace {{EX:dc=example,dc=net}}
|
2000-07-23 04:55:47 +08:00
|
|
|
with the correct values for your site.
|
1999-04-24 07:00:44 +08:00
|
|
|
|
2000-07-23 03:23:03 +08:00
|
|
|
..{{EX:ldapsearch -x -b 'dc=example,dc=net' '(objectclass=*)'}}
|
1999-04-24 07:00:44 +08:00
|
|
|
|
2000-07-23 04:55:47 +08:00
|
|
|
.This command will search for and retrieve every entry in the database.
|
|
|
|
|
2000-07-30 23:20:14 +08:00
|
|
|
You are now ready to add more entries using {{ldapadd}}(1) or
|
2000-07-23 04:55:47 +08:00
|
|
|
another LDAP client, experiment with various configuration options,
|
2000-07-30 23:20:14 +08:00
|
|
|
backend arrangements, etc. Note that by default, the {{slapd}}(8)
|
|
|
|
database grants {{read access to everybody}} excepting the
|
|
|
|
{{super-user}} (as specified by the {{EX:rootdn}} configuration
|
|
|
|
directive). It is highly recommended that you establish controls
|
|
|
|
to restrict access to authorized users. Access controls are discussed
|
|
|
|
in a later chapter.
|
|
|
|
|
|
|
|
The following chapters provide more detailed information on making,
|
|
|
|
installing, and running {{slapd}}(8).
|
1999-04-24 07:00:44 +08:00
|
|
|
|