mirror of
https://github.com/go-gitea/gitea.git
synced 2024-09-01 14:56:30 +00:00
Revert changes about status table
This commit is contained in:
parent
5141395f7a
commit
b0f67104ee
57
modules/sync/status_pool.go
Normal file
57
modules/sync/status_pool.go
Normal file
@ -0,0 +1,57 @@
|
|||||||
|
// Copyright 2016 The Gogs Authors. All rights reserved.
|
||||||
|
// SPDX-License-Identifier: MIT
|
||||||
|
|
||||||
|
package sync
|
||||||
|
|
||||||
|
import (
|
||||||
|
"sync"
|
||||||
|
|
||||||
|
"code.gitea.io/gitea/modules/container"
|
||||||
|
)
|
||||||
|
|
||||||
|
// StatusTable is a table maintains true/false values.
|
||||||
|
//
|
||||||
|
// This table is particularly useful for un/marking and checking values
|
||||||
|
// in different goroutines.
|
||||||
|
type StatusTable struct {
|
||||||
|
lock sync.RWMutex
|
||||||
|
pool container.Set[string]
|
||||||
|
}
|
||||||
|
|
||||||
|
// NewStatusTable initializes and returns a new StatusTable object.
|
||||||
|
func NewStatusTable() *StatusTable {
|
||||||
|
return &StatusTable{
|
||||||
|
pool: make(container.Set[string]),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// StartIfNotRunning sets value of given name to true if not already in pool.
|
||||||
|
// Returns whether set value was set to true
|
||||||
|
func (p *StatusTable) StartIfNotRunning(name string) bool {
|
||||||
|
p.lock.Lock()
|
||||||
|
added := p.pool.Add(name)
|
||||||
|
p.lock.Unlock()
|
||||||
|
return added
|
||||||
|
}
|
||||||
|
|
||||||
|
// Start sets value of given name to true in the pool.
|
||||||
|
func (p *StatusTable) Start(name string) {
|
||||||
|
p.lock.Lock()
|
||||||
|
p.pool.Add(name)
|
||||||
|
p.lock.Unlock()
|
||||||
|
}
|
||||||
|
|
||||||
|
// Stop sets value of given name to false in the pool.
|
||||||
|
func (p *StatusTable) Stop(name string) {
|
||||||
|
p.lock.Lock()
|
||||||
|
p.pool.Remove(name)
|
||||||
|
p.lock.Unlock()
|
||||||
|
}
|
||||||
|
|
||||||
|
// IsRunning checks if value of given name is set to true in the pool.
|
||||||
|
func (p *StatusTable) IsRunning(name string) bool {
|
||||||
|
p.lock.RLock()
|
||||||
|
exists := p.pool.Contains(name)
|
||||||
|
p.lock.RUnlock()
|
||||||
|
return exists
|
||||||
|
}
|
31
modules/sync/status_pool_test.go
Normal file
31
modules/sync/status_pool_test.go
Normal file
@ -0,0 +1,31 @@
|
|||||||
|
// Copyright 2017 The Gitea Authors. All rights reserved.
|
||||||
|
// SPDX-License-Identifier: MIT
|
||||||
|
|
||||||
|
package sync
|
||||||
|
|
||||||
|
import (
|
||||||
|
"testing"
|
||||||
|
|
||||||
|
"github.com/stretchr/testify/assert"
|
||||||
|
)
|
||||||
|
|
||||||
|
func Test_StatusTable(t *testing.T) {
|
||||||
|
table := NewStatusTable()
|
||||||
|
|
||||||
|
assert.False(t, table.IsRunning("xyz"))
|
||||||
|
|
||||||
|
table.Start("xyz")
|
||||||
|
assert.True(t, table.IsRunning("xyz"))
|
||||||
|
|
||||||
|
assert.False(t, table.StartIfNotRunning("xyz"))
|
||||||
|
assert.True(t, table.IsRunning("xyz"))
|
||||||
|
|
||||||
|
table.Stop("xyz")
|
||||||
|
assert.False(t, table.IsRunning("xyz"))
|
||||||
|
|
||||||
|
assert.True(t, table.StartIfNotRunning("xyz"))
|
||||||
|
assert.True(t, table.IsRunning("xyz"))
|
||||||
|
|
||||||
|
table.Stop("xyz")
|
||||||
|
assert.False(t, table.IsRunning("xyz"))
|
||||||
|
}
|
@ -11,6 +11,7 @@ import (
|
|||||||
|
|
||||||
"code.gitea.io/gitea/modules/graceful"
|
"code.gitea.io/gitea/modules/graceful"
|
||||||
"code.gitea.io/gitea/modules/process"
|
"code.gitea.io/gitea/modules/process"
|
||||||
|
"code.gitea.io/gitea/modules/sync"
|
||||||
"code.gitea.io/gitea/modules/translation"
|
"code.gitea.io/gitea/modules/translation"
|
||||||
|
|
||||||
"github.com/go-co-op/gocron"
|
"github.com/go-co-op/gocron"
|
||||||
@ -18,6 +19,8 @@ import (
|
|||||||
|
|
||||||
var scheduler = gocron.NewScheduler(time.Local)
|
var scheduler = gocron.NewScheduler(time.Local)
|
||||||
|
|
||||||
|
var taskStatusTable = sync.NewStatusTable()
|
||||||
|
|
||||||
// NewContext begins cron tasks
|
// NewContext begins cron tasks
|
||||||
// Each cron task is run within the shutdown context as a running server
|
// Each cron task is run within the shutdown context as a running server
|
||||||
// AtShutdown the cron server is stopped
|
// AtShutdown the cron server is stopped
|
||||||
|
@ -14,7 +14,6 @@ import (
|
|||||||
"code.gitea.io/gitea/models/db"
|
"code.gitea.io/gitea/models/db"
|
||||||
system_model "code.gitea.io/gitea/models/system"
|
system_model "code.gitea.io/gitea/models/system"
|
||||||
user_model "code.gitea.io/gitea/models/user"
|
user_model "code.gitea.io/gitea/models/user"
|
||||||
"code.gitea.io/gitea/modules/globallock"
|
|
||||||
"code.gitea.io/gitea/modules/graceful"
|
"code.gitea.io/gitea/modules/graceful"
|
||||||
"code.gitea.io/gitea/modules/log"
|
"code.gitea.io/gitea/modules/log"
|
||||||
"code.gitea.io/gitea/modules/process"
|
"code.gitea.io/gitea/modules/process"
|
||||||
@ -74,12 +73,7 @@ func (t *Task) Run() {
|
|||||||
|
|
||||||
// RunWithUser will run the task incrementing the cron counter at the time with User
|
// RunWithUser will run the task incrementing the cron counter at the time with User
|
||||||
func (t *Task) RunWithUser(doer *user_model.User, config Config) {
|
func (t *Task) RunWithUser(doer *user_model.User, config Config) {
|
||||||
lock := globallock.GetLock(fmt.Sprintf("cron_tasks_%s", t.Name))
|
if !taskStatusTable.StartIfNotRunning(t.Name) {
|
||||||
if success, err := lock.TryLock(); err != nil {
|
|
||||||
log.Error("Unable to lock cron task %s Error: %v", t.Name, err)
|
|
||||||
return
|
|
||||||
} else if !success {
|
|
||||||
// get lock failed, so that there must be another task are running.
|
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
t.lock.Lock()
|
t.lock.Lock()
|
||||||
@ -89,9 +83,7 @@ func (t *Task) RunWithUser(doer *user_model.User, config Config) {
|
|||||||
t.ExecTimes++
|
t.ExecTimes++
|
||||||
t.lock.Unlock()
|
t.lock.Unlock()
|
||||||
defer func() {
|
defer func() {
|
||||||
if _, err := lock.Unlock(); err != nil {
|
taskStatusTable.Stop(t.Name)
|
||||||
log.Error("Unable to unlock cron task %s Error: %v", t.Name, err)
|
|
||||||
}
|
|
||||||
}()
|
}()
|
||||||
graceful.GetManager().RunWithShutdownContext(func(baseCtx context.Context) {
|
graceful.GetManager().RunWithShutdownContext(func(baseCtx context.Context) {
|
||||||
defer func() {
|
defer func() {
|
||||||
|
Loading…
Reference in New Issue
Block a user