diff options
-rw-r--r-- | ldap/servers/slapd/back-ldbm/id2entry.c | 6 | ||||
-rw-r--r-- | ldap/servers/slapd/back-ldbm/monitor.c | 14 |
2 files changed, 11 insertions, 9 deletions
diff --git a/ldap/servers/slapd/back-ldbm/id2entry.c b/ldap/servers/slapd/back-ldbm/id2entry.c index 977e0b44..40512146 100644 --- a/ldap/servers/slapd/back-ldbm/id2entry.c +++ b/ldap/servers/slapd/back-ldbm/id2entry.c @@ -100,8 +100,10 @@ id2entry_add_ext( backend *be, struct backentry *e, back_txn *txn, int encrypt struct backdn *bdn = backdn_init(sdn, e->ep_id, 0); options |= SLAPI_DUMP_RDN_ENTRY; - /* If the ID already exists in the DN cache, replace it. */ - if (CACHE_ADD( &inst->inst_dncache, bdn, &oldbdn ) == 1) { + /* If the ID already exists in the DN cache && the DNs do not match, + * replace it. */ + if ((CACHE_ADD( &inst->inst_dncache, bdn, &oldbdn ) == 1) && + (slapi_sdn_compare(sdn, oldbdn->dn_sdn))) { cache_replace( &inst->inst_dncache, oldbdn, bdn ); CACHE_RETURN(&inst->inst_dncache, &oldbdn); /* to free oldbdn */ } diff --git a/ldap/servers/slapd/back-ldbm/monitor.c b/ldap/servers/slapd/back-ldbm/monitor.c index 265021c9..075a48fc 100644 --- a/ldap/servers/slapd/back-ldbm/monitor.c +++ b/ldap/servers/slapd/back-ldbm/monitor.c @@ -131,19 +131,19 @@ int ldbm_back_monitor_instance_search(Slapi_PBlock *pb, Slapi_Entry *e, cache_get_stats(&(inst->inst_dncache), &hits, &tries, &nentries, &maxentries, &size, &maxsize); sprintf(buf, "%" NSPRIu64, hits); - MSET("dnEntryCacheHits"); + MSET("dnCacheHits"); sprintf(buf, "%" NSPRIu64, tries); - MSET("dnEntryCacheTries"); + MSET("dnCacheTries"); sprintf(buf, "%lu", (unsigned long)(100.0*(double)hits / (double)(tries > 0 ? tries : 1))); - MSET("dnEntryCacheHitRatio"); + MSET("dnCacheHitRatio"); sprintf(buf, "%lu", size); - MSET("dnCurrentEntryCacheSize"); + MSET("currentDnCacheSize"); sprintf(buf, "%lu", maxsize); - MSET("dnMaxEntryCacheSize"); + MSET("maxDnCacheSize"); sprintf(buf, "%ld", nentries); - MSET("dnCurrentEntryCacheCount"); + MSET("currentDnCacheCount"); sprintf(buf, "%ld", maxentries); - MSET("dnMaxEntryCacheCount"); + MSET("maxDnCacheCount"); } #ifdef DEBUG |