dataroaring commented on code in PR #50343:
URL: https://github.com/apache/doris/pull/50343#discussion_r2060196231
##########
be/src/olap/task/engine_publish_version_task.cpp:
##########
@@ -396,6 +396,49 @@ TabletPublishTxnTask::TabletPublishTxnTask(StorageEngine&
engine,
TabletPublishTxnTask::~TabletPublishTxnTask() = default;
+Status publish_version_and_add_rowset(StorageEngine& engine, int64_t
partition_id,
+ const TabletSharedPtr& tablet, const
RowsetSharedPtr& rowset,
+ int64_t transaction_id, const Version&
version,
+ EnginePublishVersionTask*
engine_publish_version_task,
+ TabletPublishStatistics& stats) {
+ // ATTN: Here, the life cycle needs to be extended to prevent
tablet_txn_info.pending_rs_guard in txn
+ // from being released prematurely, causing path gc to mistakenly delete
the dat file
+ std::shared_ptr<TabletTxnInfo> extend_tablet_txn_info_lifetime = nullptr;
+
+ // Publish the transaction
+ auto result = engine.txn_manager()->publish_txn(partition_id, tablet,
transaction_id, version,
+ &stats,
extend_tablet_txn_info_lifetime);
+ if (!result.ok()) {
+ LOG(WARNING) << "failed to publish version. rowset_id=" <<
rowset->rowset_id()
+ << ", tablet_id=" << tablet->tablet_id() << ", txn_id="
<< transaction_id
+ << ", res=" << result;
+ if (engine_publish_version_task) {
+
engine_publish_version_task->add_error_tablet_id(tablet->tablet_id());
+ }
+ return result;
+ }
+
+ DBUG_EXECUTE_IF("EnginePublishVersionTask.handle.block_add_rowsets",
DBUG_BLOCK);
+
+ // Add visible rowset to tablet
+ int64_t start_time = MonotonicMicros();
+ result = tablet->add_inc_rowset(rowset);
+
DBUG_EXECUTE_IF("EnginePublishVersionTask.handle.after_add_inc_rowset_rowsets_block",
+ DBUG_BLOCK);
+ stats.add_inc_rowset_us = MonotonicMicros() - start_time;
+ if (!result.ok() && !result.is<PUSH_VERSION_ALREADY_EXIST>()) {
+ LOG(WARNING) << "fail to add visible rowset to tablet. rowset_id=" <<
rowset->rowset_id()
+ << ", tablet_id=" << tablet->tablet_id() << ", txn_id="
<< transaction_id
+ << ", res=" << result;
+ if (engine_publish_version_task) {
+
engine_publish_version_task->add_error_tablet_id(tablet->tablet_id());
+ }
+ return result;
Review Comment:
useless.
--
This is an automated message from the Apache Git Service.
To respond to the message, please log on to GitHub and use the
URL above to go to the specific comment.
To unsubscribe, e-mail: [email protected]
For queries about this service, please contact Infrastructure at:
[email protected]
---------------------------------------------------------------------
To unsubscribe, e-mail: [email protected]
For additional commands, e-mail: [email protected]