/
agent.go
83 lines (75 loc) · 2.55 KB
/
agent.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
package commands
import (
"github.com/cobalt77/kubecc/internal/logkc"
"github.com/cobalt77/kubecc/internal/sleep"
sleeptoolchain "github.com/cobalt77/kubecc/internal/sleep/toolchain"
"github.com/cobalt77/kubecc/pkg/apps/agent"
"github.com/cobalt77/kubecc/pkg/cc"
cctoolchain "github.com/cobalt77/kubecc/pkg/cc/toolchain"
"github.com/cobalt77/kubecc/pkg/config"
"github.com/cobalt77/kubecc/pkg/host"
"github.com/cobalt77/kubecc/pkg/identity"
"github.com/cobalt77/kubecc/pkg/meta"
"github.com/cobalt77/kubecc/pkg/metrics"
"github.com/cobalt77/kubecc/pkg/servers"
"github.com/cobalt77/kubecc/pkg/toolchains"
"github.com/cobalt77/kubecc/pkg/tracing"
"github.com/cobalt77/kubecc/pkg/types"
"github.com/spf13/cobra"
"go.uber.org/zap"
_ "google.golang.org/grpc/encoding/gzip"
)
func run(cmd *cobra.Command, args []string) {
conf := (&config.ConfigMapProvider{}).Load().Agent
ctx := meta.NewContext(
meta.WithProvider(identity.Component, meta.WithValue(types.Agent)),
meta.WithProvider(identity.UUID),
meta.WithProvider(logkc.Logger, meta.WithValue(
logkc.New(
types.Agent,
logkc.WithLogLevel(conf.LogLevel.Level()),
),
)),
meta.WithProvider(tracing.Tracer),
meta.WithProvider(host.SystemInfo),
)
lg := meta.Log(ctx)
schedulerCC, err := servers.Dial(ctx, conf.SchedulerAddress)
lg.With("address", schedulerCC.Target()).Info("Dialing scheduler")
if err != nil {
lg.With(zap.Error(err)).Fatal("Error dialing scheduler")
}
monitorCC, err := servers.Dial(ctx, conf.MonitorAddress)
lg.With("address", monitorCC.Target()).Info("Dialing monitor")
if err != nil {
lg.With(zap.Error(err)).Fatal("Error dialing monitor")
}
schedulerClient := types.NewSchedulerClient(schedulerCC)
monitorClient := types.NewMonitorClient(monitorCC)
a := agent.NewAgentServer(ctx,
agent.WithUsageLimits(&metrics.UsageLimits{
ConcurrentProcessLimit: int32(conf.UsageLimits.ConcurrentProcessLimit),
QueuePressureMultiplier: conf.UsageLimits.QueuePressureMultiplier,
QueueRejectMultiplier: conf.UsageLimits.QueueRejectMultiplier,
}),
agent.WithToolchainFinders(
toolchains.FinderWithOptions{
Finder: cc.CCFinder{},
},
toolchains.FinderWithOptions{
Finder: sleep.SleepToolchainFinder{},
},
),
agent.WithToolchainRunners(cctoolchain.AddToStore, sleeptoolchain.AddToStore),
agent.WithSchedulerClient(schedulerClient),
agent.WithMonitorClient(monitorClient),
)
go a.StartMetricsProvider()
mgr := servers.NewStreamManager(ctx, a)
mgr.Run()
}
var Command = &cobra.Command{
Use: "agent",
Short: "Run the agent service",
Run: run,
}