|  Previous    
Contents    
Index    
DocHome    
Next | 
| iPlanet Directory Server 5.1 Deployment Guide | 
Chapter 5 Designing the Directory Topology 
In Chapter 4 "Designing the Directory Tree", you designed how your directory stores entries. Because Directory Server can store a large quantity of entries, you may need to distribute your entries across more than one server. Your directory's topology describes how you divide your directory tree among multiple physical Directory Servers and how these servers link with one another. 
This chapter describes planning the topology of your directory. It contains the following sections: 
Topology Overview 
Topology Overview 
You can design your deployment of iPlanet Directory Server to support a distributed directory where the directory tree you designed in Chapter 4 "Designing the Directory Tree" is spread across multiple physical Directory Servers. The way you choose to divide your directory across servers helps you accomplish the following: 
Achieve the best possible performance for your directory-enabled applications The database is the basic unit you use for jobs such as replication, performing backups, and restoring data. You can carve a single directory into manageable chunks and assign them to separate databases. These databases can then be distributed among a number of servers, reducing the work load for each server. You can store more than one database on a single server. For example, one server might contain three different databases. 
When you divide your directory tree across several databases, each database contains a portion of your directory tree, called a suffix. For example, you can use a database to store the entries in the ou=people,dc=siroe,dc=com suffix, or branch, of your directory tree. 
When you divide your directory among several servers, each server is responsible for only a part of the directory tree. The distributed directory works similarly to the Domain Name Service (DNS), which assigns each portion of the DNS namespace to a particular DNS server. Likewise, you can distribute your directory namespace across servers while maintaining a directory that, from a client's point of view, appears to be a single directory tree. 
The iPlanet Directory Server also provides knowledge references, mechanisms for linking directory data stored in different databases. Directory Server includes two types of knowledge references, referrals and chaining. 
The remainder of this chapter describes databases and knowledge references, explains the differences between the two types of knowledge references, and describes how you can design indexes to improve the performance of your databases. 
Distributing Your Data 
Distributing your data allows you to scale your directory across multiple servers without physically containing those directory entries on each server in your enterprise. A distributed directory can thus hold a much larger number of entries than would be possible with a single server. 
In addition, you can configure your directory to hide the distributing details from the user. As far as users and applications are concerned, there is simply a single directory that answers their directory queries. 
The following sections describe the mechanics of data distribution in more detail: 
"About Using Multiple Databases" 
About Using Multiple Databases 
iPlanet Directory Server stores data in LDBM databases.The LDBM database is a high-performance disk-based database. Each database consists of a set of large files that contains all of the data assigned to it. 
You can store different portions of your directory tree in different databases. For example, your directory tree appears as follows: 
You can store the data of the three suffixes in three separate databases as follows: 
When you divide your directory tree among a number of databases, these databases can then be distributed across multiple servers. For example, the three databases you created to contain the three suffixes of your directory tree can be stored on two servers as follows: 
Server A contains databases one and two and server B contains database three. 
Distributing databases across multiple servers reduces the amount of work each server needs to do. Thus, the directory can be made to scale to a much larger number of entries than would be possible with a single server. 
In addition, iPlanet Directory Server supports adding databases dynamically, meaning you can add new databases when your directory needs them without taking your entire directory off-line. 
About Suffixes 
Each database contains the data within a suffix of your directory server. You can create both root and sub suffixes to organize the contents of your directory tree. A root suffix is the entry at the top of a tree. It can be the root of your directory tree or part of a larger tree you have designed for your directory server. 
A sub suffix is a branch underneath a root suffix. The data for root and sub suffixes are contained by databases. 
For example, you want to create suffixes to represent the distribution of your directory data. The directory tree for siroe.com Corporation appears as follows: 
siroe.com Corporation decides to split their directory tree across five different databases as follows: 
The suffixes that result contain entries for the following: 
The o=NetscapeRoot and dc=siroe,dc=com suffixes are both root suffixes. The other ou=testing,dc=siroe,dc=com suffix, the ou=development,dc=siroe,dc=com suffix and the ou=partners,ou=development,odc=siroe,dc=com suffix are all sub suffixes of the dc=siroe,dc=com root suffix. The root suffix dc=siroe,dc=com contains the data in the ou=marketing, branch of the original directory tree. 
Your directory might contain more than one root suffix. For example, an ISP called I-Zed might host several websites, one for siroe.com and one for company22.com. The ISP would create two root suffixes, one corresponding to the dc=siroe,dc=com naming context and one corresponding to the dc=company22,dc=com naming context. The directory tree appears as follows: 
The dc=i-zed,dc=com entry represents a root suffix. The entry for each hosted ISP is also a root suffix (o=siroe and o=company22). The ou=people and the ou=groups branches are sub suffixes under each root suffix. 
About Knowledge References 
Once you have distributed your data over several databases, you need to define the relationship between the distributed data. You do this using knowledge references, pointers to directory information held in different databases. The iPlanet Directory Server provides the following types of knowledge references to help you link your distributed data into a single directory tree: 
Referrals 
The server returns a piece of information to the client application indicating that the client application needs to contact another server to fulfill the request. 
Chaining 
The server contacts other servers on behalf of the client application and returns the combined results to the client application after finishing the operation. 
The following sections describe and compare these two types of knowledge references in more detail. 
Using Referrals 
A referral is a piece of information returned by a server that tells a client application the server to contact to proceed with an operation request. This redirection mechanism occurs when a client application requests a directory entry that does not exist on the local server. 
Directory Server supports two types of referrals: 
A default referral 
The directory returns a default referral when a client application presents a DN for which the server does not have a matching suffix. Default referrals are stored in the configuration file of the server. You can set a default referral for the directory server and a separate default referral for each database. 
The default referral you set for each database is done through the suffix configuration information. When the suffix of the database is disabled, you can configure the directory to return a default referral to client requests made to that suffix. For more information about suffixes, refer to "About Suffixes". For information on configuring suffixes, refer to iPlanet Directory Server Administrator's Guide. 
Smart referrals 
Smart referrals are stored on entries within the directory itself. Smart referrals point to Directory Servers that have knowledge of the subtree whose DN matches the DN of the entry containing the smart referral. 
All referrals are returned in the format of an LDAP uniform resource locator (URL). The following sections describe the structure of an LDAP referral, and then describe the two referral types supported by Directory Server. 
The Structure of an LDAP Referral 
An LDAP referral contains information in the format of an LDAP URL. An LDAP URL contains the following information: 
The host name of the server to contact 
The base DN (for search operations) or target DN (for add, delete, and modify operations). For example, a client application searches dc=siroe,dc=com for entries with a surname Jensen. A referral returns the following LDAP URL to the client application: 
ldap://europe.siroe.com:389/ou=people,l=europe,dc=siroe,dc=com 
The referral tells the client application to contact the host europe.siroe.com on port 389 and submit a search rooted at ou=people,l=europe,dc=siroe,dc=com. 
The LDAP client application you use determines how a referral is handled. Some client applications automatically retry the operation on the server to which they have been referred. Other client applications simply return the referral information to the user. Most LDAP client applications provided by iPlanet (such as the command-line utilities) automatically follow the referral. The same bind credentials you supply on the initial directory request are used to access the server. 
Most client applications follow a limited number of referrals, or hops. The limit on the number of referrals followed reduces the time a client application spends trying to complete a directory lookup request and helps eliminate hung processes caused by circular referral patterns. 
About Default Referrals 
Default referrals are returned to clients when the server or database contacted does not contain the data requested. 
The directory server determines whether a default referral should be returned by comparing the DN of the requested directory object against the directory suffixes supported by the local server. If the DN does not match the supported suffixes, the directory server returns a default referral. 
For example, a directory client requests the following directory entry: 
uid=bjensen,ou=people,dc=siroe,dc=com 
However, the server manages only entries stored under the dc=europe,dc=siroe,dc=com suffix. The directory returns a referral to the client that indicates which server to contact for entries stored in the dc=siroe,dc=com suffix. The client then contacts the appropriate server and resubmits the original request. 
You configure the default referral to point to a Directory Server that has more knowledge about the distribution of your directory. Default referrals for the server are set by the nsslapd-referral attribute. Default referrals for each database in your directory installation are set by the nsslapd-referral attribute in the database entry in the configuration. These attribute values are stored in the dse.ldif file. 
For information on configuring default referrals, see the iPlanet Directory Server Administrator's Guide. 
Smart Referrals 
Directory Server also allows you to configure your directory to use smart referrals. Smart referrals allow you to associate a directory entry or directory tree to a specific LDAP URL. Associating directory entries to specific LDAP URLs allows you to refer requests to any of the following: 
Unlike default referrals, the smart referrals are stored within the directory itself. For information on configuring and managing smart referrals, refer to the iPlanet Directory Server Administrator's Guide. 
For example, the directory for the American office of siroe.com Corporation contains the following directory branch point: ou=people,dc=siroe,dc=com. 
You redirect all requests on this branch to the ou=people branch of the European office of siroe.com Corporation by specifying a smart referral on the ou=people entry itself. This smart referral appears as follows: 
ldap://europe.siroe.com:389/ou=people,dc=siroe,dc=com 
Any requests made to the people branch of the American directory are redirected to the European directory. An illustration of this smart referral follows: 
You can use the same mechanism to redirect queries to a different server that uses a different namespace. For example, an employee working in the Italian office of siroe.com Corporation makes a request to the European directory for the phone number of a siroe.com employee in America. The referral returned by the directory follows: 
ldap://europe.siroe.com:389/ou=US employees,dc=siroe,dc=com 
The following diagram illustrates how the referral works: 
Finally, if you serve multiple suffixes on the same server, you can redirect queries from one namespace to another namespace served on the same machine. If you want to redirect all queries on the local machine for o=siroe,c=us to dc=siroe,dc=com, then you would put the following smart referral on the o=siroe,c=us entry: 
The third slash in this LDAP URL indicates that the URL points to the same Directory Server. 
For more information on LDAP URLS and on how to include smart URLs on iPlanet Directory Server entries, see iPlanet Directory Server Administrator's Guide. 
Tips for Designing Smart Referrals 
While simple to implement, consider the following points before using smart referrals: 
Keep the design simple. 
Deploying your directory using a complex web of referrals makes administration difficult. Also, overusing smart referrals can lead to circular referral patterns. For example, a referral points to an LDAP URL, this LDAP URL in turn points to another LDAP URL, and so on until a referral somewhere in the chain points back to the original server. The following diagram depicts a circular referral pattern: 
Redirect at major branch points. 
Limit your referral usage to handle redirection at the suffix level of your directory tree. Smart referrals allow you to redirect lookup requests for leaf (non-branch) entries to different servers and DNs. As a result, you may be tempted to use smart referrals as an aliasing mechanism, leading to a complex and difficult to secure directory structure. By limiting referrals to the suffix or major branch points of your directory tree, you can limit the number of referrals that you have to manage, subsequently reducing your directory's administrative overhead. 
Consider the security implications. 
Access control does not cross referral boundaries. Even if the server where the request originated allows access to an entry, when a smart referral sends a client request to another server, the client application may not be allowed access. 
Also, the client credentials need to be available on the server to which the client is referred for client authentication to take place. 
Using Chaining 
Chaining is a method for relaying requests to another server. This method is implemented through database links. A database link, as described in the section titled "Distributing Your Data", contains no data. Instead, it redirects client application requests to remote servers that contain the data. 
During chaining, a server receives a request from a client application for data it does not contain. Using the database link, the server then contacts other servers on behalf of the client application and returns the results to the client application. This operation is illustrated in the following diagram. 
Each database link is associated to a remote server holding data. You can also configure alternate remote servers containing replicas of the data for the database link to use when there is a failure. For more information on configuring database links, refer to the iPlanet Directory Server Administrator's Guide. 
Database links provide the following features: 
Invisible access to remote data. 
Because the database link takes care of client requests, data distribution is completely hidden from the client. 
Dynamic management. 
You can add or remove a part of the directory from the system while the entire system remains available to client applications. The database link can temporarily return referrals to the application until entries have been redistributed across the directory. You can also implement this functionality through the suffix itself, which can return a referral rather than forwarding a client application on to the database. 
Access control. 
The database link impersonates the client application, providing the appropriate authorization identity to the remote server. You can disable user impersonation on the remote servers when access control evaluation is not required. For more information on configuring database links, refer to the iPlanet Directory Server Administrator's Guide. 
Deciding Between Referrals and Chaining 
Both methods of linking your directory partitions have advantages and disadvantages. The method, or combination of methods, you choose depends upon the specific needs of your directory. 
The major difference between the two knowledge references is the location of the intelligence that knows how to locate the distributed information. In a chained system, the intelligence is implemented in the servers. In a system that uses referrals, the intelligence is implemented in the client application. 
While chaining reduces client complexity, it does so at the cost of increased server complexity. Chained servers must work with remote servers and send the results to directory clients. 
With referrals, the client must handle locating the referral and collating search results. However, referrals offer more flexibility for the writers of client applications and allow developers to provide better feedback to users about the progress of a distributed directory operation. 
The following sections describe some of the more specific differences between referrals and chaining in greater detail. 
Usage Differences 
Some client applications do not support referrals. Chaining allows client applications to communicate with a single server and still access the data stored on many servers. Sometimes referrals do not work when a company's network uses proxies. For example, a client application has permissions to speak to only one server inside a firewall. If they are referred to a different server, they will not be able to contact it successfully. 
Also, with referrals a client must authenticate, meaning that the servers to which clients are being referred need to contain the client credentials. With chaining, client authentication takes place only once. Clients do not need to authenticate again on the servers to which their requests are chained. 
Evaluating Access Controls 
Chaining evaluates access controls differently from referrals. With referrals, an entry for the client must exist on all of the target servers. With chaining, the client entry does not need to be on all of the target servers. 
For example, a client sends a search request to server A. The following diagram illustrates the operation using referrals: 
In the illustration above, the client application performs the following steps: 
The client application first binds with Server A. 
Server A contains an entry for the client that provides a user name and password, so returns a bind acceptance message. In order for the referral to work, the client entry must be present on Server A. 
The client application sends the operation request to Server A. 
However, Server A does not contain the information requested. Instead, Server A returns a referral to the client application telling them to contact Server B. 
The client application then sends a bind request to Server B. To bind successfully, Server B must also contain an entry for the client application. 
The bind is successful, and the client application can now resubmit its search operation to Server B. This approach requires Server B to have a replicated copy of the client's entry from Server A. 
Chaining solves this problem. A search request would occur as follows on a chained system: 
In the illustration above, the following steps are performed: 
The client application binds with Server A and Server A tries to confirm that the user name and password are correct. 
Server A does not contain an entry corresponding to the client application. Instead, it contains a database link to Server B, which contains the actual entry of the client. Server A sends a bind request to Server B. 
Server B sends an acceptance response to Server A. 
Server A then processes the client application's request using the database link. The database link contacts a remote data store located on Server B to process the search operation. In a chained system, the entry corresponding to the client application does not need to be located on the same server as the data the client requests. For example, a system could be set up as follows: 
In this illustration, the following steps are performed: 
The client application binds with Server A and Server A tries to confirm that the user name and password are correct. 
Server A does not contain an entry corresponding to the client application. Instead, it contains a database link to Server B, which contains the actual entry of the client. Server A sends a bind request to Server B. 
Server B sends an acceptance response to Server A. 
Server A then processes the client application's request using another database link. The database link contacts a remote data store located on Server C to process the search operation. However, database links do not support the following access controls: 
Controls that must access the content of the user entry are not supported when the user entry is located on a different server. This includes access controls based on groups, filters, and roles. 
Controls based on client IP addresses or DNS domains may be denied. This is because the database link impersonates the client when it contacts remote servers. If the remote database contains IP-based access controls, it will evaluate them using the database link's domain rather than the original client domain. 
Using Indexes to Improve Database Performance 
Depending upon the size of your databases, searches performed by client applications can take a lot of time and resources. In order to improve search performance, you can use indexes. 
Indexes are files stored in your directory databases. Separate index files are maintained for each database in your directory. Each file is named according to the attribute it indexes. The index file for a particular attribute can contain multiple types of indexes, allowing you to maintain several types of index for each attribute. For example, a file called cn.db3 contains all of the indexes for the common name attribute. 
Depending upon the types of applications using your directory, you will use different types of index. Different applications may frequently search for a particular attribute, or may search your directory in a different language, or may require data in a particular format. 
This section contains the following topics: 
Overview of Directory Index Types 
Overview of Directory Index Types 
The directory supports the following types of index: 
Presence index. 
The presence index lists entries that possess a particular attribute, such as uid. 
Equality index. 
The equality index lists entries that contain a specific attribute value, such as cn=Babs Jensen. 
Approximate index. 
The approximate index allows approximate (or "sounds-like") searches. For example, an entry contains the attribute value of cn=Babs L. Jensen. An approximate search would return this value for searches again cn~=Babs Jensen, cn~=Babs, and cn~=Jensen. 
Note that approximate indexes work only for English names written in ASCII characters. 
Substring index. 
The substring index allows searches against substrings within entries. For example, a search for cn=*derson would match common names containing this string (such as Bill Anderson, Norma Henderson, and Steve Sanderson). 
International index. 
The international index speeds searches for information in international directories. You configure the index to apply a matching rule by associating a locale (OID) with the attribute being indexed. 
Browsing Index 
The browsing, or virtual list view (VLV), index speeds up the display of entries in the Directory Server Console. You can create a browsing index on any branch in your directory tree to improve the display performance. 
Evaluating the Costs of Indexing 
Indexes improve search performance in your directory databases, but at the following costs: 
Indexes increase the time it takes to modify entries. 
The more indexes you maintain, the longer it takes the directory to update the database. 
Index files use disk space. 
The more attributes you index, the more files you create. And, if you create approximate and substring indexes for attributes that contain long strings, these files can grow rapidly. 
Index files use memory. 
To run more efficiently, the directory places as many index files in memory as possible. Index files use memory out of the pool available depending upon the database cache size. A large number of index files requires a larger database cache. 
Index files take time to create. 
Although index files will save time during searches, maintaining unnecessary indexes can waste time. Be certain to maintain only the files needed by the client applications using your directory. 
Previous Contents Index DocHome Next
Copyright © 2002 Sun Microsystems, Inc. Some preexisting portions Copyright © 2001 Netscape Communications Corp. All rights reserved.
Last Updated February 26, 2002