Skip to content

Commit

Permalink
owner: fix new owner updating checkpoint too early with pending DDL (#…
Browse files Browse the repository at this point in the history
  • Loading branch information
ti-chi-bot authored Jul 16, 2021
1 parent e94f5f5 commit 66f0043
Show file tree
Hide file tree
Showing 3 changed files with 12 additions and 3 deletions.
8 changes: 7 additions & 1 deletion cdc/owner/changefeed.go
Original file line number Diff line number Diff line change
Expand Up @@ -214,7 +214,10 @@ LOOP:
if err != nil {
return errors.Trace(err)
}
c.ddlPuller, err = c.newDDLPuller(cancelCtx, checkpointTs)
// Since we wait for checkpoint == ddlJob.FinishTs before executing the DDL,
// when there is a recovery, there is no guarantee that the DDL at the checkpoint
// has been executed. So we need to start the DDL puller from (checkpoint-1).
c.ddlPuller, err = c.newDDLPuller(cancelCtx, checkpointTs-1)
if err != nil {
return errors.Trace(err)
}
Expand Down Expand Up @@ -321,6 +324,9 @@ func (c *changefeed) handleBarrier(ctx cdcContext.Context) (uint64, error) {
case ddlJobBarrier:
ddlResolvedTs, ddlJob := c.ddlPuller.FrontDDL()
if ddlJob == nil || ddlResolvedTs != barrierTs {
if ddlResolvedTs < barrierTs {
return barrierTs, nil
}
c.barriers.Update(ddlJobBarrier, ddlResolvedTs)
return barrierTs, nil
}
Expand Down
5 changes: 4 additions & 1 deletion cdc/owner/schema.go
Original file line number Diff line number Diff line change
Expand Up @@ -46,6 +46,9 @@ func newSchemaWrap4Owner(kvStorage tidbkv.Storage, startTs model.Ts, config *con
return nil, errors.Trace(err)
}
}
// We do a snapshot read of the metadata from TiKV at (startTs-1) instead of startTs,
// because the DDL puller might send a DDL at startTs, which would cause schema conflicts if
// the DDL's result is already contained in the snapshot.
schemaSnap, err := entry.NewSingleSchemaSnapshotFromMeta(meta, startTs-1, config.ForceReplicate)
if err != nil {
return nil, errors.Trace(err)
Expand All @@ -58,7 +61,7 @@ func newSchemaWrap4Owner(kvStorage tidbkv.Storage, startTs model.Ts, config *con
schemaSnapshot: schemaSnap,
filter: f,
config: config,
ddlHandledTs: startTs - 1,
ddlHandledTs: startTs,
}, nil
}

Expand Down
2 changes: 1 addition & 1 deletion tests/kill_owner_with_ddl/run.sh
Original file line number Diff line number Diff line change
Expand Up @@ -69,7 +69,7 @@ function run() {

for i in $(seq 1 3); do
kill_cdc_and_restart $pd_addr $WORK_DIR $CDC_BINARY
sleep 2
sleep 8
done

export GO_FAILPOINTS=''
Expand Down

0 comments on commit 66f0043

Please sign in to comment.