mirror of
https://github.com/mudler/LocalAI.git
synced 2026-04-02 06:04:09 -04:00
* feat: add distributed mode (experimental) Signed-off-by: Ettore Di Giacinto <mudler@localai.io> * fix data races, mutexes, transactions Signed-off-by: Ettore Di Giacinto <mudler@localai.io> * refactorings Signed-off-by: Ettore Di Giacinto <mudler@localai.io> * fixups Signed-off-by: Ettore Di Giacinto <mudler@localai.io> * fix events and tool stream in agent chat Signed-off-by: Ettore Di Giacinto <mudler@localai.io> * use ginkgo Signed-off-by: Ettore Di Giacinto <mudler@localai.io> * refactoring and consolidation Signed-off-by: Ettore Di Giacinto <mudler@localai.io> * refactoring and consolidation Signed-off-by: Ettore Di Giacinto <mudler@localai.io> * refactoring and consolidation Signed-off-by: Ettore Di Giacinto <mudler@localai.io> * refactoring and consolidation Signed-off-by: Ettore Di Giacinto <mudler@localai.io> * refactoring and consolidation Signed-off-by: Ettore Di Giacinto <mudler@localai.io> * refactoring and consolidation Signed-off-by: Ettore Di Giacinto <mudler@localai.io> * refactoring and consolidation Signed-off-by: Ettore Di Giacinto <mudler@localai.io> * refactoring and consolidation Signed-off-by: Ettore Di Giacinto <mudler@localai.io> * fix(cron): compute correctly time boundaries avoiding re-triggering Signed-off-by: Ettore Di Giacinto <mudler@localai.io> * enhancements, refactorings Signed-off-by: Ettore Di Giacinto <mudler@localai.io> * do not flood of healthy checks Signed-off-by: Ettore Di Giacinto <mudler@localai.io> * do not list obvious backends as text backends Signed-off-by: Ettore Di Giacinto <mudler@localai.io> * tests fixups Signed-off-by: Ettore Di Giacinto <mudler@localai.io> * refactoring and consolidation Signed-off-by: Ettore Di Giacinto <mudler@localai.io> * Drop redundant healthcheck Signed-off-by: Ettore Di Giacinto <mudler@localai.io> * enhancements, refactorings Signed-off-by: Ettore Di Giacinto <mudler@localai.io> --------- Signed-off-by: Ettore Di Giacinto <mudler@localai.io>
53 lines
1.3 KiB
Go
53 lines
1.3 KiB
Go
package application
|
|
|
|
import (
|
|
"time"
|
|
|
|
"github.com/mudler/LocalAI/core/services/agentpool"
|
|
"github.com/mudler/xlog"
|
|
)
|
|
|
|
// RestartAgentJobService restarts the agent job service with current ApplicationConfig settings
|
|
func (a *Application) RestartAgentJobService() error {
|
|
a.agentJobMutex.Lock()
|
|
defer a.agentJobMutex.Unlock()
|
|
|
|
// Stop existing service if running
|
|
if a.agentJobService != nil {
|
|
if err := a.agentJobService.Stop(); err != nil {
|
|
xlog.Warn("Error stopping agent job service", "error", err)
|
|
}
|
|
// Wait a bit for shutdown to complete
|
|
time.Sleep(200 * time.Millisecond)
|
|
}
|
|
|
|
// Create new service instance
|
|
agentJobService := agentpool.NewAgentJobService(
|
|
a.ApplicationConfig(),
|
|
a.ModelLoader(),
|
|
a.ModelConfigLoader(),
|
|
a.TemplatesEvaluator(),
|
|
)
|
|
|
|
// Re-apply distributed wiring if available (matches startup.go logic)
|
|
if d := a.Distributed(); d != nil {
|
|
if d.Dispatcher != nil {
|
|
agentJobService.SetDistributedBackends(d.Dispatcher)
|
|
}
|
|
if d.JobStore != nil {
|
|
agentJobService.SetDistributedJobStore(d.JobStore)
|
|
}
|
|
}
|
|
|
|
// Start the service
|
|
err := agentJobService.Start(a.ApplicationConfig().Context)
|
|
if err != nil {
|
|
xlog.Error("Failed to start agent job service", "error", err)
|
|
return err
|
|
}
|
|
|
|
a.agentJobService = agentJobService
|
|
xlog.Info("Agent job service restarted")
|
|
return nil
|
|
}
|