This is an automated email from the ASF dual-hosted git repository.
w41ter pushed a commit to branch branch-2.1
in repository https://gitbox.apache.org/repos/asf/doris.git
The following commit(s) were added to refs/heads/branch-2.1 by this push:
new 031ee992e71 [feature](binlog) Allow BarrierLog to wrap another binlog
#42993 (#43485)
031ee992e71 is described below
commit 031ee992e717faaa7e58dc76acb4e7588a846d59
Author: walter <[email protected]>
AuthorDate: Fri Nov 8 14:04:54 2024 +0800
[feature](binlog) Allow BarrierLog to wrap another binlog #42993 (#43485)
cherry pick from #42993
---
.../java/org/apache/doris/persist/BarrierLog.java | 28 ++++++++++++++++++++++
1 file changed, 28 insertions(+)
diff --git a/fe/fe-core/src/main/java/org/apache/doris/persist/BarrierLog.java
b/fe/fe-core/src/main/java/org/apache/doris/persist/BarrierLog.java
index ea849d217d7..2b4245b290c 100644
--- a/fe/fe-core/src/main/java/org/apache/doris/persist/BarrierLog.java
+++ b/fe/fe-core/src/main/java/org/apache/doris/persist/BarrierLog.java
@@ -20,6 +20,7 @@ package org.apache.doris.persist;
import org.apache.doris.common.io.Text;
import org.apache.doris.common.io.Writable;
import org.apache.doris.persist.gson.GsonUtils;
+import org.apache.doris.thrift.TBinlogType;
import com.google.gson.annotations.SerializedName;
@@ -37,6 +38,11 @@ public class BarrierLog implements Writable {
@SerializedName(value = "tableName")
String tableName;
+ @SerializedName(value = "binlogType")
+ int binlogType;
+ @SerializedName(value = "binlog")
+ String binlog;
+
public BarrierLog() {
}
@@ -47,6 +53,28 @@ public class BarrierLog implements Writable {
this.tableName = tableName;
}
+ // A trick: Wrap the binlog as part of the BarrierLog so that it can work
in
+ // the old Doris version without breaking the compatibility.
+ public BarrierLog(long dbId, long tableId, TBinlogType binlogType, String
binlog) {
+ this.dbId = dbId;
+ this.tableId = tableId;
+ this.binlogType = binlogType.getValue();
+ this.binlog = binlog;
+ }
+
+ public boolean hasBinlog() {
+ return binlog != null;
+ }
+
+ public String getBinlog() {
+ return binlog;
+ }
+
+ // null is returned if binlog is not set or binlogType is not recognized.
+ public TBinlogType getBinlogType() {
+ return binlog == null ? null : TBinlogType.findByValue(binlogType);
+ }
+
public long getDbId() {
return dbId;
}
---------------------------------------------------------------------
To unsubscribe, e-mail: [email protected]
For additional commands, e-mail: [email protected]