From 22c8d6c445c380c9fa6a913e2d80a0d47b008ff1 Mon Sep 17 00:00:00 2001 From: Arpan Agrawal Date: Mon, 6 Mar 2023 17:25:04 +0530 Subject: [PATCH] Lazy superblock flush on colocated table creation Test Plan: TODO Subscribers: bogdan Differential Revision: https://phabricator.dev.yugabyte.com/D23349 --- src/yb/consensus/consensus_peers-test.cc | 6 +++++- src/yb/consensus/consensus_queue-test.cc | 4 +++- src/yb/consensus/log-dump.cc | 6 +++++- src/yb/consensus/log-test-base.h | 5 ++++- src/yb/consensus/log.h | 2 +- src/yb/consensus/log_cache-test.cc | 5 ++++- src/yb/consensus/raft_consensus-test.cc | 6 ++++-- src/yb/consensus/raft_consensus_quorum-test.cc | 5 ++++- src/yb/tablet/tablet_peer-test.cc | 3 ++- src/yb/tserver/remote_bootstrap_session-test.cc | 3 ++- 10 files changed, 34 insertions(+), 11 deletions(-) diff --git a/src/yb/consensus/consensus_peers-test.cc b/src/yb/consensus/consensus_peers-test.cc index 1707d59156f6..dfbb161cee83 100644 --- a/src/yb/consensus/consensus_peers-test.cc +++ b/src/yb/consensus/consensus_peers-test.cc @@ -57,6 +57,8 @@ using namespace std::chrono_literals; +DECLARE_bool(lazily_flush_superblock); + METRIC_DECLARE_entity(tablet); namespace yb { @@ -92,6 +94,7 @@ class ConsensusPeersTest : public YBTest { ASSERT_OK(ThreadPoolBuilder("log").Build(&log_thread_pool_)); fs_manager_.reset(new FsManager(env_.get(), GetTestPath("fs_root"), "tserver_test")); + FLAGS_lazily_flush_superblock = false; ASSERT_OK(fs_manager_->CreateInitialFileSystemLayout()); ASSERT_OK(fs_manager_->CheckAndOpenFileSystemRoots()); ASSERT_OK(Log::Open(options_, @@ -106,7 +109,8 @@ class ConsensusPeersTest : public YBTest { log_thread_pool_.get(), log_thread_pool_.get(), std::numeric_limits::max(), // cdc_min_replicated_index - &log_)); + &log_, + nullptr)); clock_.reset(new server::HybridClock()); ASSERT_OK(clock_->Init()); diff --git a/src/yb/consensus/consensus_queue-test.cc b/src/yb/consensus/consensus_queue-test.cc index 45ee90f30c19..72a9b74374f6 100644 --- a/src/yb/consensus/consensus_queue-test.cc +++ b/src/yb/consensus/consensus_queue-test.cc @@ -81,6 +81,7 @@ class ConsensusQueueTest : public YBTest { void SetUp() override { YBTest::SetUp(); + FLAGS_lazily_flush_superblock = false; fs_manager_.reset(new FsManager(env_.get(), GetTestPath("fs_root"), "tserver_test")); ASSERT_OK(fs_manager_->CreateInitialFileSystemLayout()); ASSERT_OK(fs_manager_->CheckAndOpenFileSystemRoots()); @@ -97,7 +98,8 @@ class ConsensusQueueTest : public YBTest { log_thread_pool_.get(), log_thread_pool_.get(), std::numeric_limits::max(), // cdc_min_replicated_index - &log_)); + &log_, + nullptr)); clock_.reset(new server::HybridClock()); ASSERT_OK(clock_->Init()); diff --git a/src/yb/consensus/log-dump.cc b/src/yb/consensus/log-dump.cc index c383e2eed3f1..a5485dc4c1e3 100644 --- a/src/yb/consensus/log-dump.cc +++ b/src/yb/consensus/log-dump.cc @@ -96,6 +96,8 @@ DEFINE_UNKNOWN_int64(max_op_index_to_omit, yb::OpId::Invalid().index, DEFINE_UNKNOWN_string(output_wal_dir, "", "WAL directory for the output of --filter_log_segment"); +DECLARE_bool(lazily_flush_superblock); + namespace yb { namespace log { @@ -406,6 +408,7 @@ Status FilterLogSegment(const string& segment_path) { LOG(INFO) << "Will include all records of the source WAL in the output"; } + FLAGS_lazily_flush_superblock = false; scoped_refptr log; RETURN_NOT_OK(Log::Open( log_options, @@ -420,7 +423,8 @@ Status FilterLogSegment(const string& segment_path) { log_thread_pool.get(), log_thread_pool.get(), /* cdc_min_replicated_index */ 0, - &log)); + &log, + nullptr)); auto read_entries = segment->ReadEntries(); RETURN_NOT_OK(read_entries.status); diff --git a/src/yb/consensus/log-test-base.h b/src/yb/consensus/log-test-base.h index c118756273f6..9fb71fda8958 100644 --- a/src/yb/consensus/log-test-base.h +++ b/src/yb/consensus/log-test-base.h @@ -76,6 +76,7 @@ METRIC_DECLARE_entity(table); METRIC_DECLARE_entity(tablet); +DECLARE_bool(lazily_flush_superblock); DECLARE_int32(log_min_seconds_to_retain); namespace yb { @@ -183,6 +184,7 @@ class LogTestBase : public YBTest { void BuildLog() { Schema schema_with_ids = SchemaBuilder(schema_).Build(); + FLAGS_lazily_flush_superblock = false; ASSERT_OK(Log::Open(options_, kTestTablet, tablet_wal_path_, @@ -195,7 +197,8 @@ class LogTestBase : public YBTest { log_thread_pool_.get(), log_thread_pool_.get(), std::numeric_limits::max(), // cdc_min_replicated_index - &log_)); + &log_, + nullptr)); LOG(INFO) << "Sucessfully opened the log at " << tablet_wal_path_; } diff --git a/src/yb/consensus/log.h b/src/yb/consensus/log.h index b6f8b692baf9..9e2cee93eaa6 100644 --- a/src/yb/consensus/log.h +++ b/src/yb/consensus/log.h @@ -153,7 +153,7 @@ class Log : public RefCountedThreadSafe { ThreadPool* background_sync_threadpool, int64_t cdc_min_replicated_index, scoped_refptr *log, - tablet::RaftGroupMetadata* metadata = nullptr, // TODO + tablet::RaftGroupMetadata* metadata, CreateNewSegment create_new_segment = CreateNewSegment::kTrue); ~Log(); diff --git a/src/yb/consensus/log_cache-test.cc b/src/yb/consensus/log_cache-test.cc index a397ed3a8bcf..496adaa2f6ff 100644 --- a/src/yb/consensus/log_cache-test.cc +++ b/src/yb/consensus/log_cache-test.cc @@ -65,6 +65,7 @@ using std::atomic; using std::shared_ptr; using std::thread; +DECLARE_bool(lazily_flush_superblock); DECLARE_int32(log_cache_size_limit_mb); DECLARE_int32(global_log_cache_size_limit_mb); DECLARE_int32(global_log_cache_size_limit_percentage); @@ -102,6 +103,7 @@ class LogCacheTest : public YBTest { void SetUp() override { YBTest::SetUp(); + FLAGS_lazily_flush_superblock = false; fs_manager_.reset(new FsManager(env_.get(), GetTestPath("fs_root"), "tserver_test")); ASSERT_OK(fs_manager_->CreateInitialFileSystemLayout()); ASSERT_OK(fs_manager_->CheckAndOpenFileSystemRoots()); @@ -118,7 +120,8 @@ class LogCacheTest : public YBTest { log_thread_pool_.get(), log_thread_pool_.get(), std::numeric_limits::max(), // cdc_min_replicated_index - &log_)); + &log_, + nullptr)); CloseAndReopenCache(MinimumOpId()); clock_.reset(new server::HybridClock()); diff --git a/src/yb/consensus/raft_consensus-test.cc b/src/yb/consensus/raft_consensus-test.cc index dfc04e959473..09553665b961 100644 --- a/src/yb/consensus/raft_consensus-test.cc +++ b/src/yb/consensus/raft_consensus-test.cc @@ -55,6 +55,7 @@ #include "yb/util/test_macros.h" #include "yb/util/test_util.h" +DECLARE_bool(lazily_flush_superblock); DECLARE_bool(enable_leader_failure_detection); DECLARE_bool(never_fsync); @@ -223,7 +224,7 @@ class RaftConsensusTest : public YBTest { void SetUp() override { YBTest::SetUp(); - + FLAGS_lazily_flush_superblock = false; LogOptions options; string test_path = GetTestPath("test-peer-root"); @@ -246,7 +247,8 @@ class RaftConsensusTest : public YBTest { log_thread_pool_.get(), log_thread_pool_.get(), std::numeric_limits::max(), // cdc_min_replicated_index - &log_)); + &log_, + nullptr)); log_->TEST_SetAllOpIdsSafe(true); diff --git a/src/yb/consensus/raft_consensus_quorum-test.cc b/src/yb/consensus/raft_consensus_quorum-test.cc index acad4e2ae2ed..30eeea4c28bc 100644 --- a/src/yb/consensus/raft_consensus_quorum-test.cc +++ b/src/yb/consensus/raft_consensus_quorum-test.cc @@ -65,6 +65,7 @@ DECLARE_int32(raft_heartbeat_interval_ms); DECLARE_bool(enable_leader_failure_detection); +DECLARE_bool(lazily_flush_superblock); METRIC_DECLARE_entity(table); METRIC_DECLARE_entity(tablet); @@ -134,6 +135,7 @@ class RaftConsensusQuorumTest : public YBTest { RETURN_NOT_OK(fs_manager->CreateInitialFileSystemLayout()); RETURN_NOT_OK(fs_manager->CheckAndOpenFileSystemRoots()); + FLAGS_lazily_flush_superblock = false; scoped_refptr log; RETURN_NOT_OK(Log::Open(LogOptions(), kTestTablet, @@ -147,7 +149,8 @@ class RaftConsensusQuorumTest : public YBTest { log_thread_pool_.get(), log_thread_pool_.get(), std::numeric_limits::max(), // cdc_min_replicated_index - &log)); + &log, + nullptr)); logs_.push_back(log.get()); fs_managers_.push_back(fs_manager.release()); } diff --git a/src/yb/tablet/tablet_peer-test.cc b/src/yb/tablet/tablet_peer-test.cc index 92a7f1609f65..00b9604c2ad4 100644 --- a/src/yb/tablet/tablet_peer-test.cc +++ b/src/yb/tablet/tablet_peer-test.cc @@ -185,7 +185,8 @@ class TabletPeerTest : public YBTabletTest { *tablet()->schema(), tablet()->metadata()->schema_version(), table_metric_entity_.get(), tablet_metric_entity_.get(), log_thread_pool_.get(), log_thread_pool_.get(), log_thread_pool_.get(), - tablet()->metadata()->cdc_min_replicated_index(), &log)); + tablet()->metadata()->cdc_min_replicated_index(), &log, + tablet()->metadata())); ASSERT_OK(tablet_peer_->SetBootstrapping()); ASSERT_OK(tablet_peer_->InitTabletPeer(tablet(), diff --git a/src/yb/tserver/remote_bootstrap_session-test.cc b/src/yb/tserver/remote_bootstrap_session-test.cc index 737602641819..a10ea1b0754b 100644 --- a/src/yb/tserver/remote_bootstrap_session-test.cc +++ b/src/yb/tserver/remote_bootstrap_session-test.cc @@ -76,7 +76,8 @@ void RemoteBootstrapSessionTest::SetUpTabletPeer() { log_thread_pool_.get(), log_thread_pool_.get(), std::numeric_limits::max(), // cdc_min_replicated_index - &log)); + &log, + tablet()->metadata())); scoped_refptr table_metric_entity = METRIC_ENTITY_table.Instantiate(&metric_registry_, Format("table-$0", CURRENT_TEST_NAME()));