This problem occurs if Exchange 2000 incorrectly interprets a valid Exchange 2000 Server Messaging Database (MDB) GUID to be the distinguished name of a Microsoft Exchange Server 5.5 MDB.
The Exchange Server 5.5 format for an MDB in the replication state table is a compressed server legacy distinguished name. The site part of the compressed distinguished name is stored in a lookup table. In this compressed distinguished name, this site part is replaced by an index to the lookup table where the site part of the distinguished name is stored. The rest of the server name, including the terminating NULL character, appears after this index to the lookup table. Therefore, the Exchange Server 5.5 MDB in the replication state table may appear similar to the following:
03 10 'M' 'Y' 'S' 'E' 'R' 'V' 'E' 'R' 00
When the problem that is described in the "Symptoms" section occurs, it occurs because the computer name has 13 characters. If the computer name has 13 characters, the whole Exchange Server 5.5 MDB entry in the replication state table has 16 bytes. Therefore, if the computer name has 13 characters, the whole entry is the same length as a GUID. An Exchange Server 5.5 compressed distinguished name and an Exchange 2000 GUID are both stored in the same column of the replication state table. When Exchange 2000 loads this table, Exchange 2000 must determine whether the data object is an Exchange 2000 GUID or an Exchange Server 5.5 compressed distinguished name.
Exchange 2000 first determines this data to be a directory service GUID and searches for this object in the Active Directory directory service. If this object does not appear in Active Directory, Exchange 2000 performs a test to determine whether this object is an Exchange Server 5.5 compressed DN. To test this, Exchange 2000 does the following:
- Exchange 2000 verifies whether the binary large object is equal to or more than 5 bytes.
- Exchange 2000 verifies whether the binary large object has a single zero byte.
- Exchange 2000 verifies whether the single zero byte is the last byte of the binary large object.
If all these conditions are true, Exchange 2000 determines the object to be an Exchange Server 5.5 compressed DN.
Consider the following scenario:
- You have a valid directory service GUID for an Exchange 2000 database.
- This GUID is longer than 5 bytes.
- This GUID has a single zero byte at the end of the binary large object.
- This GUID is no longer present in Active Directory.
In this scenario, Exchange 2000 incorrectly determines this GUID to be an Exchange Server 5.5 compressed distinguished name. Therefore, the replication engine does not initialize when the database is mounted.