|
@@ -4,6 +4,7 @@ import (
|
|
"errors"
|
|
"errors"
|
|
"fmt"
|
|
"fmt"
|
|
"net/http"
|
|
"net/http"
|
|
|
|
+ "sync"
|
|
"time"
|
|
"time"
|
|
|
|
|
|
"github.com/gin-gonic/gin"
|
|
"github.com/gin-gonic/gin"
|
|
@@ -23,6 +24,7 @@ type Manager struct {
|
|
cfg *Config
|
|
cfg *Config
|
|
engine *gin.Engine
|
|
engine *gin.Engine
|
|
adapter dbAdapter
|
|
adapter dbAdapter
|
|
|
|
+ rwmu sync.RWMutex
|
|
httpClient *http.Client
|
|
httpClient *http.Client
|
|
}
|
|
}
|
|
|
|
|
|
@@ -127,9 +129,11 @@ func (s *Manager) Run() {
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
-// listAllJobs repond with all jobs of specified workers
|
|
|
|
|
|
+// listAllJobs respond with all jobs of specified workers
|
|
func (s *Manager) listAllJobs(c *gin.Context) {
|
|
func (s *Manager) listAllJobs(c *gin.Context) {
|
|
|
|
+ s.rwmu.RLock()
|
|
mirrorStatusList, err := s.adapter.ListAllMirrorStatus()
|
|
mirrorStatusList, err := s.adapter.ListAllMirrorStatus()
|
|
|
|
+ s.rwmu.RUnlock()
|
|
if err != nil {
|
|
if err != nil {
|
|
err := fmt.Errorf("failed to list all mirror status: %s",
|
|
err := fmt.Errorf("failed to list all mirror status: %s",
|
|
err.Error(),
|
|
err.Error(),
|
|
@@ -150,7 +154,9 @@ func (s *Manager) listAllJobs(c *gin.Context) {
|
|
|
|
|
|
// flushDisabledJobs deletes all jobs that marks as deleted
|
|
// flushDisabledJobs deletes all jobs that marks as deleted
|
|
func (s *Manager) flushDisabledJobs(c *gin.Context) {
|
|
func (s *Manager) flushDisabledJobs(c *gin.Context) {
|
|
|
|
+ s.rwmu.Lock()
|
|
err := s.adapter.FlushDisabledJobs()
|
|
err := s.adapter.FlushDisabledJobs()
|
|
|
|
+ s.rwmu.Unlock()
|
|
if err != nil {
|
|
if err != nil {
|
|
err := fmt.Errorf("failed to flush disabled jobs: %s",
|
|
err := fmt.Errorf("failed to flush disabled jobs: %s",
|
|
err.Error(),
|
|
err.Error(),
|
|
@@ -165,7 +171,9 @@ func (s *Manager) flushDisabledJobs(c *gin.Context) {
|
|
// deleteWorker deletes one worker by id
|
|
// deleteWorker deletes one worker by id
|
|
func (s *Manager) deleteWorker(c *gin.Context) {
|
|
func (s *Manager) deleteWorker(c *gin.Context) {
|
|
workerID := c.Param("id")
|
|
workerID := c.Param("id")
|
|
|
|
+ s.rwmu.Lock()
|
|
err := s.adapter.DeleteWorker(workerID)
|
|
err := s.adapter.DeleteWorker(workerID)
|
|
|
|
+ s.rwmu.Unlock()
|
|
if err != nil {
|
|
if err != nil {
|
|
err := fmt.Errorf("failed to delete worker: %s",
|
|
err := fmt.Errorf("failed to delete worker: %s",
|
|
err.Error(),
|
|
err.Error(),
|
|
@@ -178,10 +186,12 @@ func (s *Manager) deleteWorker(c *gin.Context) {
|
|
c.JSON(http.StatusOK, gin.H{_infoKey: "deleted"})
|
|
c.JSON(http.StatusOK, gin.H{_infoKey: "deleted"})
|
|
}
|
|
}
|
|
|
|
|
|
-// listWrokers respond with informations of all the workers
|
|
|
|
|
|
+// listWorkers respond with information of all the workers
|
|
func (s *Manager) listWorkers(c *gin.Context) {
|
|
func (s *Manager) listWorkers(c *gin.Context) {
|
|
var workerInfos []WorkerStatus
|
|
var workerInfos []WorkerStatus
|
|
|
|
+ s.rwmu.RLock()
|
|
workers, err := s.adapter.ListWorkers()
|
|
workers, err := s.adapter.ListWorkers()
|
|
|
|
+ s.rwmu.RUnlock()
|
|
if err != nil {
|
|
if err != nil {
|
|
err := fmt.Errorf("failed to list workers: %s",
|
|
err := fmt.Errorf("failed to list workers: %s",
|
|
err.Error(),
|
|
err.Error(),
|
|
@@ -223,7 +233,9 @@ func (s *Manager) registerWorker(c *gin.Context) {
|
|
// listJobsOfWorker respond with all the jobs of the specified worker
|
|
// listJobsOfWorker respond with all the jobs of the specified worker
|
|
func (s *Manager) listJobsOfWorker(c *gin.Context) {
|
|
func (s *Manager) listJobsOfWorker(c *gin.Context) {
|
|
workerID := c.Param("id")
|
|
workerID := c.Param("id")
|
|
|
|
+ s.rwmu.RLock()
|
|
mirrorStatusList, err := s.adapter.ListMirrorStatus(workerID)
|
|
mirrorStatusList, err := s.adapter.ListMirrorStatus(workerID)
|
|
|
|
+ s.rwmu.RUnlock()
|
|
if err != nil {
|
|
if err != nil {
|
|
err := fmt.Errorf("failed to list jobs of worker %s: %s",
|
|
err := fmt.Errorf("failed to list jobs of worker %s: %s",
|
|
workerID, err.Error(),
|
|
workerID, err.Error(),
|
|
@@ -255,7 +267,9 @@ func (s *Manager) updateSchedulesOfWorker(c *gin.Context) {
|
|
)
|
|
)
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+ s.rwmu.RLock()
|
|
curStatus, err := s.adapter.GetMirrorStatus(workerID, mirrorName)
|
|
curStatus, err := s.adapter.GetMirrorStatus(workerID, mirrorName)
|
|
|
|
+ s.rwmu.RUnlock()
|
|
if err != nil {
|
|
if err != nil {
|
|
fmt.Errorf("failed to get job %s of worker %s: %s",
|
|
fmt.Errorf("failed to get job %s of worker %s: %s",
|
|
mirrorName, workerID, err.Error(),
|
|
mirrorName, workerID, err.Error(),
|
|
@@ -269,7 +283,9 @@ func (s *Manager) updateSchedulesOfWorker(c *gin.Context) {
|
|
}
|
|
}
|
|
|
|
|
|
curStatus.Scheduled = schedule.NextSchedule
|
|
curStatus.Scheduled = schedule.NextSchedule
|
|
|
|
+ s.rwmu.Lock()
|
|
_, err = s.adapter.UpdateMirrorStatus(workerID, mirrorName, curStatus)
|
|
_, err = s.adapter.UpdateMirrorStatus(workerID, mirrorName, curStatus)
|
|
|
|
+ s.rwmu.Unlock()
|
|
if err != nil {
|
|
if err != nil {
|
|
err := fmt.Errorf("failed to update job %s of worker %s: %s",
|
|
err := fmt.Errorf("failed to update job %s of worker %s: %s",
|
|
mirrorName, workerID, err.Error(),
|
|
mirrorName, workerID, err.Error(),
|
|
@@ -295,7 +311,9 @@ func (s *Manager) updateJobOfWorker(c *gin.Context) {
|
|
)
|
|
)
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+ s.rwmu.RLock()
|
|
curStatus, _ := s.adapter.GetMirrorStatus(workerID, mirrorName)
|
|
curStatus, _ := s.adapter.GetMirrorStatus(workerID, mirrorName)
|
|
|
|
+ s.rwmu.RUnlock()
|
|
|
|
|
|
curTime := time.Now()
|
|
curTime := time.Now()
|
|
|
|
|
|
@@ -331,7 +349,9 @@ func (s *Manager) updateJobOfWorker(c *gin.Context) {
|
|
logger.Noticef("Job [%s] @<%s> %s", status.Name, status.Worker, status.Status)
|
|
logger.Noticef("Job [%s] @<%s> %s", status.Name, status.Worker, status.Status)
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+ s.rwmu.Lock()
|
|
newStatus, err := s.adapter.UpdateMirrorStatus(workerID, mirrorName, status)
|
|
newStatus, err := s.adapter.UpdateMirrorStatus(workerID, mirrorName, status)
|
|
|
|
+ s.rwmu.Unlock()
|
|
if err != nil {
|
|
if err != nil {
|
|
err := fmt.Errorf("failed to update job %s of worker %s: %s",
|
|
err := fmt.Errorf("failed to update job %s of worker %s: %s",
|
|
mirrorName, workerID, err.Error(),
|
|
mirrorName, workerID, err.Error(),
|
|
@@ -353,7 +373,9 @@ func (s *Manager) updateMirrorSize(c *gin.Context) {
|
|
c.BindJSON(&msg)
|
|
c.BindJSON(&msg)
|
|
|
|
|
|
mirrorName := msg.Name
|
|
mirrorName := msg.Name
|
|
|
|
+ s.rwmu.RLock()
|
|
status, err := s.adapter.GetMirrorStatus(workerID, mirrorName)
|
|
status, err := s.adapter.GetMirrorStatus(workerID, mirrorName)
|
|
|
|
+ s.rwmu.RUnlock()
|
|
if err != nil {
|
|
if err != nil {
|
|
logger.Errorf(
|
|
logger.Errorf(
|
|
"Failed to get status of mirror %s @<%s>: %s",
|
|
"Failed to get status of mirror %s @<%s>: %s",
|
|
@@ -370,7 +392,9 @@ func (s *Manager) updateMirrorSize(c *gin.Context) {
|
|
|
|
|
|
logger.Noticef("Mirror size of [%s] @<%s>: %s", status.Name, status.Worker, status.Size)
|
|
logger.Noticef("Mirror size of [%s] @<%s>: %s", status.Name, status.Worker, status.Size)
|
|
|
|
|
|
|
|
+ s.rwmu.Lock()
|
|
newStatus, err := s.adapter.UpdateMirrorStatus(workerID, mirrorName, status)
|
|
newStatus, err := s.adapter.UpdateMirrorStatus(workerID, mirrorName, status)
|
|
|
|
+ s.rwmu.Unlock()
|
|
if err != nil {
|
|
if err != nil {
|
|
err := fmt.Errorf("failed to update job %s of worker %s: %s",
|
|
err := fmt.Errorf("failed to update job %s of worker %s: %s",
|
|
mirrorName, workerID, err.Error(),
|
|
mirrorName, workerID, err.Error(),
|
|
@@ -393,7 +417,9 @@ func (s *Manager) handleClientCmd(c *gin.Context) {
|
|
return
|
|
return
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+ s.rwmu.RLock()
|
|
w, err := s.adapter.GetWorker(workerID)
|
|
w, err := s.adapter.GetWorker(workerID)
|
|
|
|
+ s.rwmu.RUnlock()
|
|
if err != nil {
|
|
if err != nil {
|
|
err := fmt.Errorf("worker %s is not registered yet", workerID)
|
|
err := fmt.Errorf("worker %s is not registered yet", workerID)
|
|
s.returnErrJSON(c, http.StatusBadRequest, err)
|
|
s.returnErrJSON(c, http.StatusBadRequest, err)
|
|
@@ -410,7 +436,9 @@ func (s *Manager) handleClientCmd(c *gin.Context) {
|
|
|
|
|
|
// update job status, even if the job did not disable successfully,
|
|
// update job status, even if the job did not disable successfully,
|
|
// this status should be set as disabled
|
|
// this status should be set as disabled
|
|
|
|
+ s.rwmu.RLock()
|
|
curStat, _ := s.adapter.GetMirrorStatus(clientCmd.WorkerID, clientCmd.MirrorID)
|
|
curStat, _ := s.adapter.GetMirrorStatus(clientCmd.WorkerID, clientCmd.MirrorID)
|
|
|
|
+ s.rwmu.RUnlock()
|
|
changed := false
|
|
changed := false
|
|
switch clientCmd.Cmd {
|
|
switch clientCmd.Cmd {
|
|
case CmdDisable:
|
|
case CmdDisable:
|
|
@@ -421,7 +449,9 @@ func (s *Manager) handleClientCmd(c *gin.Context) {
|
|
changed = true
|
|
changed = true
|
|
}
|
|
}
|
|
if changed {
|
|
if changed {
|
|
|
|
+ s.rwmu.Lock()
|
|
s.adapter.UpdateMirrorStatus(clientCmd.WorkerID, clientCmd.MirrorID, curStat)
|
|
s.adapter.UpdateMirrorStatus(clientCmd.WorkerID, clientCmd.MirrorID, curStat)
|
|
|
|
+ s.rwmu.Unlock()
|
|
}
|
|
}
|
|
|
|
|
|
logger.Noticef("Posting command '%s %s' to <%s>", clientCmd.Cmd, clientCmd.MirrorID, clientCmd.WorkerID)
|
|
logger.Noticef("Posting command '%s %s' to <%s>", clientCmd.Cmd, clientCmd.MirrorID, clientCmd.WorkerID)
|