mirror of
https://codeberg.org/forgejo/forgejo.git
synced 2025-01-28 17:58:16 +00:00
Issues: Standardise the issues indexer queue settings
This commit is contained in:
parent
4658b2f35e
commit
cc123c3448
2 changed files with 36 additions and 58 deletions
|
@ -6,7 +6,6 @@ package issues
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
"encoding/json"
|
|
||||||
"os"
|
"os"
|
||||||
"sync"
|
"sync"
|
||||||
"time"
|
"time"
|
||||||
|
@ -113,64 +112,10 @@ func InitIssueIndexer(syncReindex bool) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
queueType := queue.PersistableChannelQueueType
|
issueIndexerQueue = setting.CreateQueue("issue_indexer", handler, &IndexerData{})
|
||||||
switch setting.Indexer.IssueQueueType {
|
|
||||||
case setting.LevelQueueType:
|
|
||||||
queueType = queue.LevelQueueType
|
|
||||||
case setting.ChannelQueueType:
|
|
||||||
queueType = queue.PersistableChannelQueueType
|
|
||||||
case setting.RedisQueueType:
|
|
||||||
queueType = queue.RedisQueueType
|
|
||||||
default:
|
|
||||||
log.Fatal("Unsupported indexer queue type: %v",
|
|
||||||
setting.Indexer.IssueQueueType)
|
|
||||||
}
|
|
||||||
|
|
||||||
name := "issue_indexer_queue"
|
if issueIndexerQueue == nil {
|
||||||
opts := make(map[string]interface{})
|
log.Fatal("Unable to create issue indexer queue")
|
||||||
opts["QueueLength"] = setting.Indexer.UpdateQueueLength
|
|
||||||
opts["BatchLength"] = setting.Indexer.IssueQueueBatchNumber
|
|
||||||
opts["DataDir"] = setting.Indexer.IssueQueueDir
|
|
||||||
|
|
||||||
addrs, password, dbIdx, err := setting.ParseQueueConnStr(setting.Indexer.IssueQueueConnStr)
|
|
||||||
if queueType == queue.RedisQueueType && err != nil {
|
|
||||||
log.Fatal("Unable to parse connection string for RedisQueueType: %s : %v",
|
|
||||||
setting.Indexer.IssueQueueConnStr,
|
|
||||||
err)
|
|
||||||
}
|
|
||||||
opts["Addresses"] = addrs
|
|
||||||
opts["Password"] = password
|
|
||||||
opts["DBIndex"] = dbIdx
|
|
||||||
opts["QueueName"] = name
|
|
||||||
opts["Name"] = name
|
|
||||||
opts["Workers"] = 1
|
|
||||||
opts["BlockTimeout"] = 1 * time.Second
|
|
||||||
opts["BoostTimeout"] = 5 * time.Minute
|
|
||||||
opts["BoostWorkers"] = 5
|
|
||||||
cfg, err := json.Marshal(opts)
|
|
||||||
if err != nil {
|
|
||||||
log.Error("Unable to marshall generic options: %v Error: %v", opts, err)
|
|
||||||
log.Fatal("Unable to create issue indexer queue with type %s: %v",
|
|
||||||
queueType,
|
|
||||||
err)
|
|
||||||
}
|
|
||||||
log.Debug("Creating issue indexer queue with type %s: configuration: %s", queueType, string(cfg))
|
|
||||||
issueIndexerQueue, err = queue.CreateQueue(queueType, handler, cfg, &IndexerData{})
|
|
||||||
if err != nil {
|
|
||||||
issueIndexerQueue, err = queue.CreateQueue(queue.WrappedQueueType, handler, queue.WrappedQueueConfiguration{
|
|
||||||
Underlying: queueType,
|
|
||||||
Timeout: setting.GracefulHammerTime + 30*time.Second,
|
|
||||||
MaxAttempts: 10,
|
|
||||||
Config: cfg,
|
|
||||||
QueueLength: setting.Indexer.UpdateQueueLength,
|
|
||||||
Name: name,
|
|
||||||
}, &IndexerData{})
|
|
||||||
}
|
|
||||||
if err != nil {
|
|
||||||
log.Fatal("Unable to create issue indexer queue with type %s: %v : %v",
|
|
||||||
queueType,
|
|
||||||
string(cfg),
|
|
||||||
err)
|
|
||||||
}
|
}
|
||||||
default:
|
default:
|
||||||
issueIndexerQueue = &queue.DummyQueue{}
|
issueIndexerQueue = &queue.DummyQueue{}
|
||||||
|
|
|
@ -6,6 +6,7 @@ package setting
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"encoding/json"
|
"encoding/json"
|
||||||
|
"fmt"
|
||||||
"path"
|
"path"
|
||||||
"strconv"
|
"strconv"
|
||||||
"strings"
|
"strings"
|
||||||
|
@ -145,6 +146,38 @@ func newQueueService() {
|
||||||
if !hasWorkers {
|
if !hasWorkers {
|
||||||
Cfg.Section("queue.notification").Key("WORKERS").SetValue("5")
|
Cfg.Section("queue.notification").Key("WORKERS").SetValue("5")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Now handle the old issue_indexer configuration
|
||||||
|
section := Cfg.Section("queue.issue_indexer")
|
||||||
|
issueIndexerSectionMap := map[string]string{}
|
||||||
|
for _, key := range section.Keys() {
|
||||||
|
issueIndexerSectionMap[key.Name()] = key.Value()
|
||||||
|
}
|
||||||
|
if _, ok := issueIndexerSectionMap["TYPE"]; !ok {
|
||||||
|
switch Indexer.IssueQueueType {
|
||||||
|
case LevelQueueType:
|
||||||
|
section.Key("TYPE").SetValue("level")
|
||||||
|
case ChannelQueueType:
|
||||||
|
section.Key("TYPE").SetValue("persistable-channel")
|
||||||
|
case RedisQueueType:
|
||||||
|
section.Key("TYPE").SetValue("redis")
|
||||||
|
default:
|
||||||
|
log.Fatal("Unsupported indexer queue type: %v",
|
||||||
|
Indexer.IssueQueueType)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if _, ok := issueIndexerSectionMap["LENGTH"]; !ok {
|
||||||
|
section.Key("LENGTH").SetValue(fmt.Sprintf("%d", Indexer.UpdateQueueLength))
|
||||||
|
}
|
||||||
|
if _, ok := issueIndexerSectionMap["BATCH_LENGTH"]; !ok {
|
||||||
|
section.Key("BATCH_LENGTH").SetValue(fmt.Sprintf("%d", Indexer.IssueQueueBatchNumber))
|
||||||
|
}
|
||||||
|
if _, ok := issueIndexerSectionMap["DATADIR"]; !ok {
|
||||||
|
section.Key("DATADIR").SetValue(Indexer.IssueQueueDir)
|
||||||
|
}
|
||||||
|
if _, ok := issueIndexerSectionMap["CONN_STR"]; !ok {
|
||||||
|
section.Key("CONN_STR").SetValue(Indexer.IssueQueueConnStr)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// ParseQueueConnStr parses a queue connection string
|
// ParseQueueConnStr parses a queue connection string
|
||||||
|
|
Loading…
Reference in a new issue