From d66a15fe3597b7960d974ff02c07c0af9c4a765d Mon Sep 17 00:00:00 2001 From: lulu2panpan Date: Sat, 25 May 2024 22:05:06 +0800 Subject: [PATCH] migrate sql parser from druid to polardbx-parser (#5097) * migrate parser from druid to polardbx-parser * migrate parser from druid to polardbx-parser(with version 5.4.19) * fix bug : full ddl sqls should not assign to extra field but data field * fix bug : full ddl sqls should not assign to extra field but data field --------- Co-authored-by: agapple --- common/pom.xml | 5 ++ .../otter/canal/common/utils/CommonUtils.java | 6 ++ parse/pom.xml | 4 +- .../inbound/mysql/dbsync/TableMetaCache.java | 2 +- .../inbound/mysql/ddl/DruidDdlParser.java | 63 +++++++++---------- .../inbound/mysql/tsdb/DatabaseTableMeta.java | 11 ++-- .../inbound/mysql/tsdb/MemoryTableMeta.java | 50 +++++++++------ .../parse/support/AuthenticationInfo.java | 4 +- .../inbound/mysql/tsdb/FastsqlSchemaTest.java | 16 ++--- .../mysql/tsdb/MemoryTableMeta_DDL_Test.java | 5 +- .../tsdb/MemoryTableMeta_Random_DDL_Test.java | 2 +- pom.xml | 5 ++ 12 files changed, 99 insertions(+), 74 deletions(-) diff --git a/common/pom.xml b/common/pom.xml index e3f5f96424..899977d07c 100644 --- a/common/pom.xml +++ b/common/pom.xml @@ -87,6 +87,11 @@ com.google.code.findbugs jsr305 + + com.alibaba + druid + true + org.springframework spring-test diff --git a/common/src/main/java/com/alibaba/otter/canal/common/utils/CommonUtils.java b/common/src/main/java/com/alibaba/otter/canal/common/utils/CommonUtils.java index 52b9621a7c..efb74a32c1 100644 --- a/common/src/main/java/com/alibaba/otter/canal/common/utils/CommonUtils.java +++ b/common/src/main/java/com/alibaba/otter/canal/common/utils/CommonUtils.java @@ -1,5 +1,7 @@ package com.alibaba.otter.canal.common.utils; +import com.alibaba.druid.filter.config.ConfigTools; + import java.io.File; /** @@ -50,4 +52,8 @@ public static boolean deleteDir(File dirFile) { return dirFile.delete(); } + + public static String decryptDruidPassword(String publicKeyText, String cipherText) throws Exception { + return ConfigTools.decrypt(publicKeyText, cipherText); + } } diff --git a/parse/pom.xml b/parse/pom.xml index 9ea05d5c7a..1cab43c202 100644 --- a/parse/pom.xml +++ b/parse/pom.xml @@ -46,8 +46,8 @@ ${project.version} - com.alibaba - druid + com.alibaba.polardbx + polardbx-parser mysql diff --git a/parse/src/main/java/com/alibaba/otter/canal/parse/inbound/mysql/dbsync/TableMetaCache.java b/parse/src/main/java/com/alibaba/otter/canal/parse/inbound/mysql/dbsync/TableMetaCache.java index a7409b999b..f2cd0a645d 100644 --- a/parse/src/main/java/com/alibaba/otter/canal/parse/inbound/mysql/dbsync/TableMetaCache.java +++ b/parse/src/main/java/com/alibaba/otter/canal/parse/inbound/mysql/dbsync/TableMetaCache.java @@ -258,7 +258,7 @@ private String getFullName(String schema, String table) { .append('`') .append('.') .append('`') - .append(table) + .append(StringUtils.replace(table,"`","``")) .append('`') .toString(); } diff --git a/parse/src/main/java/com/alibaba/otter/canal/parse/inbound/mysql/ddl/DruidDdlParser.java b/parse/src/main/java/com/alibaba/otter/canal/parse/inbound/mysql/ddl/DruidDdlParser.java index 2ca626879a..ec0eae29cc 100644 --- a/parse/src/main/java/com/alibaba/otter/canal/parse/inbound/mysql/ddl/DruidDdlParser.java +++ b/parse/src/main/java/com/alibaba/otter/canal/parse/inbound/mysql/ddl/DruidDdlParser.java @@ -4,39 +4,38 @@ import java.util.Arrays; import java.util.List; +import com.alibaba.polardbx.druid.sql.SQLUtils; +import com.alibaba.polardbx.druid.sql.ast.SQLExpr; +import com.alibaba.polardbx.druid.sql.ast.SQLStatement; +import com.alibaba.polardbx.druid.sql.ast.expr.SQLIdentifierExpr; +import com.alibaba.polardbx.druid.sql.ast.expr.SQLPropertyExpr; +import com.alibaba.polardbx.druid.sql.ast.statement.SQLAlterTableAddConstraint; +import com.alibaba.polardbx.druid.sql.ast.statement.SQLAlterTableAddIndex; +import com.alibaba.polardbx.druid.sql.ast.statement.SQLAlterTableDropConstraint; +import com.alibaba.polardbx.druid.sql.ast.statement.SQLAlterTableDropIndex; +import com.alibaba.polardbx.druid.sql.ast.statement.SQLAlterTableDropKey; +import com.alibaba.polardbx.druid.sql.ast.statement.SQLAlterTableItem; +import com.alibaba.polardbx.druid.sql.ast.statement.SQLAlterTableRename; +import com.alibaba.polardbx.druid.sql.ast.statement.SQLAlterTableStatement; +import com.alibaba.polardbx.druid.sql.ast.statement.SQLConstraint; +import com.alibaba.polardbx.druid.sql.ast.statement.SQLCreateDatabaseStatement; +import com.alibaba.polardbx.druid.sql.ast.statement.SQLCreateIndexStatement; +import com.alibaba.polardbx.druid.sql.ast.statement.SQLCreateTableStatement; +import com.alibaba.polardbx.druid.sql.ast.statement.SQLDeleteStatement; +import com.alibaba.polardbx.druid.sql.ast.statement.SQLDropDatabaseStatement; +import com.alibaba.polardbx.druid.sql.ast.statement.SQLDropIndexStatement; +import com.alibaba.polardbx.druid.sql.ast.statement.SQLDropTableStatement; +import com.alibaba.polardbx.druid.sql.ast.statement.SQLExprTableSource; +import com.alibaba.polardbx.druid.sql.ast.statement.SQLInsertStatement; +import com.alibaba.polardbx.druid.sql.ast.statement.SQLTableSource; +import com.alibaba.polardbx.druid.sql.ast.statement.SQLTruncateStatement; +import com.alibaba.polardbx.druid.sql.ast.statement.SQLUnique; +import com.alibaba.polardbx.druid.sql.ast.statement.SQLUpdateStatement; +import com.alibaba.polardbx.druid.sql.dialect.mysql.ast.statement.MySqlRenameTableStatement; +import com.alibaba.polardbx.druid.sql.parser.ParserException; +import com.alibaba.polardbx.druid.util.JdbcConstants; import org.apache.commons.lang.StringUtils; -import com.alibaba.druid.sql.SQLUtils; -import com.alibaba.druid.sql.ast.SQLExpr; -import com.alibaba.druid.sql.ast.SQLStatement; -import com.alibaba.druid.sql.ast.expr.SQLIdentifierExpr; -import com.alibaba.druid.sql.ast.expr.SQLPropertyExpr; -import com.alibaba.druid.sql.ast.statement.SQLAlterTableAddConstraint; -import com.alibaba.druid.sql.ast.statement.SQLAlterTableAddIndex; -import com.alibaba.druid.sql.ast.statement.SQLAlterTableDropConstraint; -import com.alibaba.druid.sql.ast.statement.SQLAlterTableDropIndex; -import com.alibaba.druid.sql.ast.statement.SQLAlterTableDropKey; -import com.alibaba.druid.sql.ast.statement.SQLAlterTableItem; -import com.alibaba.druid.sql.ast.statement.SQLAlterTableRename; -import com.alibaba.druid.sql.ast.statement.SQLAlterTableStatement; -import com.alibaba.druid.sql.ast.statement.SQLConstraint; -import com.alibaba.druid.sql.ast.statement.SQLCreateDatabaseStatement; -import com.alibaba.druid.sql.ast.statement.SQLCreateIndexStatement; -import com.alibaba.druid.sql.ast.statement.SQLCreateTableStatement; -import com.alibaba.druid.sql.ast.statement.SQLDeleteStatement; -import com.alibaba.druid.sql.ast.statement.SQLDropDatabaseStatement; -import com.alibaba.druid.sql.ast.statement.SQLDropIndexStatement; -import com.alibaba.druid.sql.ast.statement.SQLDropTableStatement; -import com.alibaba.druid.sql.ast.statement.SQLExprTableSource; -import com.alibaba.druid.sql.ast.statement.SQLInsertStatement; -import com.alibaba.druid.sql.ast.statement.SQLTableSource; -import com.alibaba.druid.sql.ast.statement.SQLTruncateStatement; -import com.alibaba.druid.sql.ast.statement.SQLUnique; -import com.alibaba.druid.sql.ast.statement.SQLUpdateStatement; -import com.alibaba.druid.sql.dialect.mysql.ast.statement.MySqlRenameTableStatement; -import com.alibaba.druid.sql.dialect.mysql.ast.statement.MySqlRenameTableStatement.Item; -import com.alibaba.druid.sql.parser.ParserException; -import com.alibaba.druid.util.JdbcConstants; import com.alibaba.otter.canal.protocol.CanalEntry.EventType; /** @@ -141,7 +140,7 @@ public static List parse(String queryString, String schmeaName) { } } else if (statement instanceof MySqlRenameTableStatement) { MySqlRenameTableStatement rename = (MySqlRenameTableStatement) statement; - for (Item item : rename.getItems()) { + for (MySqlRenameTableStatement.Item item : rename.getItems()) { DdlResult ddlResult = new DdlResult(); processName(ddlResult, schmeaName, item.getName(), true); processName(ddlResult, schmeaName, item.getTo(), false); diff --git a/parse/src/main/java/com/alibaba/otter/canal/parse/inbound/mysql/tsdb/DatabaseTableMeta.java b/parse/src/main/java/com/alibaba/otter/canal/parse/inbound/mysql/tsdb/DatabaseTableMeta.java index 71d0be5a07..beab52d8fc 100644 --- a/parse/src/main/java/com/alibaba/otter/canal/parse/inbound/mysql/tsdb/DatabaseTableMeta.java +++ b/parse/src/main/java/com/alibaba/otter/canal/parse/inbound/mysql/tsdb/DatabaseTableMeta.java @@ -13,14 +13,15 @@ import java.util.concurrent.locks.ReadWriteLock; import java.util.concurrent.locks.ReentrantReadWriteLock; import java.util.regex.Pattern; - +import com.alibaba.otter.canal.parse.driver.mysql.packets.server.FieldPacket; +import com.alibaba.polardbx.druid.sql.repository.Schema; +import org.apache.commons.beanutils.BeanUtils; import org.apache.commons.lang.ObjectUtils; import org.apache.commons.lang.StringUtils; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.slf4j.MDC; -import com.alibaba.druid.sql.repository.Schema; import com.alibaba.fastjson2.JSON; import com.alibaba.fastjson2.JSONObject; import com.alibaba.otter.canal.filter.CanalEventFilter; @@ -227,7 +228,7 @@ private boolean dumpTableMeta(MysqlConnection connection, final CanalEventFilter StringBuilder sql = new StringBuilder(); for (String table : tables) { - sql.append("show create table `" + schema + "`.`" + table + "`;"); + sql.append("show create table `" + schema + "`.`" + StringUtils.replace(table,"`","``") + "`;"); } List packets = connection.queryMulti(sql.toString()); @@ -363,7 +364,7 @@ private boolean applySnapshotToDB(EntryPosition position, boolean init) { snapshotDO.setBinlogOffest(position.getPosition()); snapshotDO.setBinlogMasterId(String.valueOf(position.getServerId())); snapshotDO.setBinlogTimestamp(position.getTimestamp()); - snapshotDO.setExtra(JSON.toJSONString(schemaDdls)); + snapshotDO.setData(JSON.toJSONString(schemaDdls)); try { metaSnapshotDAO.insert(snapshotDO); } catch (Throwable e) { @@ -508,7 +509,7 @@ private String structureSchema(String schema) { private String getFullName(String schema, String table) { StringBuilder builder = new StringBuilder(); - return builder.append(structureSchema(schema)).append('.').append('`').append(table).append('`').toString(); + return builder.append(structureSchema(schema)).append('.').append('`').append(StringUtils.replace(table,"`","``")).append('`').toString(); } public static boolean compareTableMeta(TableMeta source, TableMeta target) { diff --git a/parse/src/main/java/com/alibaba/otter/canal/parse/inbound/mysql/tsdb/MemoryTableMeta.java b/parse/src/main/java/com/alibaba/otter/canal/parse/inbound/mysql/tsdb/MemoryTableMeta.java index 189e099a42..c40f4a73f5 100644 --- a/parse/src/main/java/com/alibaba/otter/canal/parse/inbound/mysql/tsdb/MemoryTableMeta.java +++ b/parse/src/main/java/com/alibaba/otter/canal/parse/inbound/mysql/tsdb/MemoryTableMeta.java @@ -3,27 +3,38 @@ import java.util.*; import java.util.concurrent.ConcurrentHashMap; +import com.alibaba.polardbx.druid.DbType; +import com.alibaba.polardbx.druid.sql.SQLUtils; +import com.alibaba.polardbx.druid.sql.ast.SQLDataType; +import com.alibaba.polardbx.druid.sql.ast.SQLDataTypeImpl; +import com.alibaba.polardbx.druid.sql.ast.SQLExpr; +import com.alibaba.polardbx.druid.sql.ast.SQLStatement; +import com.alibaba.polardbx.druid.sql.ast.expr.SQLCharExpr; +import com.alibaba.polardbx.druid.sql.ast.expr.SQLIdentifierExpr; +import com.alibaba.polardbx.druid.sql.ast.expr.SQLMethodInvokeExpr; +import com.alibaba.polardbx.druid.sql.ast.expr.SQLNullExpr; +import com.alibaba.polardbx.druid.sql.ast.expr.SQLPropertyExpr; +import com.alibaba.polardbx.druid.sql.ast.statement.SQLColumnConstraint; +import com.alibaba.polardbx.druid.sql.ast.statement.SQLColumnDefinition; +import com.alibaba.polardbx.druid.sql.ast.statement.SQLColumnPrimaryKey; +import com.alibaba.polardbx.druid.sql.ast.statement.SQLColumnUniqueKey; +import com.alibaba.polardbx.druid.sql.ast.statement.SQLCreateTableStatement; +import com.alibaba.polardbx.druid.sql.ast.statement.SQLNotNullConstraint; +import com.alibaba.polardbx.druid.sql.ast.statement.SQLNullConstraint; +import com.alibaba.polardbx.druid.sql.ast.statement.SQLSelectOrderByItem; +import com.alibaba.polardbx.druid.sql.ast.statement.SQLTableElement; +import com.alibaba.polardbx.druid.sql.dialect.mysql.ast.MySqlPrimaryKey; +import com.alibaba.polardbx.druid.sql.dialect.mysql.ast.MySqlUnique; +import com.alibaba.polardbx.druid.sql.dialect.mysql.ast.expr.MySqlOrderingExpr; +import com.alibaba.polardbx.druid.sql.repository.Schema; +import com.alibaba.polardbx.druid.sql.repository.SchemaObject; +import com.alibaba.polardbx.druid.sql.repository.SchemaRepository; +import com.alibaba.polardbx.druid.sql.visitor.SQLASTOutputVisitor; +import com.alibaba.polardbx.druid.sql.visitor.VisitorFeature; +import com.alibaba.polardbx.druid.util.JdbcConstants; import org.apache.commons.lang.StringUtils; import org.slf4j.Logger; import org.slf4j.LoggerFactory; - -import com.alibaba.druid.DbType; -import com.alibaba.druid.sql.SQLUtils; -import com.alibaba.druid.sql.ast.SQLDataType; -import com.alibaba.druid.sql.ast.SQLDataTypeImpl; -import com.alibaba.druid.sql.ast.SQLExpr; -import com.alibaba.druid.sql.ast.SQLStatement; -import com.alibaba.druid.sql.ast.expr.*; -import com.alibaba.druid.sql.ast.statement.*; -import com.alibaba.druid.sql.dialect.mysql.ast.MySqlPrimaryKey; -import com.alibaba.druid.sql.dialect.mysql.ast.MySqlUnique; -import com.alibaba.druid.sql.dialect.mysql.ast.expr.MySqlOrderingExpr; -import com.alibaba.druid.sql.repository.Schema; -import com.alibaba.druid.sql.repository.SchemaObject; -import com.alibaba.druid.sql.repository.SchemaRepository; -import com.alibaba.druid.sql.visitor.SQLASTOutputVisitor; -import com.alibaba.druid.sql.visitor.VisitorFeature; -import com.alibaba.druid.util.JdbcConstants; import com.alibaba.otter.canal.parse.inbound.TableMeta; import com.alibaba.otter.canal.parse.inbound.TableMeta.FieldMeta; import com.alibaba.otter.canal.parse.inbound.mysql.ddl.DruidDdlParser; @@ -39,9 +50,10 @@ public class MemoryTableMeta implements TableMetaTSDB { private Logger logger = LoggerFactory.getLogger(MemoryTableMeta.class); private Map, TableMeta> tableMetas = new ConcurrentHashMap<>(); - private SchemaRepository repository = new SchemaRepository(JdbcConstants.MYSQL); + private SchemaRepository repository; public MemoryTableMeta(){ + repository = new SchemaRepository(JdbcConstants.MYSQL); } @Override diff --git a/parse/src/main/java/com/alibaba/otter/canal/parse/support/AuthenticationInfo.java b/parse/src/main/java/com/alibaba/otter/canal/parse/support/AuthenticationInfo.java index 6b12ef0dc1..00d3521e69 100644 --- a/parse/src/main/java/com/alibaba/otter/canal/parse/support/AuthenticationInfo.java +++ b/parse/src/main/java/com/alibaba/otter/canal/parse/support/AuthenticationInfo.java @@ -2,7 +2,7 @@ import java.net.InetSocketAddress; -import com.alibaba.druid.filter.config.ConfigTools; +import com.alibaba.otter.canal.common.utils.CommonUtils; import org.apache.commons.lang.builder.ToStringBuilder; import org.apache.commons.lang.builder.ToStringStyle; @@ -25,7 +25,7 @@ public class AuthenticationInfo { public void initPwd() throws Exception{ if (enableDruid) { - this.password = ConfigTools.decrypt(pwdPublicKey, password); + this.password = CommonUtils.decryptDruidPassword(pwdPublicKey, password); } } diff --git a/parse/src/test/java/com/alibaba/otter/canal/parse/inbound/mysql/tsdb/FastsqlSchemaTest.java b/parse/src/test/java/com/alibaba/otter/canal/parse/inbound/mysql/tsdb/FastsqlSchemaTest.java index cb5569385e..92fb0182f2 100644 --- a/parse/src/test/java/com/alibaba/otter/canal/parse/inbound/mysql/tsdb/FastsqlSchemaTest.java +++ b/parse/src/test/java/com/alibaba/otter/canal/parse/inbound/mysql/tsdb/FastsqlSchemaTest.java @@ -3,14 +3,14 @@ import org.junit.Assert; import org.junit.Test; -import com.alibaba.druid.DbType; -import com.alibaba.druid.sql.SQLUtils; -import com.alibaba.druid.sql.repository.Schema; -import com.alibaba.druid.sql.repository.SchemaObject; -import com.alibaba.druid.sql.repository.SchemaRepository; -import com.alibaba.druid.sql.visitor.SQLASTOutputVisitor; -import com.alibaba.druid.sql.visitor.VisitorFeature; -import com.alibaba.druid.util.JdbcConstants; +import com.alibaba.polardbx.druid.DbType; +import com.alibaba.polardbx.druid.sql.SQLUtils; +import com.alibaba.polardbx.druid.sql.repository.Schema; +import com.alibaba.polardbx.druid.sql.repository.SchemaObject; +import com.alibaba.polardbx.druid.sql.repository.SchemaRepository; +import com.alibaba.polardbx.druid.sql.visitor.SQLASTOutputVisitor; +import com.alibaba.polardbx.druid.sql.visitor.VisitorFeature; +import com.alibaba.polardbx.druid.util.JdbcConstants; public class FastsqlSchemaTest { diff --git a/parse/src/test/java/com/alibaba/otter/canal/parse/inbound/mysql/tsdb/MemoryTableMeta_DDL_Test.java b/parse/src/test/java/com/alibaba/otter/canal/parse/inbound/mysql/tsdb/MemoryTableMeta_DDL_Test.java index baec415f44..050d4742a5 100644 --- a/parse/src/test/java/com/alibaba/otter/canal/parse/inbound/mysql/tsdb/MemoryTableMeta_DDL_Test.java +++ b/parse/src/test/java/com/alibaba/otter/canal/parse/inbound/mysql/tsdb/MemoryTableMeta_DDL_Test.java @@ -6,9 +6,6 @@ import java.util.ArrayList; import java.util.List; -import com.alibaba.druid.sql.repository.SchemaObject; -import com.alibaba.druid.sql.repository.SchemaRepository; -import com.alibaba.druid.util.JdbcConstants; import org.apache.commons.io.IOUtils; import org.apache.commons.lang.StringUtils; import org.junit.Assert; @@ -17,7 +14,7 @@ import org.springframework.test.context.ContextConfiguration; import org.springframework.test.context.junit4.SpringJUnit4ClassRunner; -import com.alibaba.druid.sql.repository.Schema; +import com.alibaba.polardbx.druid.sql.repository.Schema; import com.alibaba.otter.canal.parse.inbound.TableMeta; /** diff --git a/parse/src/test/java/com/alibaba/otter/canal/parse/inbound/mysql/tsdb/MemoryTableMeta_Random_DDL_Test.java b/parse/src/test/java/com/alibaba/otter/canal/parse/inbound/mysql/tsdb/MemoryTableMeta_Random_DDL_Test.java index f11eb27b54..2162f49c39 100644 --- a/parse/src/test/java/com/alibaba/otter/canal/parse/inbound/mysql/tsdb/MemoryTableMeta_Random_DDL_Test.java +++ b/parse/src/test/java/com/alibaba/otter/canal/parse/inbound/mysql/tsdb/MemoryTableMeta_Random_DDL_Test.java @@ -14,7 +14,7 @@ import org.springframework.test.context.ContextConfiguration; import org.springframework.test.context.junit4.SpringJUnit4ClassRunner; -import com.alibaba.druid.sql.repository.Schema; +import com.alibaba.polardbx.druid.sql.repository.Schema; import com.alibaba.otter.canal.parse.inbound.TableMeta; /** diff --git a/pom.xml b/pom.xml index 825246fae9..1940e88739 100644 --- a/pom.xml +++ b/pom.xml @@ -389,6 +389,11 @@ log4j-to-slf4j ${log4j_version} + + com.alibaba.polardbx + polardbx-parser + 5.4.19 +