Skip to content

Commit

Permalink
[BugFix] Fix several problem for logical view restore (backport #52291)…
Browse files Browse the repository at this point in the history
… (#52440)

Signed-off-by: srlch <[email protected]>
  • Loading branch information
srlch authored Oct 30, 2024
1 parent a670faa commit de7ec77
Show file tree
Hide file tree
Showing 4 changed files with 43 additions and 60 deletions.
8 changes: 3 additions & 5 deletions fe/fe-core/src/main/java/com/starrocks/backup/BackupJob.java
Original file line number Diff line number Diff line change
Expand Up @@ -707,11 +707,9 @@ private void saveMetaInfo() {
localMetaInfoFilePath = metaInfoFile.getAbsolutePath();

// 3. save job info file
// save table info into BackupJobInfo only for OlapTable or MV
List<Table> olapTbls = backupMeta.getTables().values().stream()
.filter(Table::isOlapTableOrMaterializedView).collect(Collectors.toList());
jobInfo = BackupJobInfo.fromCatalog(createTime, label, dbName, dbId, olapTbls, snapshotInfos);
LOG.warn("job info: {}. {}", jobInfo, this);
jobInfo = BackupJobInfo.fromCatalog(createTime, label, dbName, dbId, backupMeta.getTables().values(),
snapshotInfos);
LOG.debug("job info: {}. {}", jobInfo, this);
File jobInfoFile = new File(jobDir, Repository.PREFIX_JOB_INFO + createTimeStr);
if (!jobInfoFile.createNewFile()) {
status = new Status(ErrCode.COMMON_ERROR, "Failed to create job info file: " + jobInfoFile.toString());
Expand Down
12 changes: 11 additions & 1 deletion fe/fe-core/src/main/java/com/starrocks/backup/BackupJobInfo.java
Original file line number Diff line number Diff line change
Expand Up @@ -304,11 +304,16 @@ public static BackupJobInfo fromCatalog(long backupTime, String label, String db

// tbls
for (Table tbl : tbls) {
OlapTable olapTbl = (OlapTable) tbl;
BackupTableInfo tableInfo = new BackupTableInfo();
tableInfo.id = tbl.getId();
tableInfo.name = tbl.getName();
jobInfo.tables.put(tableInfo.name, tableInfo);

if (tbl.isOlapView()) {
continue;
}

OlapTable olapTbl = (OlapTable) tbl;
// partitions
for (Partition partition : olapTbl.getPartitions()) {
BackupPartitionInfo partitionInfo = new BackupPartitionInfo();
Expand Down Expand Up @@ -451,6 +456,11 @@ private static void genFromJson(String json, BackupJobInfo jobInfo) {
}
JSONObject parts = tbl.getJSONObject("partitions");
String[] partsNames = JSONObject.getNames(parts);
if (partsNames == null) {
// skip logical view
jobInfo.tables.put(tblName, tblInfo);
continue;
}
for (String partName : partsNames) {
BackupPartitionInfo partInfo = new BackupPartitionInfo();
partInfo.name = partName;
Expand Down
76 changes: 23 additions & 53 deletions fe/fe-core/src/main/java/com/starrocks/backup/RestoreJob.java
Original file line number Diff line number Diff line change
Expand Up @@ -47,7 +47,6 @@
import com.google.common.collect.Table.Cell;
import com.google.gson.annotations.SerializedName;
import com.starrocks.analysis.BrokerDesc;
import com.starrocks.analysis.TableName;
import com.starrocks.backup.BackupJobInfo.BackupIndexInfo;
import com.starrocks.backup.BackupJobInfo.BackupPartitionInfo;
import com.starrocks.backup.BackupJobInfo.BackupPhysicalPartitionInfo;
Expand Down Expand Up @@ -79,9 +78,7 @@
import com.starrocks.catalog.Table;
import com.starrocks.catalog.Tablet;
import com.starrocks.catalog.TabletMeta;
import com.starrocks.catalog.View;
import com.starrocks.common.Config;
import com.starrocks.common.DdlException;
import com.starrocks.common.Pair;
import com.starrocks.common.UserException;
import com.starrocks.common.io.Text;
Expand All @@ -93,11 +90,8 @@
import com.starrocks.fs.HdfsUtil;
import com.starrocks.metric.MetricRepo;
import com.starrocks.persist.ColocatePersistInfo;
import com.starrocks.qe.ConnectContext;
import com.starrocks.server.GlobalStateMgr;
import com.starrocks.sql.analyzer.SemanticException;
import com.starrocks.sql.ast.CreateViewStmt;
import com.starrocks.sql.parser.NodePosition;
import com.starrocks.task.AgentBatchTask;
import com.starrocks.task.AgentTask;
import com.starrocks.task.AgentTaskExecutor;
Expand Down Expand Up @@ -536,6 +530,19 @@ private void checkAndPrepareMeta() {
Table remoteTbl = backupMeta.getTable(tblInfo.name);
Preconditions.checkNotNull(remoteTbl);
Table localTbl = db.getTable(jobInfo.getAliasByOriginNameIfSet(tblInfo.name));

if (localTbl != null && remoteTbl.isOlapView() && !localTbl.isOlapView()) {
status = new Status(ErrCode.BAD_REPLACE,
"Table: " + localTbl.getName() + " has existed and it is not a View");
return;
}

if (remoteTbl.isOlapView()) {
remoteTbl.setId(globalStateMgr.getNextId());
restoredTbls.add(remoteTbl);
continue;
}

if (localTbl != null) {
if (localTbl instanceof OlapTable && localTbl.hasAutoIncrementColumn()) {
// it must be !isReplay == true
Expand Down Expand Up @@ -765,7 +772,7 @@ private void checkAndPrepareMeta() {
backupTableInfo.getPartInfo(restorePart.getName()), true);
}
// set restored table's new name after all 'genFileMapping'
((OlapTable) restoreTbl).setName(jobInfo.getAliasByOriginNameIfSet(restoreTbl.getName()));
restoreTbl.setName(jobInfo.getAliasByOriginNameIfSet(restoreTbl.getName()));
}

LOG.debug("finished to generate create replica tasks. {}", this);
Expand All @@ -785,14 +792,6 @@ private void checkAndPrepareMeta() {
return;
}

// add all restored olap view into globalStateMgr
List<View> restoredOlapViews = backupMeta.getTables().values().stream().filter(Table::isOlapView)
.map(x -> (View) x).collect(Collectors.toList());
addRestoreOlapView(restoredOlapViews);
if (!status.ok()) {
return;
}

LOG.info("finished to prepare meta. begin to make snapshot. {}", this);

// begin to make snapshots for all replicas
Expand Down Expand Up @@ -850,38 +849,6 @@ protected void sendCreateReplicaTasks() {
}
}

protected void addRestoreOlapView(List<View> restoredOlapViews) {
Database db = globalStateMgr.getLocalMetastore().getDb(dbId);

ConnectContext context = new ConnectContext();
context.setDatabase(db.getFullName());
context.setGlobalStateMgr(globalStateMgr);
context.setStartTime();
context.setThreadLocalInfo();

for (View restoredOlapView : restoredOlapViews) {
Table localTbl = db.getTable(restoredOlapView.getId());
if (localTbl != null && !localTbl.isOlapView()) {
status = new Status(ErrCode.BAD_REPLACE,
"Table: " + localTbl.getName() + " has existed and it is not a View");
return;
}

CreateViewStmt stmt = new CreateViewStmt(false, true, new TableName(db.getFullName(), restoredOlapView.getName()),
Lists.newArrayList(), restoredOlapView.getComment(), restoredOlapView.getQueryStatement(), NodePosition.ZERO);
stmt.setColumns(restoredOlapView.getColumns());
stmt.setInlineViewDef(restoredOlapView.getInlineViewDef());
context.getSessionVariable().setSqlMode(restoredOlapView.getSqlMode());
try {
GlobalStateMgr.getCurrentState().getMetadataMgr().createView(stmt);
} catch (DdlException e) {
status = new Status(ErrCode.COMMON_ERROR,
"Failed to create view for restore. err message: " + e.getMessage());
return;
}
}
}

protected void addRestorePartitionsAndTables(Database db) {
Locker locker = new Locker();
locker.lockDatabase(db, LockType.WRITE);
Expand All @@ -893,6 +860,10 @@ protected void addRestorePartitionsAndTables(Database db) {

// add restored tables
for (Table tbl : restoredTbls) {
if (tbl.isOlapView()) {
// for logical view, force drop and replace
db.dropTable(tbl.getName());
}
if (!db.registerTableUnlocked(tbl)) {
status = new Status(ErrCode.COMMON_ERROR, "Table " + tbl.getName()
+ " already exist in db: " + db.getOriginName());
Expand Down Expand Up @@ -1147,7 +1118,7 @@ private void replayCheckAndPrepareMeta() {
// replay set all existing tables's state to RESTORE
for (BackupTableInfo tblInfo : jobInfo.tables.values()) {
Table tbl = db.getTable(jobInfo.getAliasByOriginNameIfSet(tblInfo.name));
if (tbl == null) {
if (tbl == null || tbl.isOlapView()) {
continue;
}
OlapTable olapTbl = (OlapTable) tbl;
Expand All @@ -1169,9 +1140,8 @@ private void replayCheckAndPrepareMeta() {
locker.unLockDatabase(db, LockType.WRITE);
}

List<View> restoredOlapViews = backupMeta.getTables().values().stream().filter(Table::isOlapView)
.map(x -> (View) x).collect(Collectors.toList());
addRestoreOlapView(restoredOlapViews);
// restored view need not to be added again here, because
// another edit log created by createView will done.

LOG.info("replay check and prepare meta. {}", this);
}
Expand Down Expand Up @@ -1485,9 +1455,9 @@ private Status allTabletCommitted(boolean isReplay) {
// set all tables' state to NORMAL
setTableStateToNormal(db);

for (long tblId : restoredVersionInfo.rowKeySet()) {
for (long tblId : restoredVersionInfo.rowKeySet()) {
Table tbl = db.getTable(tblId);
if (tbl == null) {
if (tbl == null || tbl.isOlapView()) {
continue;
}
OlapTable olapTbl = (OlapTable) tbl;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -718,7 +718,7 @@ public void testColocateRestore() {
public void testRestoreView() {
new Expectations() {
{
globalStateMgr.getLocalMetastore().getDb(anyLong);
globalStateMgr.getDb(anyLong);
minTimes = 0;
result = db;

Expand Down Expand Up @@ -784,6 +784,11 @@ boolean await(long timeout, TimeUnit unit) {

View restoredView = (View) db.getTable(CatalogMocker.TEST_TBL6_ID);

BackupTableInfo tblInfo = new BackupTableInfo();
tblInfo.id = CatalogMocker.TEST_TBL6_ID;
tblInfo.name = CatalogMocker.TEST_TBL6_NAME;
jobInfo.tables.put(tblInfo.name, tblInfo);

new MockUp<LocalMetastore>() {
@Mock
public Database getDb(String dbName) {
Expand Down

0 comments on commit de7ec77

Please sign in to comment.