Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
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
16 changes: 13 additions & 3 deletions main.go
Original file line number Diff line number Diff line change
Expand Up @@ -343,9 +343,19 @@ func main() {
return err
}

bucket := c.String("s3-bucket")
prefix := c.String("s3-prefix")
return migrate.MigrateLogsS3(source, bucket, prefix)
target, err := sql.Open(
c.GlobalString("target-database-driver"),
c.GlobalString("target-database-datasource"),
)

if err != nil {
return err
}

return migrate.MigrateLogsS3(
source, target,
c.GlobalString("s3-bucket"),
c.GlobalString("s3-prefix"))
},
},
{
Expand Down
27 changes: 27 additions & 0 deletions migrate/db/mysql/ddl_gen.go
Original file line number Diff line number Diff line change
Expand Up @@ -124,6 +124,14 @@ var migrations = []struct {
name: "create-table-org-secrets",
stmt: createTableOrgSecrets,
},
{
name: "create-table-last-migrated-log-id",
stmt: createTableLastMigratedLogID,
},
{
name: "create-record-last-migrated-log-id",
stmt: createRecordLastMigratedLogID,
},
}

// Migrate performs the database migration. If the migration fails
Expand Down Expand Up @@ -577,3 +585,22 @@ CREATE TABLE IF NOT EXISTS orgsecrets (
,UNIQUE(secret_namespace, secret_name)
);
`

//
// 013_create_table_last_migrated_log_id.sql
//

var createTableLastMigratedLogID = `
CREATE TABLE IF NOT EXISTS last_migrated_log_id (
id INTEGER PRIMARY KEY
,log_id INTEGER
);
`

//
// 014_create_record_last_migrated_log_id.sql
//

var createRecordLastMigratedLogID = `
INSERT IGNORE INTO last_migrated_log_id (id, log_id) VALUES (1, -1);
`
28 changes: 28 additions & 0 deletions migrate/db/postgres/ddl_gen.go
Original file line number Diff line number Diff line change
Expand Up @@ -120,6 +120,14 @@ var migrations = []struct {
name: "create-table-org-secrets",
stmt: createTableOrgSecrets,
},
{
name: "create-table-last-migrated-log-id",
stmt: createTableLastMigratedLogID,
},
{
name: "create-record-last-migrated-log-id",
stmt: createRecordLastMigratedLogID,
},
}

// Migrate performs the database migration. If the migration fails
Expand Down Expand Up @@ -555,3 +563,23 @@ CREATE TABLE IF NOT EXISTS orgsecrets (
,UNIQUE(secret_namespace, secret_name)
);
`

//
// 013_create_table_last_migrated_log_id.sql
//

var createTableLastMigratedLogID = `
CREATE TABLE IF NOT EXISTS last_migrated_log_id (
id INTEGER PRIMARY KEY
,log_id INTEGER
);
`

//
// 014_create_record_last_migrated_log_id.sql
//

var createRecordLastMigratedLogID = `
INSERT INTO last_migrated_log_id (id, log_id) VALUES (1, -1)
ON CONFLICT DO NOTHING;
`
27 changes: 27 additions & 0 deletions migrate/db/sqlite/ddl_gen.go
Original file line number Diff line number Diff line change
Expand Up @@ -120,6 +120,14 @@ var migrations = []struct {
name: "create-table-org-secrets",
stmt: createTableOrgSecrets,
},
{
name: "create-table-last-migrated-log-id",
stmt: createTableLastMigratedLogID,
},
{
name: "create-record-last-migrated-log-id",
stmt: createRecordLastMigratedLogID,
},
}

// Migrate performs the database migration. If the migration fails
Expand Down Expand Up @@ -557,3 +565,22 @@ CREATE TABLE IF NOT EXISTS orgsecrets (
,UNIQUE(secret_namespace, secret_name)
);
`

//
// 013_create_table_last_migrated_log_id.sql
//

var createTableLastMigratedLogID = `
CREATE TABLE IF NOT EXISTS last_migrated_log_id (
id INTEGER PRIMARY KEY
,log_id INTEGER
);
`

//
// 014_create_record_last_migrated_log_id.sql
//

var createRecordLastMigratedLogID = `
INSERT OR IGNORE INTO last_migrated_log_id (id, log_id) VALUES (1, -1);
`
23 changes: 21 additions & 2 deletions migrate/logs.go
Original file line number Diff line number Diff line change
Expand Up @@ -64,11 +64,29 @@ func MigrateLogs(source, target *sql.DB) error {
}

// MigrateLogsS3 migrates the steps from the V0 database to S3.
func MigrateLogsS3(source *sql.DB, bucket, prefix string) error {
func MigrateLogsS3(source, target *sql.DB, bucket, prefix string) error {
stepsV0 := []*StepV0{}

// get the last migrated log id
lastMigratedLog := &LastMigratedLogID{}
if err := meddler.QueryRow(target, lastMigratedLog, lastMigratedLogIDQuery); err != nil {
return err
}
lastMigratedLogID := lastMigratedLog.LogID

defer func() {
err := meddler.Update(target, "last_migrated_log_id", &LastMigratedLogID{
ID: 1,
LogID: lastMigratedLogID,
})
if err != nil {
logrus.WithError(err).Warnf("cannot update last migrated log id: %d", lastMigratedLogID)
}
}()

// 1. load all stages from the V0 database.
err := meddler.QueryAll(source, &stepsV0, stepListQuery)
err := meddler.QueryAll(
source, &stepsV0, stepListFilterByIDQuery, lastMigratedLogID)
if err != nil {
return err
}
Expand Down Expand Up @@ -109,6 +127,7 @@ func MigrateLogsS3(source *sql.DB, bucket, prefix string) error {
logrus.WithError(err).Errorln("migration failed")
return err
}
lastMigratedLogID = logsV0.ProcID
}

logrus.Infof("migration complete")
Expand Down
16 changes: 16 additions & 0 deletions migrate/steps.go
Original file line number Diff line number Diff line change
Expand Up @@ -86,7 +86,23 @@ WHERE proc_ppid != 0
AND repo_user_id > 0
`

const stepListFilterByIDQuery = `
SELECT procs.*
FROM procs
INNER JOIN builds ON procs.proc_build_id = builds.build_id
INNER JOIN repos ON builds.build_repo_id = repos.repo_id
WHERE proc_ppid != 0
AND repo_user_id > 0
AND proc_id > ?
ORDER BY proc_id
`

const updateStepSeq = `
ALTER SEQUENCE steps_step_id_seq
RESTART WITH %d
`

const lastMigratedLogIDQuery = `
SELECT log_id FROM last_migrated_log_id
WHERE id = 1
`
6 changes: 6 additions & 0 deletions migrate/types.go
Original file line number Diff line number Diff line change
Expand Up @@ -296,6 +296,12 @@ type (
Token string `meddler:"registry_token"`
}

// LastMigratedLogID is a last migrated log id.
LastMigratedLogID struct {
ID int64 `meddler:"id,pk"`
LogID int64 `meddler:"log_id"`
}

// DockerConfig defines required attributes from Docker registry credentials.
DockerConfig struct {
AuthConfigs map[string]AuthConfig `json:"auths"`
Expand Down