oc-schedulerd/daemons/execute_monitor_local.go

46 lines
1.1 KiB
Go
Raw Normal View History

2024-07-29 15:46:44 +02:00
package daemons
2024-08-09 18:44:33 +02:00
import (
2024-08-20 15:24:46 +02:00
"fmt"
"oc-schedulerd/conf"
2024-08-09 18:44:33 +02:00
"os/exec"
"github.com/rs/zerolog"
2024-08-09 18:44:33 +02:00
)
2024-07-29 15:46:44 +02:00
type LocalMonitor struct {
2024-10-02 14:38:51 +02:00
LokiURL string
KubeURL string
ExecutionID string
Duration int
Logger zerolog.Logger
2024-07-29 15:46:44 +02:00
}
func (lm *LocalMonitor) LaunchLocalMonitor() {
2024-08-21 14:20:13 +02:00
if lm.LokiURL == "" || lm.KubeURL == "" || lm.ExecutionID == "" {
lm.Logger.Error().Msg("Missing parameter in LocalMonitor")
2024-07-29 15:46:44 +02:00
}
// For dev purposes, in prod KubeURL must be a kube API's URL
2024-08-20 15:24:46 +02:00
if lm.KubeURL != "localhost" {
2024-08-09 18:44:33 +02:00
lm.execRemoteKube()
2024-08-20 15:24:46 +02:00
} else {
lm.execLocalKube()
2024-07-29 15:46:44 +02:00
}
}
func (lm *LocalMonitor) execLocalKube() {
2024-08-28 14:03:48 +02:00
args := []string{"-e", lm.ExecutionID, "-u", lm.LokiURL, "-m", conf.GetConfig().MongoUrl, "-d", conf.GetConfig().DBName}
2024-08-20 16:14:10 +02:00
if lm.Duration > 0 {
args = append(args, "-t", fmt.Sprintf("%d", lm.Duration))
}
cmd := exec.Command(conf.GetConfig().MonitorPath, args...)
err := cmd.Start()
if err != nil {
2024-08-21 14:20:13 +02:00
lm.Logger.Error().Msg("Could not start oc-monitor for " + lm.ExecutionID + " : " + err.Error())
2024-08-09 18:44:33 +02:00
}
2024-07-29 15:46:44 +02:00
}
// TODO : implement this
2024-10-02 14:38:51 +02:00
func (lm *LocalMonitor) execRemoteKube() {}