Skip to content

Commit

Permalink
avoid race having MaintainPull send updated offset before sync record…
Browse files Browse the repository at this point in the history
…s commits
  • Loading branch information
serprex committed Mar 13, 2024
1 parent 31c52d9 commit 67ffab2
Show file tree
Hide file tree
Showing 3 changed files with 18 additions and 2 deletions.
1 change: 1 addition & 0 deletions flow/activities/flowable.go
Original file line number Diff line number Diff line change
Expand Up @@ -410,6 +410,7 @@ func (a *FlowableActivity) SyncFlow(
logger.Info(fmt.Sprintf("pushed %d records in %d seconds", numRecords, int(syncDuration.Seconds())))

lastCheckpoint := recordBatch.GetLastCheckpoint()
srcConn.UpdateReplStateLastOffset(lastCheckpoint)

err = monitoring.UpdateNumRowsAndEndLSNForCDCBatch(
ctx,
Expand Down
3 changes: 3 additions & 0 deletions flow/connectors/core.go
Original file line number Diff line number Diff line change
Expand Up @@ -54,6 +54,9 @@ type CDCPullConnector interface {
// This method should be idempotent, and should be able to be called multiple times with the same request.
PullRecords(ctx context.Context, catalogPool *pgxpool.Pool, req *model.PullRecordsRequest) error

// Called when offset has been confirmed to destination
UpdateReplStateLastOffset(lastOffset int64)

// PullFlowCleanup drops both the Postgres publication and replication slot, as a part of DROP MIRROR
PullFlowCleanup(ctx context.Context, jobName string) error

Expand Down
16 changes: 14 additions & 2 deletions flow/connectors/postgres/postgres.go
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@ import (
"regexp"
"strings"
"sync"
"sync/atomic"
"time"

"github.com/google/uuid"
Expand Down Expand Up @@ -49,6 +50,7 @@ type ReplState struct {
Slot string
Publication string
Offset int64
LastOffset atomic.Int64
}

func NewPostgresConnector(ctx context.Context, pgConfig *protos.PostgresConfig) (*PostgresConnector, error) {
Expand Down Expand Up @@ -133,7 +135,7 @@ func (c *PostgresConnector) ReplPing(ctx context.Context) error {
return pglogrepl.SendStandbyStatusUpdate(
ctx,
c.replConn.PgConn(),
pglogrepl.StandbyStatusUpdate{WALWritePosition: pglogrepl.LSN(c.replState.Offset)},
pglogrepl.StandbyStatusUpdate{WALWritePosition: pglogrepl.LSN(c.replState.LastOffset.Load())},
)
}
}
Expand Down Expand Up @@ -184,7 +186,9 @@ func (c *PostgresConnector) MaybeStartReplication(
Slot: slotName,
Publication: publicationName,
Offset: req.LastOffset,
LastOffset: atomic.Int64{},
}
c.replState.LastOffset.Store(req.LastOffset)
}
return nil
}
Expand Down Expand Up @@ -308,7 +312,9 @@ func (c *PostgresConnector) SetLastOffset(ctx context.Context, jobName string, l
func (c *PostgresConnector) PullRecords(ctx context.Context, catalogPool *pgxpool.Pool, req *model.PullRecordsRequest) error {
defer func() {
req.RecordStream.Close()
c.replState.Offset = req.RecordStream.GetLastCheckpoint()
if c.replState != nil {
c.replState.Offset = req.RecordStream.GetLastCheckpoint()
}
}()

// Slotname would be the job name prefixed with "peerflow_slot_"
Expand Down Expand Up @@ -387,6 +393,12 @@ func (c *PostgresConnector) PullRecords(ctx context.Context, catalogPool *pgxpoo
return nil
}

func (c *PostgresConnector) UpdateReplStateLastOffset(lastOffset int64) {
if c.replState != nil {
c.replState.LastOffset.Store(lastOffset)
}
}

// SyncRecords pushes records to the destination.
func (c *PostgresConnector) SyncRecords(ctx context.Context, req *model.SyncRecordsRequest) (*model.SyncResponse, error) {
rawTableIdentifier := getRawTableIdentifier(req.FlowJobName)
Expand Down

0 comments on commit 67ffab2

Please sign in to comment.