From 0387f5f5c1703f07d1111b08a0c0de4e1e90839d Mon Sep 17 00:00:00 2001 From: Howard Chu Date: Thu, 12 Jun 2014 13:23:29 -0700 Subject: [PATCH] Revert "ITS#7616 defer searches while consumer refreshing" This reverts commit cf4aa8f9d9ac77d2884a34fa0d2e52951cf06ca6. There appears to be no safe way for this to work with MMR. --- servers/slapd/syncrepl.c | 38 ++++++-------------------------------- 1 file changed, 6 insertions(+), 32 deletions(-) diff --git a/servers/slapd/syncrepl.c b/servers/slapd/syncrepl.c index 8e75fe8796..836adf1ed6 100644 --- a/servers/slapd/syncrepl.c +++ b/servers/slapd/syncrepl.c @@ -148,8 +148,6 @@ static int syncrepl_add_glue_ancestors( /* delta-mmr overlay handler */ static int syncrepl_op_modify( Operation *op, SlapReply *rs ); -static int syncrepl_op_search( Operation *op, SlapReply *rs ); - /* callback functions */ static int dn_callback( Operation *, SlapReply * ); static int nonpresent_callback( Operation *, SlapReply * ); @@ -218,14 +216,16 @@ init_syncrepl(syncinfo_t *si) if ( !syncrepl_ov.on_bi.bi_type ) { syncrepl_ov.on_bi.bi_type = "syncrepl"; syncrepl_ov.on_bi.bi_op_modify = syncrepl_op_modify; - syncrepl_ov.on_bi.bi_op_search = syncrepl_op_search; overlay_register( &syncrepl_ov ); } - if (!overlay_is_inst( si->si_be, syncrepl_ov.on_bi.bi_type )) { + /* delta-MMR needs the overlay, nothing else does. + * This must happen before accesslog overlay is configured. + */ + if ( si->si_syncdata && + !overlay_is_inst( si->si_be, syncrepl_ov.on_bi.bi_type )) { overlay_config( si->si_be, syncrepl_ov.on_bi.bi_type, -1, NULL, NULL ); - /* delta-MMR needs this. Must happen before accesslog overlay is configured. */ - if ( si->si_syncdata && !ad_reqMod ) { + if ( !ad_reqMod ) { const char *text; logschema *ls = &accesslog_sc; @@ -1179,7 +1179,6 @@ do_syncrep2( } else { rc = -2; } - si->si_refreshDone = 1; goto done; case LDAP_RES_INTERMEDIATE: @@ -2168,31 +2167,6 @@ syncrepl_op_modify( Operation *op, SlapReply *rs ) return SLAP_CB_CONTINUE; } -static int -syncrepl_op_search( Operation *op, SlapReply *rs ) -{ - slap_overinst *on = (slap_overinst *)op->o_bd->bd_info; - syncinfo_t *si; - - /* Allow syncrepl internal searches */ - if ( op->o_conn->c_conn_idx == -1 ) - return SLAP_CB_CONTINUE; - - /* Check if any of our consumers are refreshing */ - for ( si = op->o_bd->be_syncinfo; si; si = si->si_next ) { - /* If we have some state, allow other consumers to progress */ - if ( si->si_cookieState->cs_num > 0 && - op->o_sync > SLAP_CONTROL_IGNORED ) - return SLAP_CB_CONTINUE; - /* If we have any consumer refreshing, reject searches */ - if ( !si->si_refreshDone ) { - send_ldap_error( op, rs, LDAP_BUSY, "syncrepl refresh in progress" ); - return rs->sr_err; - } - } - return SLAP_CB_CONTINUE; -} - static int syncrepl_message_to_op( syncinfo_t *si, -- 2.39.5