|
| 1 | +/* |
| 2 | +Copyright 2025 The Kubernetes Authors. |
| 3 | +
|
| 4 | +Licensed under the Apache License, Version 2.0 (the "License"); |
| 5 | +you may not use this file except in compliance with the License. |
| 6 | +You may obtain a copy of the License at |
| 7 | +
|
| 8 | + http://www.apache.org/licenses/LICENSE-2.0 |
| 9 | +
|
| 10 | +Unless required by applicable law or agreed to in writing, software |
| 11 | +distributed under the License is distributed on an "AS IS" BASIS, |
| 12 | +WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| 13 | +See the License for the specific language governing permissions and |
| 14 | +limitations under the License. |
| 15 | +*/ |
| 16 | + |
| 17 | +package main |
| 18 | + |
| 19 | +import ( |
| 20 | + "flag" |
| 21 | + "os" |
| 22 | + |
| 23 | + "github.com/go-logr/logr" |
| 24 | + uberzap "go.uber.org/zap" |
| 25 | + "google.golang.org/grpc" |
| 26 | + healthPb "google.golang.org/grpc/health/grpc_health_v1" |
| 27 | + ctrl "sigs.k8s.io/controller-runtime" |
| 28 | + "sigs.k8s.io/controller-runtime/pkg/log/zap" |
| 29 | + "sigs.k8s.io/controller-runtime/pkg/manager" |
| 30 | + "sigs.k8s.io/gateway-api-inference-extension/internal/runnable" |
| 31 | + runserver "sigs.k8s.io/gateway-api-inference-extension/pkg/body-based-routing/server" |
| 32 | +) |
| 33 | + |
| 34 | +var ( |
| 35 | + grpcPort = flag.Int( |
| 36 | + "grpcPort", |
| 37 | + runserver.DefaultGrpcPort, |
| 38 | + "The gRPC port used for communicating with Envoy proxy") |
| 39 | + grpcHealthPort = flag.Int( |
| 40 | + "grpcHealthPort", |
| 41 | + 9003, |
| 42 | + "The port used for gRPC liveness and readiness probes") |
| 43 | + |
| 44 | + setupLog = ctrl.Log.WithName("setup") |
| 45 | +) |
| 46 | + |
| 47 | +func main() { |
| 48 | + if err := run(); err != nil { |
| 49 | + os.Exit(1) |
| 50 | + } |
| 51 | +} |
| 52 | + |
| 53 | +func run() error { |
| 54 | + opts := zap.Options{Development: true} |
| 55 | + opts.BindFlags(flag.CommandLine) |
| 56 | + flag.Parse() |
| 57 | + initLogging(&opts) |
| 58 | + |
| 59 | + // Print all flag values |
| 60 | + flags := make(map[string]any) |
| 61 | + flag.VisitAll(func(f *flag.Flag) { |
| 62 | + flags[f.Name] = f.Value |
| 63 | + }) |
| 64 | + setupLog.Info("Flags processed", "flags", flags) |
| 65 | + |
| 66 | + // Init runtime. |
| 67 | + cfg, err := ctrl.GetConfig() |
| 68 | + if err != nil { |
| 69 | + setupLog.Error(err, "Failed to get rest config") |
| 70 | + return err |
| 71 | + } |
| 72 | + |
| 73 | + mgr, err := ctrl.NewManager(cfg, ctrl.Options{}) |
| 74 | + if err != nil { |
| 75 | + setupLog.Error(err, "Failed to create manager", "config", cfg) |
| 76 | + return err |
| 77 | + } |
| 78 | + |
| 79 | + ctx := ctrl.SetupSignalHandler() |
| 80 | + |
| 81 | + // Setup runner. |
| 82 | + serverRunner := &runserver.ExtProcServerRunner{GrpcPort: *grpcPort} |
| 83 | + |
| 84 | + // Register health server. |
| 85 | + if err := registerHealthServer(mgr, ctrl.Log.WithName("health"), *grpcHealthPort); err != nil { |
| 86 | + return err |
| 87 | + } |
| 88 | + |
| 89 | + // Register ext-proc server. |
| 90 | + if err := mgr.Add(serverRunner.AsRunnable(ctrl.Log.WithName("ext-proc"))); err != nil { |
| 91 | + setupLog.Error(err, "Failed to register ext-proc gRPC server") |
| 92 | + return err |
| 93 | + } |
| 94 | + |
| 95 | + // Start the manager. This blocks until a signal is received. |
| 96 | + setupLog.Info("Manager starting") |
| 97 | + if err := mgr.Start(ctx); err != nil { |
| 98 | + setupLog.Error(err, "Error starting manager") |
| 99 | + return err |
| 100 | + } |
| 101 | + setupLog.Info("Manager terminated") |
| 102 | + return nil |
| 103 | +} |
| 104 | + |
| 105 | +// registerHealthServer adds the Health gRPC server as a Runnable to the given manager. |
| 106 | +func registerHealthServer(mgr manager.Manager, logger logr.Logger, port int) error { |
| 107 | + srv := grpc.NewServer() |
| 108 | + healthPb.RegisterHealthServer(srv, &healthServer{ |
| 109 | + logger: logger, |
| 110 | + }) |
| 111 | + if err := mgr.Add( |
| 112 | + runnable.NoLeaderElection(runnable.GRPCServer("health", srv, port))); err != nil { |
| 113 | + setupLog.Error(err, "Failed to register health server") |
| 114 | + return err |
| 115 | + } |
| 116 | + return nil |
| 117 | +} |
| 118 | + |
| 119 | +func initLogging(opts *zap.Options) { |
| 120 | + logger := zap.New(zap.UseFlagOptions(opts), zap.RawZapOpts(uberzap.AddCaller())) |
| 121 | + ctrl.SetLogger(logger) |
| 122 | +} |
0 commit comments