Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[flash-360] support cyclic rename #137

Merged
merged 142 commits into from
Aug 6, 2019
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
142 commits
Select commit Hold shift + click to select a range
a514e64
Widen schema syncer with sync all semantic, add background schema syn…
zanmato1984 Jun 11, 2019
4a79bb7
Merge branch 'master' into ddl
zanmato1984 Jun 12, 2019
0eafdd4
Finish widen some data types to avoid data rewriting during apply ddl
zanmato1984 Jun 12, 2019
9d69885
Merge branch 'master' into ddl
zanmato1984 Jun 12, 2019
5b648cc
Add update_timestamp into table info
zanmato1984 Jun 17, 2019
647bbbb
Refine read and flush to be more robust for schema change
zanmato1984 Jun 21, 2019
bf25957
Fix nullable for overflow check when decode region cache
zanmato1984 Jun 21, 2019
095ca6c
Add schema state enum
zanmato1984 Jun 23, 2019
dd50f03
Support column type change in schema syncer
zanmato1984 Jun 23, 2019
363ecc7
Fix comment
zanmato1984 Jun 23, 2019
18ed32e
Add mock functions for TiDB DDL
zanmato1984 Jun 23, 2019
402132a
Fix rvalue ref
zanmato1984 Jun 24, 2019
02ad15e
Fix some bugs in schema syncer and mock tidb
zanmato1984 Jun 24, 2019
fb2b960
Adjust test
zanmato1984 Jun 24, 2019
718d1c0
Add alter test
zanmato1984 Jun 24, 2019
463836e
Not do data conversion for alter txn table, as we already stored wide…
zanmato1984 Jun 25, 2019
e86d96a
Fix typo
zanmato1984 Jun 25, 2019
6988bdb
Fix mock tidb reverse type mapping
zanmato1984 Jun 25, 2019
7fb48af
Enhance overflow checking when flushing
zanmato1984 Jun 25, 2019
9ad7a1c
Enhance alter test
zanmato1984 Jun 25, 2019
509ee1c
Refine some code
zanmato1984 Jul 1, 2019
f26a75e
Remove table region mapping when drop table
zanmato1984 Jul 2, 2019
261b3d2
Adjust drop order
zanmato1984 Jul 2, 2019
47d17fc
Print file path in mutable test script when error
zanmato1984 Jul 2, 2019
d409926
Fix insert widen data through sql
zanmato1984 Jul 2, 2019
40379bf
Fix some txn tests
zanmato1984 Jul 2, 2019
ebd897a
Fix widen data write of import statement
zanmato1984 Jul 3, 2019
98d09cf
DDL read and update by tikv's meta (#103)
hanfei1991 Jul 12, 2019
423363a
Add schema version check before reading
zanmato1984 Jul 12, 2019
c6f32a6
Merge branch 'ddl' into ddl-ruoxi
zanmato1984 Jul 12, 2019
d563bdf
Merge master
zanmato1984 Jul 12, 2019
31e84ac
Fix build error
zanmato1984 Jul 12, 2019
0b483b4
Format
zanmato1984 Jul 12, 2019
a888d93
Merge branch 'ddl' into ddl-ruoxi
zanmato1984 Jul 12, 2019
5411052
Reorg schema syncer code
zanmato1984 Jul 15, 2019
45831f6
Add lock control in schema syncer interface
zanmato1984 Jul 15, 2019
745850e
Refinement
zanmato1984 Jul 15, 2019
26b6dd7
Add sync schema on read
zanmato1984 Jul 16, 2019
9314f91
fix bug during creating column: use a wrong db name (#107)
hanfei1991 Jul 16, 2019
d1ac4f4
Simplify schema syncer interface and adjust mock stuff
zanmato1984 Jul 16, 2019
d3e2298
Rename default schema version setting
zanmato1984 Jul 18, 2019
e690046
Compensate last commit
zanmato1984 Jul 18, 2019
149a114
fix ddl sync for table drop and truncate (#109)
hanfei1991 Jul 18, 2019
f942f8a
Add schema sync on read and simplify schema syncer interface and adju…
zanmato1984 Jul 18, 2019
89b849d
Merge master
zanmato1984 Jul 18, 2019
2e67d08
Fix build error
zanmato1984 Jul 18, 2019
ffbdc92
Fix build error
zanmato1984 Jul 18, 2019
2c57e8c
Merge dll branch
zanmato1984 Jul 18, 2019
49b3fdf
Remove curl library
zanmato1984 Jul 18, 2019
b5c2a85
Remove curl from builder image
zanmato1984 Jul 18, 2019
e515c30
Remove useless codes, init schema syncer based on pd config
zanmato1984 Jul 18, 2019
fa38d54
Merge branch 'master' into ddl
zanmato1984 Jul 18, 2019
e084771
Minor fix to schema debug
zanmato1984 Jul 18, 2019
e89c697
Fix alter tmt and pass tests
zanmato1984 Jul 18, 2019
293c880
Merge ddl
zanmato1984 Jul 18, 2019
aa8072a
Merge branch 'ddl' into ddl-ruoxi
zanmato1984 Jul 18, 2019
5623239
Remove useless codes (#112)
zanmato1984 Jul 18, 2019
14bc79b
Merge ddl
zanmato1984 Jul 18, 2019
074f521
Fix build fail
zanmato1984 Jul 18, 2019
a1e9b57
Merge remote
zanmato1984 Jul 18, 2019
76f973d
Fix alter tmt and pass schema tests (#114)
zanmato1984 Jul 19, 2019
448696c
sync default value from tidb to flash (#113)
hanfei1991 Jul 19, 2019
3140836
Add lock for mock schema syncer
zanmato1984 Jul 19, 2019
23ff96c
Fix schema sync service init context
zanmato1984 Jul 19, 2019
fb638a7
Adjust schema tests
zanmato1984 Jul 19, 2019
fc10c2e
Not sync if no schema change detected
zanmato1984 Jul 19, 2019
d3b0af9
Adjust txn mock tests
zanmato1984 Jul 19, 2019
9590357
Merge ddl
zanmato1984 Jul 19, 2019
2237d2e
[DDL] Pass all txn tests (#116)
zanmato1984 Jul 19, 2019
4eb977a
Merge master and format
zanmato1984 Jul 19, 2019
f6c7275
Merge branch 'ddl' into ddl-ruoxi
zanmato1984 Jul 19, 2019
517793b
Fix default value bug
zanmato1984 Jul 19, 2019
0e510f3
Rename some tests
zanmato1984 Jul 19, 2019
4dad596
Fix empty default value bug (#117)
zanmato1984 Jul 19, 2019
32e9f3d
Remove sync schema test
zanmato1984 Jul 19, 2019
bbe3743
Merge branch 'ddl' into ddl-ruoxi
zanmato1984 Jul 19, 2019
c6d4f86
Remove a lot useless code
zanmato1984 Jul 19, 2019
9851e66
Refine schema sync on read, and add drop on read test
zanmato1984 Jul 20, 2019
1a6a1c4
Remove a lot useless code (#118)
zanmato1984 Jul 20, 2019
b001bcc
Merge branch 'ddl' into ddl-ruoxi
zanmato1984 Jul 20, 2019
33fb39d
Refine schema sync on read logic and add test (#120)
zanmato1984 Jul 22, 2019
d29f518
Merge branch 'ddl' into ddl-ruoxi
zanmato1984 Jul 22, 2019
52baefc
add schema_version for TableInfo (#122)
hanfei1991 Jul 22, 2019
72aa0f2
Merge branch 'ddl' into ddl-ruoxi
zanmato1984 Jul 22, 2019
6242a3d
fix bug for drop table; (#123)
hanfei1991 Jul 22, 2019
11f261d
Support rename mock tidb table
zanmato1984 Jul 22, 2019
a689b8a
Add rename tests
zanmato1984 Jul 22, 2019
80ea634
add logs for debug (#126)
hanfei1991 Jul 22, 2019
00bd504
Add mock truncate table and tests
zanmato1984 Jul 22, 2019
4f7c2d9
Test rename table (#124)
zanmato1984 Jul 22, 2019
bc79718
tiny fix (#127)
hanfei1991 Jul 22, 2019
34984cd
Add rename/truncate on read/write test and alter on read test
zanmato1984 Jul 22, 2019
3fcc650
Merge branch 'ddl' into ddl-ruoxi
zanmato1984 Jul 22, 2019
4fe0e7b
Add rename/truncate on read/write test and alter on read test (#128)
zanmato1984 Jul 23, 2019
8e806e6
support for alter column. (#129)
hanfei1991 Jul 23, 2019
027a1c6
Fix mis-widen internal columns
zanmato1984 Jul 23, 2019
21eeb8e
Merge branch 'ddl' into ddl-ruoxi
zanmato1984 Jul 23, 2019
6126544
Merge master
zanmato1984 Jul 23, 2019
af063aa
Support rename table. (#130)
hanfei1991 Jul 23, 2019
19a1abb
Fix fragile txn mock test
zanmato1984 Jul 23, 2019
79b92a5
Merge branch 'ddl' of github.com:pingcap/tics into ddl
zanmato1984 Jul 23, 2019
6f1c6ad
Merge branch 'ddl' into ddl-ruoxi
zanmato1984 Jul 23, 2019
d8b9f0d
Fix mis-widen internal columns (#133)
zanmato1984 Jul 24, 2019
38ea54c
Fix fragile txn mock test again
zanmato1984 Jul 24, 2019
e3caf12
Merge branch 'ddl-ruoxi' into ddl
zanmato1984 Jul 24, 2019
e02344f
Remove useless code
zanmato1984 Jul 24, 2019
f461c16
Resolve a dead lock problem during bootstraping. (#134)
hanfei1991 Jul 24, 2019
22679aa
Fix dead lock in learner read (#135)
zanmato1984 Jul 24, 2019
bb200fa
Adjust order of region check and lock by region scanner creation (#136)
zanmato1984 Jul 24, 2019
5dbae9f
Address comments
zanmato1984 Jul 24, 2019
3a6d5a6
support cyclic rename
hanfei1991 Jul 24, 2019
605acbc
address comment
hanfei1991 Jul 25, 2019
6e19709
[FLASH-358] Support Region DeleteRange (#139)
solotzg Jul 25, 2019
2dbb362
Address comments
zanmato1984 Jul 30, 2019
9628ef4
Merge branch 'master' into ddl
zanmato1984 Jul 30, 2019
0852980
Merge branch 'master' into ddl
zanmato1984 Jul 30, 2019
772b5aa
Merge branch 'ddl' of github.com:pingcap/tics into ddl
zanmato1984 Jul 30, 2019
77b8c33
Fix test config based on new ddl
zanmato1984 Jul 30, 2019
fc04e2a
fix drop db bug
hanfei1991 Jul 30, 2019
795384e
Merge branch 'master' into ddl
zanmato1984 Jul 30, 2019
c8f9570
refine log
hanfei1991 Jul 31, 2019
02219d1
Fix a ignore db config bug and add verbose pd addr
zanmato1984 Jul 31, 2019
0ad4c47
Merge branch 'ddl' of github.com:pingcap/tics into ddl
zanmato1984 Jul 31, 2019
da51a7d
Enlarge pd/kv/db startup waiting time
zanmato1984 Jul 31, 2019
caba195
Merge branch 'master' into ddl
zanmato1984 Jul 31, 2019
d8505b4
Remove useless commands
zanmato1984 Aug 1, 2019
510b409
format client-c
hanfei1991 Aug 1, 2019
f885b95
Merge branch 'ddl' of github.com:pingcap/tics into ddl
zanmato1984 Aug 5, 2019
75d271f
Address comments
zanmato1984 Aug 5, 2019
56b594b
address comments
hanfei1991 Aug 5, 2019
688892f
hot fix
hanfei1991 Aug 5, 2019
573a569
Fix failed test
zanmato1984 Aug 5, 2019
89170bc
Merge branch 'ddl' of github.com:pingcap/tics into ddl
zanmato1984 Aug 5, 2019
274aa5c
Fix mutable tests by using no schema syncer
zanmato1984 Aug 5, 2019
81eb519
Merge branch 'master' into ddl
solotzg Aug 5, 2019
152aeab
fix. optimize background thread pool. (#153)
solotzg Aug 5, 2019
f7a8086
Merge branch 'ddl' into hanfei-ddl/cyclic-rename
hanfei1991 Aug 5, 2019
96c52bf
Merge branch 'ddl' into hanfei-ddl/cyclic-rename
hanfei1991 Aug 5, 2019
9800ba7
Merge branch 'master' into hanfei-ddl/cyclic-rename
hanfei1991 Aug 5, 2019
b3b3539
format
hanfei1991 Aug 5, 2019
d20d9bf
address comments
hanfei1991 Aug 6, 2019
05830a4
Merge branch 'master' into hanfei-ddl/cyclic-rename
hanfei1991 Aug 6, 2019
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
172 changes: 151 additions & 21 deletions dbms/src/Storages/Transaction/SchemaBuilder.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -111,7 +111,7 @@ inline AlterCommands detectSchemaChanges(Logger * log, const TableInfo & table_i
return alter_commands;
}

void SchemaBuilder::applyAlterTableImpl(TiDB::TableInfoPtr table_info, const String & db_name, StorageMergeTree * storage)
void SchemaBuilder::applyAlterTableImpl(TableInfoPtr table_info, const String & db_name, StorageMergeTree * storage)
{
table_info->schema_version = target_version;
auto orig_table_info = storage->getTableInfo();
Expand Down Expand Up @@ -275,9 +275,9 @@ void SchemaBuilder::applyRenameTable(DBInfoPtr db_info, DatabaseID old_db_id, Ta

void SchemaBuilder::applyRenameTableImpl(const String & old_db, const String & new_db, const String & old_table, const String & new_table)
{
LOG_INFO(log, "The " + old_db + "." + old_table + " will be renamed to " + new_db + "." + new_table);
if (old_db == new_db && old_table == new_table)
{
LOG_INFO(log, "The " + old_db + "." + old_table + " has been renamed, nothing needs to do");
return;
}

Expand Down Expand Up @@ -328,10 +328,13 @@ void SchemaBuilder::applyCreateSchemaImpl(TiDB::DBInfoPtr db_info)
void SchemaBuilder::applyDropSchema(DatabaseID schema_id)
{
auto database_name = databases[schema_id];
if (database_name == "")
if (unlikely(database_name == ""))
{
LOG_INFO(
log, "Syncer wants to drop database: " + std::to_string(schema_id) + " . But database is not found, may has been dropped.");
return;
}
LOG_INFO(log, "Try to drop database: " + database_name);
auto drop_query = std::make_shared<ASTDropQuery>();
drop_query->database = database_name;
drop_query->if_exists = true;
Expand Down Expand Up @@ -477,45 +480,172 @@ void SchemaBuilder::applyDropTable(TiDB::DBInfoPtr dbInfo, Int64 table_id)
applyDropTableImpl(database_name, table_info.name);
}

void SchemaBuilder::updateDB(TiDB::DBInfoPtr db_info)
// Drop Invalid Tables in Every DB
void SchemaBuilder::dropInvalidTables(std::vector<std::pair<TableInfoPtr, DBInfoPtr>> table_dbs)
{
auto database_name = databases[db_info->id];
if (database_name == "")
{
applyCreateSchemaImpl(db_info);
}
auto tables = getter.listTables(db_info->id);
auto & tmt_context = context.getTMTContext();

std::set<TableID> table_ids;

for (auto table : tables)
table_ids.insert(table->id);
for (auto table_db : table_dbs)
table_ids.insert(table_db.first->id);

auto & tmt_context = context.getTMTContext();
auto storage_map = tmt_context.getStorages().getAllStorage();
for (auto it = storage_map.begin(); it != storage_map.end(); it++)
{
auto storage = it->second;
if (storage->getDatabaseName() == db_info->name && table_ids.count(storage->getTableInfo().id) == 0)
if (table_ids.count(storage->getTableInfo().id) == 0)
{
// Drop Table
applyDropTableImpl(db_info->name, storage->getTableName());
LOG_DEBUG(log, "Table " + db_info->name + "." + storage->getTableName() + " is dropped during schema all schemas");
const String db_name = storage->getDatabaseName();
applyDropTableImpl(db_name, storage->getTableName());
LOG_DEBUG(log, "Table " + db_name + "." + storage->getTableName() + " is dropped during schema all schemas");
}
}
}

using TableName = std::pair<String, String>;
using TableNamePair = std::pair<TableName, TableName>;
using TableNameMap = std::map<TableName, TableName>;
using TableNameSet = std::set<TableName>;
constexpr char TmpTableNamePrefix[] = "_tiflash_tmp_";

inline TableName generateTmpTable(const TableName & name) { return TableName(name.first, String(TmpTableNamePrefix) + name.second); }

TableNamePair resolveRename(
SchemaBuilder * builder, TableNameMap & map, TableNameMap::iterator it, TableNameSet & visited)
{
TableName target_name = it->second;
TableName origin_name = it->first;
visited.insert(it->first);
auto next_it = map.find(target_name);
if (next_it == map.end())
{
builder->applyRenameTableImpl(origin_name.first, target_name.first, origin_name.second, target_name.second);
map.erase(it);
return TableNamePair();
}
else if (visited.find(target_name) != visited.end())
{
// There is a cycle.
auto tmp_name = generateTmpTable(target_name);
builder->applyRenameTableImpl(target_name.first, tmp_name.first, target_name.second, tmp_name.second);
builder->applyRenameTableImpl(origin_name.first, target_name.first, origin_name.second, target_name.second);
map.erase(it);
return TableNamePair(target_name, tmp_name);
}
else
{
auto pair = resolveRename(builder, map, next_it, visited);
if (pair.first == origin_name)
{
origin_name = pair.second;
}
builder->applyRenameTableImpl(origin_name.first, target_name.first, origin_name.second, target_name.second);
map.erase(it);
return pair;
}
}

void SchemaBuilder::alterAndRenameTables(std::vector<std::pair<TableInfoPtr, DBInfoPtr>> table_dbs)
{
// Rename Table First.
auto & tmt_context = context.getTMTContext();
auto storage_map = tmt_context.getStorages().getAllStorage();
TableNameMap rename_map;
for (auto table_db : table_dbs)
{
auto storage = static_cast<StorageMergeTree *>(tmt_context.getStorages().get(table_db.first->id).get());
if (storage != nullptr)
{
const String old_db = storage->getDatabaseName();
const String old_table = storage->getTableName();
const String new_db = table_db.second->name;
const String new_table = table_db.first->name;
if (old_db != new_db || old_table != new_table)
{
rename_map[TableName(old_db, old_table)] = TableName(new_db, new_table);
}
}
}

while (!rename_map.empty())
{
auto it = rename_map.begin();
TableNameSet visited;
resolveRename(this, rename_map, it, visited);
}

// Then Alter Table
for (auto table_db : table_dbs)
{
auto storage = static_cast<StorageMergeTree *>(tmt_context.getStorages().get(table_db.first->id).get());
if (storage != nullptr)
zanmato1984 marked this conversation as resolved.
Show resolved Hide resolved
{
const String db_name = storage->getDatabaseName();
applyAlterTableImpl(table_db.first, db_name, storage);
}
}
}

for (auto table : tables)
void SchemaBuilder::createTables(std::vector<std::pair<TableInfoPtr, DBInfoPtr>> table_dbs)
{
auto & tmt_context = context.getTMTContext();
for (auto table_db : table_dbs)
{
auto storage = static_cast<StorageMergeTree *>(tmt_context.getStorages().get(table->id).get());
auto storage = static_cast<StorageMergeTree *>(tmt_context.getStorages().get(table_db.first->id).get());
if (storage == nullptr)
{
applyCreateTable(db_info, table->id);
applyCreateTableImpl(*table_db.second, *table_db.first);
}
else
}
}

void SchemaBuilder::syncAllSchema()
{
LOG_DEBUG(log, "try load all schemas.");

std::vector<DBInfoPtr> all_schema = getter.listDBs();

for (auto db_info : all_schema)
{
LOG_DEBUG(log, "Load schema : " + db_info->name);
}

std::set<TiDB::DatabaseID> db_ids;
for (auto db : all_schema)
{
db_ids.insert(db->id);
}

// Drop invalid databases;
for (auto it = databases.begin(); it != databases.end(); it++)
{
if (db_ids.count(it->first) == 0)
{
applyAlterTableImpl(table, db_info->name, storage);
applyDropSchema(it->first);
}
}

// Collect All Table Info and Create DBs.
std::vector<std::pair<TableInfoPtr, DBInfoPtr>> all_tables;
for (auto db : all_schema)
{
auto database_name = databases[db->id];
if (database_name == "")
{
applyCreateSchemaImpl(db);
}
std::vector<TableInfoPtr> tables = getter.listTables(db->id);
for (auto table : tables)
{
all_tables.push_back(std::make_pair(table, db));
}
}

dropInvalidTables(all_tables);
alterAndRenameTables(all_tables);
createTables(all_tables);
}

// end namespace
Expand Down
13 changes: 10 additions & 3 deletions dbms/src/Storages/Transaction/SchemaBuilder.h
Original file line number Diff line number Diff line change
Expand Up @@ -25,10 +25,12 @@ struct SchemaBuilder

void applyDiff(const SchemaDiff & diff);

void updateDB(TiDB::DBInfoPtr db_info);

void applyDropSchema(DatabaseID schema_id);

void syncAllSchema();

void applyRenameTableImpl(const String & old_db, const String & new_db, const String & old_table, const String & new_table);

private:
bool applyCreateSchema(DatabaseID schema_id);

Expand All @@ -54,7 +56,12 @@ struct SchemaBuilder

void applyRenameTable(TiDB::DBInfoPtr db_info, TiDB::DatabaseID old_db_id, TiDB::TableID table_id);

void applyRenameTableImpl(const String & old_db, const String & new_db, const String & old_table, const String & new_table);

void createTables(std::vector<std::pair<TiDB::TableInfoPtr, TiDB::DBInfoPtr>> table_dbs);

void alterAndRenameTables(std::vector<std::pair<TiDB::TableInfoPtr, TiDB::DBInfoPtr>> table_dbs);

void dropInvalidTables(std::vector<std::pair<TiDB::TableInfoPtr, TiDB::DBInfoPtr>> table_dbs);
};

} // namespace DB
44 changes: 15 additions & 29 deletions dbms/src/Storages/Transaction/TiDBSchemaSyncer.h
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,9 @@ struct TiDBSchemaSyncer : public SchemaSyncer
{
return false;
}
LOG_INFO(log, "start to sync schemas. current version is: " + std::to_string(cur_version) + " and try to sync schema version to: " + std::to_string(version));
LOG_INFO(log,
"start to sync schemas. current version is: " + std::to_string(cur_version)
+ " and try to sync schema version to: " + std::to_string(version));
if (!tryLoadSchemaDiffs(getter, version, context))
{
loadAllSchema(getter, version, context);
Expand Down Expand Up @@ -68,41 +70,25 @@ struct TiDBSchemaSyncer : public SchemaSyncer
diffs.push_back(getter.getSchemaDiff(used_version));
}
LOG_DEBUG(log, "end load schema diffs.");
for (const auto & diff : diffs)
try
{
builder.applyDiff(diff);
for (const auto & diff : diffs)
{
builder.applyDiff(diff);
}
}
catch (Exception & e)
{
LOG_ERROR(log, "apply diff meets exception : " + e.displayText());
return false;
}
return true;
}

bool loadAllSchema(SchemaGetter & getter, Int64 version, Context & context)
void loadAllSchema(SchemaGetter & getter, Int64 version, Context & context)
{
LOG_DEBUG(log, "try load all schemas.");

std::vector<TiDB::DBInfoPtr> all_schema = getter.listDBs();

for (auto db_info : all_schema)
{
LOG_DEBUG(log, "Load schema : " + db_info->name);
}

SchemaBuilder builder(getter, context, databases, version);

std::set<TiDB::DatabaseID> db_ids;
for (auto db : all_schema)
{
builder.updateDB(db);
db_ids.insert(db->id);
}
// Drop databases;
for (auto it = databases.begin(); it != databases.end(); it++)
{
if (db_ids.count(it->first) == 0)
{
builder.applyDropSchema(it->first);
}
}
return true;
builder.syncAllSchema();
}
};

Expand Down