diff --git a/fe/fe-common/src/main/java/org/apache/doris/common/Config.java b/fe/fe-common/src/main/java/org/apache/doris/common/Config.java index afa39be2f06635..437be27a8aa7a2 100644 --- a/fe/fe-common/src/main/java/org/apache/doris/common/Config.java +++ b/fe/fe-common/src/main/java/org/apache/doris/common/Config.java @@ -2190,6 +2190,11 @@ public class Config extends ConfigBase { "Whether to enable binlog feature"}) public static boolean enable_feature_binlog = false; + @ConfField(mutable = false, description = { + "是否默认为 Database/Table 启用binlog特性", + "Whether to enable binlog feature for Database/Table by default"}) + public static boolean force_enable_feature_binlog = false; + @ConfField(mutable = false, masterOnly = false, expType = ExperimentalType.EXPERIMENTAL, description = { "设置 binlog 消息最字节长度", "Set the maximum byte length of binlog message"}) diff --git a/fe/fe-core/src/main/java/org/apache/doris/analysis/CreateDbStmt.java b/fe/fe-core/src/main/java/org/apache/doris/analysis/CreateDbStmt.java index fa52da40c5daaf..aabe08a5a33db8 100644 --- a/fe/fe-core/src/main/java/org/apache/doris/analysis/CreateDbStmt.java +++ b/fe/fe-core/src/main/java/org/apache/doris/analysis/CreateDbStmt.java @@ -19,12 +19,14 @@ import org.apache.doris.catalog.Env; import org.apache.doris.cluster.ClusterNamespace; +import org.apache.doris.common.Config; import org.apache.doris.common.ErrorCode; import org.apache.doris.common.ErrorReport; import org.apache.doris.common.FeNameFormat; import org.apache.doris.common.UserException; import org.apache.doris.common.util.InternalDatabaseUtil; import org.apache.doris.common.util.PrintableMap; +import org.apache.doris.common.util.PropertyAnalyzer; import org.apache.doris.mysql.privilege.PrivPredicate; import org.apache.doris.qe.ConnectContext; @@ -42,6 +44,11 @@ public CreateDbStmt(boolean ifNotExists, String dbName, Map prop this.ifNotExists = ifNotExists; this.dbName = dbName; this.properties = properties == null ? new HashMap<>() : properties; + + if (Config.force_enable_feature_binlog + && !this.properties.containsKey(PropertyAnalyzer.PROPERTIES_BINLOG_ENABLE)) { + this.properties.put(PropertyAnalyzer.PROPERTIES_BINLOG_ENABLE, "true"); + } } public String getFullDbName() { diff --git a/fe/fe-core/src/main/java/org/apache/doris/catalog/Database.java b/fe/fe-core/src/main/java/org/apache/doris/catalog/Database.java index 816fd0217843ae..b218109383230d 100644 --- a/fe/fe-core/src/main/java/org/apache/doris/catalog/Database.java +++ b/fe/fe-core/src/main/java/org/apache/doris/catalog/Database.java @@ -282,6 +282,9 @@ public DatabaseProperty getDbProperties() { public void setDbProperties(DatabaseProperty dbProperties) { this.dbProperties = dbProperties; + if (PropertyAnalyzer.hasBinlogConfig(dbProperties.getProperties())) { + binlogConfig = dbProperties.getBinlogConfig(); + } } public long getUsedDataQuotaWithLock() {