Skip to content

Commit

Permalink
manager: fix checkpoint (#76)
Browse files Browse the repository at this point in the history
  • Loading branch information
skyzh authored Jan 4, 2021
1 parent 50c6f68 commit dd261af
Show file tree
Hide file tree
Showing 3 changed files with 28 additions and 17 deletions.
30 changes: 20 additions & 10 deletions pkg/manager/manager.go
Original file line number Diff line number Diff line change
Expand Up @@ -51,11 +51,11 @@ type Status struct {
}

type WorkerCheckPoint struct {
LastInvokeTime time.Time
LastInvokeTime time.Time `json:"last_invoke_time"`
}

type CheckPoint struct {
workerInfo map[string]WorkerCheckPoint
WorkerInfo map[string]WorkerCheckPoint `json:"worker_info"`
}

// fromCheckpoint laods last invoke time from json
Expand Down Expand Up @@ -89,7 +89,7 @@ func NewManager(config *config.Config) (*Manager, error) {
if err != nil {
logger.Info("failed to parse checkpoint file")
} else {
for worker, info := range checkpoint.workerInfo {
for worker, info := range checkpoint.WorkerInfo {
workersLastInvokeTime[worker] = info.LastInvokeTime
}
}
Expand All @@ -106,23 +106,32 @@ func NewManager(config *config.Config) (*Manager, error) {
if disabled, ok := repoConfig["disabled"].(bool); ok && disabled {
continue
}
w, err := worker.NewWorker(repoConfig)
if err != nil {
return nil, err
}
newManager.workers = append(newManager.workers, w)
name, _ := repoConfig["name"].(string)
if _, ok := newManager.workersLastInvokeTime[name]; !ok {
newManager.workersLastInvokeTime[name] = time.Now().AddDate(-1, 0, 0)
}
w, err := worker.NewWorker(repoConfig, newManager.workersLastInvokeTime[name])
if err != nil {
return nil, err
}
newManager.workers = append(newManager.workers, w)
}
return &newManager, nil
}

func (m *Manager) checkpoint() error {
file, _ := json.MarshalIndent(m.workersLastInvokeTime, "", " ")
ckptObj := &CheckPoint{WorkerInfo: make(map[string]WorkerCheckPoint)}
for k, t := range m.workersLastInvokeTime {
ckptObj.WorkerInfo[k] = WorkerCheckPoint{
LastInvokeTime: t,
}
}
file, err := json.MarshalIndent(ckptObj, "", " ")
if err != nil {
return err
}
ckpt := fmt.Sprintf("%s.tmp", m.config.Checkpoint)
err := ioutil.WriteFile(ckpt, file, 0644)
err = ioutil.WriteFile(ckpt, file, 0644)
if err != nil {
return err
}
Expand Down Expand Up @@ -184,6 +193,7 @@ func (m *Manager) Run() {
}).Debugf("Calling RunSync() to w %s", w.GetConfig()["name"])
go w.RunSync()
}
m.checkpoint()
for {
// wait until config.Interval seconds has elapsed
select {
Expand Down
4 changes: 2 additions & 2 deletions pkg/worker/worker.go
Original file line number Diff line number Diff line change
Expand Up @@ -34,7 +34,7 @@ type Status struct {
}

// NewWorker generates a worker by config and log.
func NewWorker(cfg config.RepoConfig) (Worker, error) {
func NewWorker(cfg config.RepoConfig, lastFinished time.Time) (Worker, error) {
if syncType, ok := cfg["type"]; ok {
switch syncType {
case "rsync":
Expand All @@ -45,7 +45,7 @@ func NewWorker(cfg config.RepoConfig) (Worker, error) {
newShellScriptExecutor(cfg),
Status{
Result: true,
LastFinished: time.Now().AddDate(-1, 0, 0),
LastFinished: lastFinished,
Idle: true,
Stdout: make([]string, 0),
Stderr: make([]string, 0),
Expand Down
11 changes: 6 additions & 5 deletions pkg/worker/worker_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -12,9 +12,10 @@ import (
"github.com/stretchr/testify/assert"

"errors"
"sync/atomic"

"github.com/sirupsen/logrus"
"github.com/sjtug/lug/pkg/config"
"sync/atomic"
)

func TestNewExternalWorker(t *testing.T) {
Expand All @@ -23,12 +24,12 @@ func TestNewExternalWorker(t *testing.T) {
"blahblah": "foobar",
"type": "external",
}
_, err := NewWorker(c)
_, err := NewWorker(c, time.Now())
// worker with no name is not allowed
asrt.NotNil(err)

c["name"] = "test_external"
w, err := NewWorker(c)
w, err := NewWorker(c, time.Now())
// config with name and dummy kv pairs should be allowed
asrt.Nil(err)

Expand All @@ -47,7 +48,7 @@ func TestNewShellScriptWorker(t *testing.T) {

asrt := assert.New(t)

w, _ := NewWorker(c)
w, _ := NewWorker(c, time.Now())

asrt.Equal(true, w.GetStatus().Result)
asrt.Equal("shell_script", w.GetConfig()["type"])
Expand Down Expand Up @@ -186,7 +187,7 @@ func TestShellScriptWorkerArgParse(t *testing.T) {
"name": "shell",
"script": "wc -l /proc/stat",
}
w, err := NewWorker(c)
w, err := NewWorker(c, time.Now())

asrt := assert.New(t)
asrt.Nil(err)
Expand Down

0 comments on commit dd261af

Please sign in to comment.