mirror of
https://github.com/mudler/LocalAI.git
synced 2025-06-02 00:44:59 +00:00
feat(explorer): make possible to run sync in a separate process (#3224)
Signed-off-by: Ettore Di Giacinto <mudler@localai.io>
This commit is contained in:
parent
4dfa085339
commit
9729d2ae37
9 changed files with 83 additions and 67 deletions
|
@ -16,22 +16,10 @@ import (
|
|||
type DiscoveryServer struct {
|
||||
sync.Mutex
|
||||
database *Database
|
||||
networkState *NetworkState
|
||||
connectionTime time.Duration
|
||||
failures map[string]int
|
||||
errorThreshold int
|
||||
}
|
||||
|
||||
type NetworkState struct {
|
||||
Networks map[string]Network
|
||||
}
|
||||
|
||||
func (s *DiscoveryServer) NetworkState() *NetworkState {
|
||||
s.Lock()
|
||||
defer s.Unlock()
|
||||
return s.networkState
|
||||
}
|
||||
|
||||
// NewDiscoveryServer creates a new DiscoveryServer with the given Database.
|
||||
// it keeps the db state in sync with the network state
|
||||
func NewDiscoveryServer(db *Database, dur time.Duration, failureThreshold int) *DiscoveryServer {
|
||||
|
@ -44,11 +32,7 @@ func NewDiscoveryServer(db *Database, dur time.Duration, failureThreshold int) *
|
|||
return &DiscoveryServer{
|
||||
database: db,
|
||||
connectionTime: dur,
|
||||
networkState: &NetworkState{
|
||||
Networks: map[string]Network{},
|
||||
},
|
||||
errorThreshold: failureThreshold,
|
||||
failures: make(map[string]int),
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -116,10 +100,10 @@ func (s *DiscoveryServer) runBackground() {
|
|||
|
||||
if hasWorkers {
|
||||
s.Lock()
|
||||
s.networkState.Networks[token] = Network{
|
||||
Clusters: ledgerK,
|
||||
}
|
||||
delete(s.failures, token)
|
||||
data, _ := s.database.Get(token)
|
||||
(&data).Clusters = ledgerK
|
||||
(&data).Failures = 0
|
||||
s.database.Set(token, data)
|
||||
s.Unlock()
|
||||
} else {
|
||||
s.failedToken(token)
|
||||
|
@ -132,27 +116,23 @@ func (s *DiscoveryServer) runBackground() {
|
|||
func (s *DiscoveryServer) failedToken(token string) {
|
||||
s.Lock()
|
||||
defer s.Unlock()
|
||||
s.failures[token]++
|
||||
data, _ := s.database.Get(token)
|
||||
(&data).Failures++
|
||||
s.database.Set(token, data)
|
||||
}
|
||||
|
||||
func (s *DiscoveryServer) deleteFailedConnections() {
|
||||
s.Lock()
|
||||
defer s.Unlock()
|
||||
for k, v := range s.failures {
|
||||
if v > s.errorThreshold {
|
||||
log.Info().Any("network", k).Msg("Network has been removed from the database")
|
||||
s.database.Delete(k)
|
||||
delete(s.failures, k)
|
||||
for _, t := range s.database.TokenList() {
|
||||
data, _ := s.database.Get(t)
|
||||
if data.Failures > s.errorThreshold {
|
||||
log.Info().Any("token", t).Msg("Token has been removed from the database")
|
||||
s.database.Delete(t)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
type ClusterData struct {
|
||||
Workers []string
|
||||
Type string
|
||||
NetworkID string
|
||||
}
|
||||
|
||||
func (s *DiscoveryServer) retrieveNetworkData(c context.Context, ledger *blockchain.Ledger, networkData chan ClusterData) {
|
||||
clusters := map[string]ClusterData{}
|
||||
|
||||
|
@ -217,7 +197,7 @@ func (s *DiscoveryServer) retrieveNetworkData(c context.Context, ledger *blockch
|
|||
}
|
||||
|
||||
// Start the discovery server. This is meant to be run in to a goroutine.
|
||||
func (s *DiscoveryServer) Start(ctx context.Context) error {
|
||||
func (s *DiscoveryServer) Start(ctx context.Context, keepRunning bool) error {
|
||||
for {
|
||||
select {
|
||||
case <-ctx.Done():
|
||||
|
@ -225,6 +205,9 @@ func (s *DiscoveryServer) Start(ctx context.Context) error {
|
|||
default:
|
||||
// Collect data
|
||||
s.runBackground()
|
||||
if !keepRunning {
|
||||
return nil
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue