2026-04-24 21:17:42 -05:00
|
|
|
// Command flock-agent is the per-node DaemonSet binary. It owns IPAM, netns
|
|
|
|
|
// programming, BIRD config, and nftables. M1 boots only the state store and a
|
|
|
|
|
// placeholder unix listener.
|
|
|
|
|
package main
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
"context"
|
|
|
|
|
"flag"
|
|
|
|
|
"log/slog"
|
|
|
|
|
"os"
|
|
|
|
|
"os/signal"
|
|
|
|
|
"syscall"
|
|
|
|
|
|
|
|
|
|
"code.fritzlab.net/fritzlab/flock/pkg/agent"
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
func main() {
|
|
|
|
|
var (
|
2026-04-24 22:00:48 -05:00
|
|
|
node = flag.String("node", os.Getenv("NODE_NAME"), "node name (defaults to $NODE_NAME)")
|
|
|
|
|
statePath = flag.String("state", "/var/lib/flock/allocations.json", "path to allocations.json")
|
|
|
|
|
socket = flag.String("socket", agent.SocketPath, "unix socket for CNI RPC")
|
|
|
|
|
kubeconfig = flag.String("kubeconfig", os.Getenv("KUBECONFIG"), "kubeconfig path (empty = in-cluster)")
|
2026-04-24 21:17:42 -05:00
|
|
|
)
|
|
|
|
|
flag.Parse()
|
|
|
|
|
|
|
|
|
|
logger := slog.New(slog.NewJSONHandler(os.Stderr, &slog.HandlerOptions{Level: slog.LevelInfo}))
|
|
|
|
|
|
|
|
|
|
if *node == "" {
|
|
|
|
|
logger.Error("--node or $NODE_NAME is required")
|
|
|
|
|
os.Exit(2)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
srv, err := agent.NewServer(agent.Config{
|
2026-04-24 22:00:48 -05:00
|
|
|
Node: *node,
|
|
|
|
|
StatePath: *statePath,
|
|
|
|
|
Socket: *socket,
|
|
|
|
|
Logger: logger,
|
|
|
|
|
Kubeconfig: *kubeconfig,
|
2026-04-24 21:17:42 -05:00
|
|
|
})
|
|
|
|
|
if err != nil {
|
|
|
|
|
logger.Error("init server", "err", err)
|
|
|
|
|
os.Exit(1)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
ctx, cancel := signal.NotifyContext(context.Background(), syscall.SIGINT, syscall.SIGTERM)
|
|
|
|
|
defer cancel()
|
|
|
|
|
|
|
|
|
|
if err := srv.Run(ctx); err != nil {
|
|
|
|
|
logger.Error("run", "err", err)
|
|
|
|
|
os.Exit(1)
|
|
|
|
|
}
|
|
|
|
|
}
|