diff --git a/src/raft/RaftManager.cc b/src/raft/RaftManager.cc index eaf06c0d99..38d5438b86 100644 --- a/src/raft/RaftManager.cc +++ b/src/raft/RaftManager.cc @@ -1040,11 +1040,16 @@ void RaftManager::request_vote() logdb->update_raft_state(raft_state_xml); - srand(_server_id); + srand(_server_id+1); - ms = rand() % 500 + election_timeout.tv_sec * 1000 + ms = rand() % 1000 + election_timeout.tv_sec * 1000 + election_timeout.tv_nsec / 1000000; + oss.str(""); + + oss << "No leader found, starting new election in " << ms << "ms"; + NebulaLog::log("RCM", Log::INFO, oss); + set_timeout(ms, etimeout); nanosleep(&etimeout, 0);