From db645d477fc80dbe71342da6e73cd4644054feef Mon Sep 17 00:00:00 2001 From: Billy McFall <22157057+Billy99@users.noreply.github.com> Date: Fri, 1 Nov 2024 16:12:44 -0400 Subject: [PATCH] logs: simplify the bpfman-agent logs As part of a security review which required extend logging behaviour, investigated improving the logs. Moved the logs from using context, which prints a lot if useless info, to just using regular logs. Signed-off-by: Billy McFall <22157057+Billy99@users.noreply.github.com> --- ...bpfman-operator.clusterserviceversion.yaml | 4 +- .../deployment.yaml | 2 +- .../bpfman-agent/application-program.go | 20 +++-- controllers/bpfman-agent/common.go | 76 +++++++++---------- controllers/bpfman-agent/fentry-program.go | 4 +- controllers/bpfman-agent/fexit-program.go | 4 +- controllers/bpfman-agent/kprobe-program.go | 4 +- controllers/bpfman-agent/tc-program.go | 4 +- controllers/bpfman-agent/tcx-program.go | 5 +- .../bpfman-agent/tracepoint-program.go | 4 +- controllers/bpfman-agent/uprobe-program.go | 4 +- controllers/bpfman-agent/xdp-program.go | 4 +- .../bpfman-operator/application-programs.go | 4 +- controllers/bpfman-operator/common.go | 8 +- controllers/bpfman-operator/configmap.go | 3 +- controllers/bpfman-operator/fentry-program.go | 4 +- controllers/bpfman-operator/fexit-program.go | 4 +- controllers/bpfman-operator/kprobe-program.go | 4 +- controllers/bpfman-operator/tc-program.go | 4 +- controllers/bpfman-operator/tcx-program.go | 4 +- .../bpfman-operator/tracepoint-program.go | 4 +- controllers/bpfman-operator/uprobe-program.go | 4 +- controllers/bpfman-operator/xdp-program.go | 4 +- 23 files changed, 84 insertions(+), 98 deletions(-) diff --git a/bundle/manifests/bpfman-operator.clusterserviceversion.yaml b/bundle/manifests/bpfman-operator.clusterserviceversion.yaml index 59339fa32..4e5708825 100644 --- a/bundle/manifests/bpfman-operator.clusterserviceversion.yaml +++ b/bundle/manifests/bpfman-operator.clusterserviceversion.yaml @@ -307,7 +307,7 @@ metadata: capabilities: Basic Install categories: OpenShift Optional containerImage: quay.io/bpfman/bpfman-operator:latest - createdAt: "2024-10-21T11:51:40Z" + createdAt: "2024-11-01T20:38:03Z" features.operators.openshift.io/cnf: "false" features.operators.openshift.io/cni: "false" features.operators.openshift.io/csi: "true" @@ -1102,7 +1102,7 @@ spec: - /bpfman-operator env: - name: GO_LOG - value: debug + value: info image: quay.io/bpfman/bpfman-operator:latest imagePullPolicy: IfNotPresent livenessProbe: diff --git a/config/bpfman-operator-deployment/deployment.yaml b/config/bpfman-operator-deployment/deployment.yaml index a8dbc0100..0eefab8da 100644 --- a/config/bpfman-operator-deployment/deployment.yaml +++ b/config/bpfman-operator-deployment/deployment.yaml @@ -74,7 +74,7 @@ spec: imagePullPolicy: IfNotPresent env: - name: GO_LOG - value: debug + value: info name: bpfman-operator securityContext: allowPrivilegeEscalation: false diff --git a/controllers/bpfman-agent/application-program.go b/controllers/bpfman-agent/application-program.go index 08d2dea64..ac5b019ef 100644 --- a/controllers/bpfman-agent/application-program.go +++ b/controllers/bpfman-agent/application-program.go @@ -15,7 +15,6 @@ import ( "sigs.k8s.io/controller-runtime/pkg/builder" "sigs.k8s.io/controller-runtime/pkg/client" "sigs.k8s.io/controller-runtime/pkg/handler" - "sigs.k8s.io/controller-runtime/pkg/log" "sigs.k8s.io/controller-runtime/pkg/predicate" ) @@ -40,8 +39,7 @@ func (r *BpfApplicationReconciler) Reconcile(ctx context.Context, req ctrl.Reque r.finalizer = internal.BpfApplicationControllerFinalizer r.recType = internal.ApplicationString - ctxLogger := log.FromContext(ctx) - ctxLogger.Info("Reconcile Application: Enter", "ReconcileKey", req) + r.Logger.Info("bpfman-agent enter: application", "Name", req.Name) // Lookup K8s node object for this bpfman-agent This should always succeed if err := r.Get(ctx, types.NamespacedName{Namespace: v1.NamespaceAll, Name: r.NodeName}, r.ourNode); err != nil { @@ -192,7 +190,7 @@ func (r *BpfApplicationReconciler) Reconcile(ctx context.Context, req ctrl.Reque case bpfmaniov1alpha1.ProgTypeTC: _, ifErr := getInterfaces(&p.TC.InterfaceSelector, r.ourNode) if ifErr != nil { - ctxLogger.Error(ifErr, "failed to get interfaces for TC Program", + r.Logger.Error(ifErr, "failed to get interfaces for TC Program", "app program name", a.Name, "program index", j) continue } @@ -220,7 +218,7 @@ func (r *BpfApplicationReconciler) Reconcile(ctx context.Context, req ctrl.Reque case bpfmaniov1alpha1.ProgTypeTCX: _, ifErr := getInterfaces(&p.TCX.InterfaceSelector, r.ourNode) if ifErr != nil { - ctxLogger.Error(ifErr, "failed to get interfaces for TCX Program", + r.Logger.Error(ifErr, "failed to get interfaces for TCX Program", "app program name", a.Name, "program index", j) continue } @@ -248,7 +246,7 @@ func (r *BpfApplicationReconciler) Reconcile(ctx context.Context, req ctrl.Reque case bpfmaniov1alpha1.ProgTypeXDP: _, ifErr := getInterfaces(&p.XDP.InterfaceSelector, r.ourNode) if ifErr != nil { - ctxLogger.Error(ifErr, "failed to get interfaces for XDP Program", + r.Logger.Error(ifErr, "failed to get interfaces for XDP Program", "app program name", a.Name, "program index", j) continue } @@ -274,12 +272,12 @@ func (r *BpfApplicationReconciler) Reconcile(ctx context.Context, req ctrl.Reque complete, res, err = r.reconcileCommon(ctx, rec, xdpObjects) default: - ctxLogger.Error(fmt.Errorf("unsupported bpf program type"), "unsupported bpf program type", "ProgType", p.Type) + r.Logger.Error(fmt.Errorf("unsupported bpf program type"), "unsupported bpf program type", "ProgType", p.Type) // Skip this program and continue to the next one continue } - ctxLogger.V(1).Info("Reconcile Application", "Application", i, "Program", j, "Name", a.Name, + r.Logger.V(1).Info("Reconcile Application", "Application", i, "Program", j, "Name", a.Name, "type", p.Type, "Complete", complete, "Result", res, "Error", err) if complete { @@ -296,20 +294,20 @@ func (r *BpfApplicationReconciler) Reconcile(ctx context.Context, req ctrl.Reque // find programs that need to be deleted and delete them opts := []client.ListOption{client.MatchingLabels{internal.BpfProgramOwner: a.Name}} if err := r.List(ctx, bpfPrograms, opts...); err != nil { - ctxLogger.Error(err, "failed to get freshPrograms for full reconcile") + r.Logger.Error(err, "failed to get freshPrograms for full reconcile") return ctrl.Result{}, err } for _, bpfProgram := range bpfPrograms.Items { id := bpfProgram.Labels[internal.AppProgramId] if _, ok := appProgramMap[id]; !ok { - ctxLogger.Info("Deleting BpfProgram", "AppProgramId", id, "BpfProgram", bpfProgram.Name) + r.Logger.Info("Deleting BpfProgram", "AppProgramId", id, "BpfProgram", bpfProgram.Name) bpfDeletedPrograms.Items = append(bpfDeletedPrograms.Items, bpfProgram) } } // Delete BpfPrograms that are no longer needed res, err = r.unLoadAndDeleteBpfProgramsList(ctx, bpfDeletedPrograms, internal.BpfApplicationControllerFinalizer) if err != nil { - ctxLogger.Error(err, "failed to delete programs") + r.Logger.Error(err, "failed to delete programs") return ctrl.Result{}, err } // We've completed reconciling all programs for this application, continue to the next one diff --git a/controllers/bpfman-agent/common.go b/controllers/bpfman-agent/common.go index bd1d69ed9..e60ddeecf 100644 --- a/controllers/bpfman-agent/common.go +++ b/controllers/bpfman-agent/common.go @@ -167,7 +167,7 @@ func (r *ReconcilerCommon) reconcileCommon(ctx context.Context, rec bpfmanReconc result, err := r.reconcileProgram(ctx, rec, program, loadedBpfPrograms) if err != nil { - r.Logger.Error(err, "Reconciling program failed", "Program Name", rec.getName, "ReconcileResult", result.String()) + r.Logger.Error(err, "Reconciling program failed", "Name", rec.getName, "ReconcileResult", result.String()) } switch result { @@ -202,7 +202,7 @@ func (r *ReconcilerCommon) reconcileBpfProgram(ctx context.Context, isBeingDeleted bool, mapOwnerStatus *MapOwnerParamStatus) (bpfmaniov1alpha1.BpfProgramConditionType, error) { - r.Logger.V(1).Info("enter reconcileBpfmanProgram()", "bpfProgram", bpfProgram.Name, "CurrentProgram", rec.getName()) + r.Logger.V(1).Info("enter reconcileBpfmanProgram()", "Name", bpfProgram.Name, "CurrentProgram", rec.getName()) uuid := bpfProgram.UID noContainersOnNode := noContainersOnNode(bpfProgram) @@ -216,7 +216,7 @@ func (r *ReconcilerCommon) reconcileBpfProgram(ctx context.Context, // prog ID should already have been set if program is loaded id, err := bpfmanagentinternal.GetID(bpfProgram) if err != nil { - r.Logger.Error(err, "Failed to get bpf program ID") + r.Logger.Error(err, "Failed to get kernel ID for BpfProgram") return bpfmaniov1alpha1.BpfProgCondNotLoaded, err } switch shouldBeLoaded { @@ -229,28 +229,28 @@ func (r *ReconcilerCommon) reconcileBpfProgram(ctx context.Context, } isSame, reasons := bpfmanagentinternal.DoesProgExist(loadedBpfProgram, loadRequest) if !isSame { - r.Logger.V(1).Info("bpf program is in wrong state, unloading and reloading", "reason", reasons, "bpfProgram Name", bpfProgram.Name, "bpf program ID", id) + r.Logger.Info("BpfProgram is in wrong state, unloading and reloading", "reason", reasons, "Name", bpfProgram.Name, "Program ID", id) if err := bpfmanagentinternal.UnloadBpfmanProgram(ctx, r.BpfmanClient, *id); err != nil { - r.Logger.Error(err, "Failed to unload BPF Program") + r.Logger.Error(err, "Failed to unload eBPF Program") return bpfmaniov1alpha1.BpfProgCondNotUnloaded, err } - r.Logger.Info("Calling bpfman to load bpf program on Node", "bpfProgram Name", bpfProgram.Name) + r.Logger.Info("Calling bpfman to load eBPF Program on Node", "Name", bpfProgram.Name) r.progId, err = bpfmanagentinternal.LoadBpfmanProgram(ctx, r.BpfmanClient, loadRequest) if err != nil { - r.Logger.Error(err, "Failed to load bpf program") + r.Logger.Error(err, "Failed to load eBPF Program") return bpfmaniov1alpha1.BpfProgCondNotLoaded, err } } else { // Program exists and bpfProgram K8s Object is up to date - r.Logger.V(1).Info("Program is in correct state. Nothing to do in bpfman") + r.Logger.V(1).Info("BpfProgram is in correct state. Nothing to do in bpfman") r.progId = id } case false: // The program is loaded but it shouldn't be loaded. - r.Logger.Info("Calling bpfman to unload program on node", "bpfProgram Name", bpfProgram.Name, "Program ID", id) + r.Logger.Info("Calling bpfman to unload eBPF Program on node", "Name", bpfProgram.Name, "Program ID", id) if err := bpfmanagentinternal.UnloadBpfmanProgram(ctx, r.BpfmanClient, *id); err != nil { - r.Logger.Error(err, "Failed to unload Program") + r.Logger.Error(err, "Failed to unload eBPF Program") return bpfmaniov1alpha1.BpfProgCondNotUnloaded, err } } @@ -263,10 +263,10 @@ func (r *ReconcilerCommon) reconcileBpfProgram(ctx context.Context, return bpfmaniov1alpha1.BpfProgCondBytecodeSelectorError, err } - r.Logger.Info("Calling bpfman to load program on node", "bpfProgram name", bpfProgram.Name) + r.Logger.Info("Calling bpfman to load eBPF Program on node", "Name", bpfProgram.Name) r.progId, err = bpfmanagentinternal.LoadBpfmanProgram(ctx, r.BpfmanClient, loadRequest) if err != nil { - r.Logger.Error(err, "Failed to load Program") + r.Logger.Error(err, "Failed to load eBPF Program") return bpfmaniov1alpha1.BpfProgCondNotLoaded, err } case false: @@ -454,10 +454,10 @@ func getInterfaces(interfaceSelector *bpfmaniov1alpha1.InterfaceSelector, ourNod func (r *ReconcilerCommon) removeFinalizer(ctx context.Context, o client.Object, finalizer string) bool { changed := controllerutil.RemoveFinalizer(o, finalizer) if changed { - r.Logger.Info("Removing finalizer from bpfProgram", "object name", o.GetName()) + r.Logger.Info("Calling KubeAPI to remove finalizer from BpfProgram", "object name", o.GetName()) err := r.Update(ctx, o) if err != nil { - r.Logger.Error(err, "failed to remove bpfProgram Finalizer") + r.Logger.Error(err, "failed to remove BpfProgram Finalizer") return true } } @@ -496,9 +496,9 @@ func (r *ReconcilerCommon) updateStatus(ctx context.Context, bpfProgram *bpfmani meta.SetStatusCondition(&bpfProgram.Status.Conditions, cond.Condition()) - r.Logger.V(1).Info("Updating bpfProgram condition", "bpfProgram", bpfProgram.Name, "condition", cond.Condition().Type) + r.Logger.Info("Calling KubeAPI to update BpfProgram condition", "Name", bpfProgram.Name, "condition", cond.Condition().Type) if err := r.Status().Update(ctx, bpfProgram); err != nil { - r.Logger.Error(err, "failed to set bpfProgram object status") + r.Logger.Error(err, "failed to set BpfProgram object status") } r.Logger.V(1).Info("condition updated", "new condition", cond) @@ -589,7 +589,7 @@ func (r *ReconcilerCommon) createBpfProgram( // Make the corresponding BpfProgramConfig the owner if err := ctrl.SetControllerReference(rec.getOwner(), bpfProg, r.Scheme); err != nil { - return nil, fmt.Errorf("failed to bpfProgram object owner reference: %v", err) + return nil, fmt.Errorf("failed to set BpfProgram object owner reference: %v", err) } return bpfProg, nil @@ -624,7 +624,7 @@ func (r *ReconcilerCommon) handleProgDelete( r.Logger.V(1).Info("handleProgDelete()", "isBeingDeleted", isBeingDeleted, "isNodeSelected", isNodeSelected, "mapOwnerStatus", mapOwnerStatus) for _, bpfProgram := range existingBpfPrograms { - r.Logger.V(1).Info("Deleting bpfProgram", "Name", bpfProgram.Name) + r.Logger.V(1).Info("Deleting BpfProgram", "Name", bpfProgram.Name) // Reconcile the bpfProgram if error write condition and exit with // retry. cond, err := r.reconcileBpfProgram(ctx, @@ -637,7 +637,7 @@ func (r *ReconcilerCommon) handleProgDelete( ) if err != nil { r.updateStatus(ctx, &bpfProgram, cond) - return internal.Requeue, fmt.Errorf("failed to delete bpfman program: %v", err) + return internal.Requeue, fmt.Errorf("failed to delete program from bpfman: %v", err) } if r.removeFinalizer(ctx, &bpfProgram, rec.getFinalizer()) { @@ -656,16 +656,16 @@ func (r *ReconcilerCommon) handleProgDelete( // to changes that caused the containers to not be selected anymore. // So, explicitly delete them. opts := client.DeleteOptions{} - r.Logger.Info("Deleting bpfProgram", "Name", bpfProgram.Name, "Owner", bpfProgram.GetName()) + r.Logger.Info("Calling KubeAPI to delete BpfProgram", "Name", bpfProgram.Name, "Owner", bpfProgram.GetName()) if err := r.Delete(ctx, &bpfProgram, &opts); err != nil { - return internal.Requeue, fmt.Errorf("failed to delete bpfProgram object: %v", err) + return internal.Requeue, fmt.Errorf("failed to delete BpfProgram object: %v", err) } return internal.Updated, nil } } // We're done reconciling. - r.Logger.Info("Finished reconciling", "program name", rec.getName()) + r.Logger.Info("No change in status", "Name", rec.getName()) return internal.Unchanged, nil } @@ -674,20 +674,20 @@ func (r *ReconcilerCommon) handleProgDelete( // has changed such that the BpfPrograms are no longer needed. func (r *ReconcilerCommon) unLoadAndDeleteBpfProgramsList(ctx context.Context, bpfProgramsList *bpfmaniov1alpha1.BpfProgramList, finalizerString string) (reconcile.Result, error) { for _, bpfProgram := range bpfProgramsList.Items { - r.Logger.V(1).Info("Deleting bpfProgram", "Name", bpfProgram.Name) + r.Logger.V(1).Info("Deleting BpfProgram", "Name", bpfProgram.Name) id, err := bpfmanagentinternal.GetID(&bpfProgram) if err != nil { - r.Logger.Error(err, "Failed to get bpf program ID") + r.Logger.Error(err, "Failed to get kernel ID from BpfProgram") return ctrl.Result{}, nil } if id != nil && !statusContains(&bpfProgram, bpfmaniov1alpha1.BpfProgCondUnloaded) { - r.Logger.Info("Calling bpfman to unload program on node", "bpfProgram Name", bpfProgram.Name, "Program ID", id) + r.Logger.Info("Calling bpfman to unload program on node", "Name", bpfProgram.Name, "Program ID", id) if err := bpfmanagentinternal.UnloadBpfmanProgram(ctx, r.BpfmanClient, *id); err != nil { if strings.Contains(err.Error(), programDoesNotExistErr) { - r.Logger.Info("Program not found on node", "bpfProgram Name", bpfProgram.Name, "Program ID", id) + r.Logger.Info("Program not found on node", "Name", bpfProgram.Name, "Program ID", id) } else { - r.Logger.Error(err, "Failed to unload Program") + r.Logger.Error(err, "Failed to unload Program from bpfman") return ctrl.Result{RequeueAfter: retryDurationAgent}, nil } if r.updateStatus(ctx, &bpfProgram, bpfmaniov1alpha1.BpfProgCondUnloaded) { @@ -705,9 +705,9 @@ func (r *ReconcilerCommon) unLoadAndDeleteBpfProgramsList(ctx context.Context, b } opts := client.DeleteOptions{} - r.Logger.Info("Deleting bpfProgram", "Name", bpfProgram.Name, "Owner", bpfProgram.GetName()) + r.Logger.Info("Calling KubeAPI to delete BpfProgram", "Name", bpfProgram.Name, "Owner", bpfProgram.GetName()) if err := r.Delete(ctx, &bpfProgram, &opts); err != nil { - return ctrl.Result{RequeueAfter: retryDurationAgent}, fmt.Errorf("failed to delete bpfProgram object: %v", err) + return ctrl.Result{RequeueAfter: retryDurationAgent}, fmt.Errorf("failed to delete BpfProgram object: %v", err) } else { // we will deal one program at a time, so we can break out of the loop break @@ -748,9 +748,9 @@ func (r *ReconcilerCommon) handleProgCreateOrUpdate( } else { // Create a new bpfProgram Object for this program. opts := client.CreateOptions{} - r.Logger.Info("Creating bpfProgram", "Name", expectedBpfProgram.Name, "Owner", rec.getOwner().GetName()) + r.Logger.Info("Calling KubeAPI to create BpfProgram", "Name", expectedBpfProgram.Name, "Owner", rec.getOwner().GetName()) if err := r.Create(ctx, &expectedBpfProgram, &opts); err != nil { - return internal.Requeue, fmt.Errorf("failed to create bpfProgram object: %v", err) + return internal.Requeue, fmt.Errorf("failed to create BpfProgram object: %v", err) } return internal.Updated, nil } @@ -792,11 +792,11 @@ func (r *ReconcilerCommon) handleProgCreateOrUpdate( // If bpfProgram Maps OR the program ID annotation isn't up to date just update it and return if !reflect.DeepEqual(existingId, r.progId) { - r.Logger.Info("Updating bpfProgram Object", "Id", r.progId, "bpfProgram", existingBpfProgram.Name) + r.Logger.Info("Calling KubeAPI to update BpfProgram Object", "Id", r.progId, "Name", existingBpfProgram.Name) // annotations should be populated on create existingBpfProgram.Annotations[internal.IdAnnotation] = strconv.FormatUint(uint64(*r.progId), 10) if err := r.Update(ctx, &existingBpfProgram, &client.UpdateOptions{}); err != nil { - return internal.Requeue, fmt.Errorf("failed to update bpfProgram's Programs: %v", err) + return internal.Requeue, fmt.Errorf("failed to update BpfProgram's Programs: %v", err) } return internal.Updated, nil } @@ -813,7 +813,7 @@ func (r *ReconcilerCommon) handleProgCreateOrUpdate( return r.handleProgDelete(ctx, rec, existingBpfPrograms, loadedBpfPrograms, isNodeSelected, isBeingDeleted, mapOwnerStatus) } else { // We're done reconciling. - r.Logger.Info("Finished reconciling", "program name", rec.getName()) + r.Logger.Info("No change in status", "Name", rec.getName()) return internal.Unchanged, nil } } @@ -846,7 +846,7 @@ func (r *ReconcilerCommon) reconcileProgram(ctx context.Context, // on this node. existingBpfPrograms, err := r.getExistingBpfPrograms(ctx, rec) if err != nil { - return internal.Requeue, fmt.Errorf("failed to get existing bpfPrograms: %v", err) + return internal.Requeue, fmt.Errorf("failed to get existing BpfPrograms: %v", err) } // Determine if the MapOwnerSelector was set, and if so, see if the MapOwner @@ -872,7 +872,7 @@ func (r *ReconcilerCommon) reconcileProgram(ctx context.Context, // installed in multiple containers because of ContainerSelector). expectedBpfPrograms, err := rec.getExpectedBpfPrograms(ctx) if err != nil { - return internal.Requeue, fmt.Errorf("failed to get expected bpfPrograms: %v", err) + return internal.Requeue, fmt.Errorf("failed to get expected BpfPrograms: %v", err) } return r.handleProgCreateOrUpdate(ctx, rec, existingBpfPrograms, expectedBpfPrograms, loadedBpfPrograms, isNodeSelected, isBeingDeleted, mapOwnerStatus) @@ -933,7 +933,7 @@ func (r *ReconcilerCommon) processMapOwnerParam( if len(bpfProgramList.Items) == 0 { return mapOwnerStatus, nil } else if len(bpfProgramList.Items) > 1 { - return mapOwnerStatus, fmt.Errorf("MapOwnerSelector resolved to multiple bpfProgram Objects") + return mapOwnerStatus, fmt.Errorf("MapOwnerSelector resolved to multiple BpfProgram Objects") } else { mapOwnerStatus.isFound = true @@ -1029,5 +1029,5 @@ func (r *ReconcilerCommon) getBpfProgram( } } - return fmt.Errorf("bpfProgram not found") + return fmt.Errorf("BpfProgram not found") } diff --git a/controllers/bpfman-agent/fentry-program.go b/controllers/bpfman-agent/fentry-program.go index 680693e1e..02545224c 100644 --- a/controllers/bpfman-agent/fentry-program.go +++ b/controllers/bpfman-agent/fentry-program.go @@ -32,7 +32,6 @@ import ( "sigs.k8s.io/controller-runtime/pkg/builder" "sigs.k8s.io/controller-runtime/pkg/client" "sigs.k8s.io/controller-runtime/pkg/handler" - "sigs.k8s.io/controller-runtime/pkg/log" "sigs.k8s.io/controller-runtime/pkg/predicate" ) @@ -149,8 +148,7 @@ func (r *FentryProgramReconciler) Reconcile(ctx context.Context, req ctrl.Reques r.ourNode = &v1.Node{} r.Logger = ctrl.Log.WithName("fentry") - ctxLogger := log.FromContext(ctx) - ctxLogger.Info("Reconcile Fentry: Enter", "ReconcileKey", req) + r.Logger.Info("bpfman-agent enter: fentry", "Name", req.Name) // Lookup K8s node object for this bpfman-agent This should always succeed if err := r.Get(ctx, types.NamespacedName{Namespace: v1.NamespaceAll, Name: r.NodeName}, r.ourNode); err != nil { diff --git a/controllers/bpfman-agent/fexit-program.go b/controllers/bpfman-agent/fexit-program.go index b52171e80..f1799d80a 100644 --- a/controllers/bpfman-agent/fexit-program.go +++ b/controllers/bpfman-agent/fexit-program.go @@ -32,7 +32,6 @@ import ( "sigs.k8s.io/controller-runtime/pkg/builder" "sigs.k8s.io/controller-runtime/pkg/client" "sigs.k8s.io/controller-runtime/pkg/handler" - "sigs.k8s.io/controller-runtime/pkg/log" "sigs.k8s.io/controller-runtime/pkg/predicate" ) @@ -149,8 +148,7 @@ func (r *FexitProgramReconciler) Reconcile(ctx context.Context, req ctrl.Request r.ourNode = &v1.Node{} r.Logger = ctrl.Log.WithName("fexit") - ctxLogger := log.FromContext(ctx) - ctxLogger.Info("Reconcile Fexit: Enter", "ReconcileKey", req) + r.Logger.Info("bpfman-agent enter: fexit", "Name", req.Name) // Lookup K8s node object for this bpfman-agent This should always succeed if err := r.Get(ctx, types.NamespacedName{Namespace: v1.NamespaceAll, Name: r.NodeName}, r.ourNode); err != nil { diff --git a/controllers/bpfman-agent/kprobe-program.go b/controllers/bpfman-agent/kprobe-program.go index 89e912b70..8b18400b0 100644 --- a/controllers/bpfman-agent/kprobe-program.go +++ b/controllers/bpfman-agent/kprobe-program.go @@ -32,7 +32,6 @@ import ( "sigs.k8s.io/controller-runtime/pkg/builder" "sigs.k8s.io/controller-runtime/pkg/client" "sigs.k8s.io/controller-runtime/pkg/handler" - "sigs.k8s.io/controller-runtime/pkg/log" "sigs.k8s.io/controller-runtime/pkg/predicate" ) @@ -149,8 +148,7 @@ func (r *KprobeProgramReconciler) Reconcile(ctx context.Context, req ctrl.Reques r.ourNode = &v1.Node{} r.Logger = ctrl.Log.WithName("kprobe") - ctxLogger := log.FromContext(ctx) - ctxLogger.Info("Reconcile Kprobe: Enter", "ReconcileKey", req) + r.Logger.Info("bpfman-agent enter: kprobe", "Name", req.Name) // Lookup K8s node object for this bpfman-agent This should always succeed if err := r.Get(ctx, types.NamespacedName{Namespace: v1.NamespaceAll, Name: r.NodeName}, r.ourNode); err != nil { diff --git a/controllers/bpfman-agent/tc-program.go b/controllers/bpfman-agent/tc-program.go index 03515dd05..6c585c751 100644 --- a/controllers/bpfman-agent/tc-program.go +++ b/controllers/bpfman-agent/tc-program.go @@ -32,7 +32,6 @@ import ( "sigs.k8s.io/controller-runtime/pkg/builder" "sigs.k8s.io/controller-runtime/pkg/client" "sigs.k8s.io/controller-runtime/pkg/handler" - "sigs.k8s.io/controller-runtime/pkg/log" "sigs.k8s.io/controller-runtime/pkg/predicate" ) @@ -195,8 +194,7 @@ func (r *TcProgramReconciler) Reconcile(ctx context.Context, req ctrl.Request) ( r.ourNode = &v1.Node{} r.Logger = ctrl.Log.WithName("tc") - ctxLogger := log.FromContext(ctx) - ctxLogger.Info("Reconcile TC: Enter", "ReconcileKey", req) + r.Logger.Info("bpfman-agent enter: TC", "Name", req.Name) // Lookup K8s node object for this bpfman-agent This should always succeed if err := r.Get(ctx, types.NamespacedName{Namespace: v1.NamespaceAll, Name: r.NodeName}, r.ourNode); err != nil { diff --git a/controllers/bpfman-agent/tcx-program.go b/controllers/bpfman-agent/tcx-program.go index 788db969e..3c918b186 100644 --- a/controllers/bpfman-agent/tcx-program.go +++ b/controllers/bpfman-agent/tcx-program.go @@ -19,6 +19,7 @@ package bpfmanagent import ( "context" "fmt" + bpfmaniov1alpha1 "github.com/bpfman/bpfman-operator/apis/v1alpha1" bpfmanagentinternal "github.com/bpfman/bpfman-operator/controllers/bpfman-agent/internal" "github.com/bpfman/bpfman-operator/internal" @@ -31,7 +32,6 @@ import ( "sigs.k8s.io/controller-runtime/pkg/builder" "sigs.k8s.io/controller-runtime/pkg/client" "sigs.k8s.io/controller-runtime/pkg/handler" - "sigs.k8s.io/controller-runtime/pkg/log" "sigs.k8s.io/controller-runtime/pkg/predicate" ) @@ -160,8 +160,7 @@ func (r *TcxProgramReconciler) Reconcile(ctx context.Context, req ctrl.Request) r.ourNode = &v1.Node{} r.Logger = ctrl.Log.WithName("tcx") - ctxLogger := log.FromContext(ctx) - ctxLogger.Info("Reconcile TCX: Enter", "ReconcileKey", req) + r.Logger.Info("bpfman-agent enter: tcx", "Name", req.Name) // Lookup K8s node object for this bpfman-agent This should always succeed if err := r.Get(ctx, types.NamespacedName{Namespace: v1.NamespaceAll, Name: r.NodeName}, r.ourNode); err != nil { diff --git a/controllers/bpfman-agent/tracepoint-program.go b/controllers/bpfman-agent/tracepoint-program.go index dfafff528..97480369c 100644 --- a/controllers/bpfman-agent/tracepoint-program.go +++ b/controllers/bpfman-agent/tracepoint-program.go @@ -32,7 +32,6 @@ import ( "sigs.k8s.io/controller-runtime/pkg/builder" "sigs.k8s.io/controller-runtime/pkg/client" "sigs.k8s.io/controller-runtime/pkg/handler" - "sigs.k8s.io/controller-runtime/pkg/log" "sigs.k8s.io/controller-runtime/pkg/predicate" ) @@ -150,8 +149,7 @@ func (r *TracepointProgramReconciler) Reconcile(ctx context.Context, req ctrl.Re r.ourNode = &v1.Node{} r.Logger = ctrl.Log.WithName("tracept") - ctxLogger := log.FromContext(ctx) - ctxLogger.Info("Reconcile Tracepoint: Enter", "ReconcileKey", req) + r.Logger.Info("bpfman-agent enter: tracepoint", "Name", req.Name) // Lookup K8s node object for this bpfman-agent This should always succeed if err := r.Get(ctx, types.NamespacedName{Namespace: v1.NamespaceAll, Name: r.NodeName}, r.ourNode); err != nil { diff --git a/controllers/bpfman-agent/uprobe-program.go b/controllers/bpfman-agent/uprobe-program.go index 7e03b3fd7..09838073f 100644 --- a/controllers/bpfman-agent/uprobe-program.go +++ b/controllers/bpfman-agent/uprobe-program.go @@ -33,7 +33,6 @@ import ( "sigs.k8s.io/controller-runtime/pkg/builder" "sigs.k8s.io/controller-runtime/pkg/client" "sigs.k8s.io/controller-runtime/pkg/handler" - "sigs.k8s.io/controller-runtime/pkg/log" "sigs.k8s.io/controller-runtime/pkg/predicate" ) @@ -233,8 +232,7 @@ func (r *UprobeProgramReconciler) Reconcile(ctx context.Context, req ctrl.Reques r.ourNode = &v1.Node{} r.Logger = ctrl.Log.WithName("uprobe") - ctxLogger := log.FromContext(ctx) - ctxLogger.Info("Reconcile Uprobe: Enter", "ReconcileKey", req) + r.Logger.Info("bpfman-agent enter: uprobe", "Name", req.Name) // Lookup K8s node object for this bpfman-agent This should always succeed if err := r.Get(ctx, types.NamespacedName{Namespace: v1.NamespaceAll, Name: r.NodeName}, r.ourNode); err != nil { diff --git a/controllers/bpfman-agent/xdp-program.go b/controllers/bpfman-agent/xdp-program.go index 72859a4b2..7b8b0dac9 100644 --- a/controllers/bpfman-agent/xdp-program.go +++ b/controllers/bpfman-agent/xdp-program.go @@ -32,7 +32,6 @@ import ( "sigs.k8s.io/controller-runtime/pkg/builder" "sigs.k8s.io/controller-runtime/pkg/client" "sigs.k8s.io/controller-runtime/pkg/handler" - "sigs.k8s.io/controller-runtime/pkg/log" "sigs.k8s.io/controller-runtime/pkg/predicate" ) @@ -181,8 +180,7 @@ func (r *XdpProgramReconciler) Reconcile(ctx context.Context, req ctrl.Request) r.ourNode = &v1.Node{} r.Logger = ctrl.Log.WithName("xdp") - ctxLogger := log.FromContext(ctx) - ctxLogger.Info("Reconcile XDP: Enter", "ReconcileKey", req) + r.Logger.Info("bpfman-agent enter: XDP", "Name", req.Name) // Lookup K8s node object for this bpfman-agent This should always succeed if err := r.Get(ctx, types.NamespacedName{Namespace: v1.NamespaceAll, Name: r.NodeName}, r.ourNode); err != nil { diff --git a/controllers/bpfman-operator/application-programs.go b/controllers/bpfman-operator/application-programs.go index 0001c3430..58fb7ecc7 100644 --- a/controllers/bpfman-operator/application-programs.go +++ b/controllers/bpfman-operator/application-programs.go @@ -28,7 +28,6 @@ import ( ctrl "sigs.k8s.io/controller-runtime" "sigs.k8s.io/controller-runtime/pkg/builder" "sigs.k8s.io/controller-runtime/pkg/handler" - "sigs.k8s.io/controller-runtime/pkg/log" "sigs.k8s.io/controller-runtime/pkg/predicate" bpfmaniov1alpha1 "github.com/bpfman/bpfman-operator/apis/v1alpha1" @@ -66,7 +65,8 @@ func (r *BpfApplicationReconciler) SetupWithManager(mgr ctrl.Manager) error { } func (r *BpfApplicationReconciler) Reconcile(ctx context.Context, req ctrl.Request) (ctrl.Result, error) { - r.Logger = log.FromContext(ctx) + r.Logger = ctrl.Log.WithName("application") + r.Logger.Info("bpfman-operator enter: application", "Name", req.NamespacedName.Name) appProgram := &bpfmaniov1alpha1.BpfApplication{} if err := r.Get(ctx, req.NamespacedName, appProgram); err != nil { diff --git a/controllers/bpfman-operator/common.go b/controllers/bpfman-operator/common.go index 69e89efa1..3c7d9ec1c 100644 --- a/controllers/bpfman-operator/common.go +++ b/controllers/bpfman-operator/common.go @@ -66,7 +66,7 @@ func reconcileBpfProgram(ctx context.Context, rec ProgramReconciler, prog client r := rec.getRecCommon() progName := prog.GetName() - r.Logger.V(1).Info("Reconciling Program", "ProgramName", progName) + r.Logger.V(1).Info("Reconciling Program", "Name", progName) if !controllerutil.ContainsFinalizer(prog, internal.BpfmanOperatorFinalizer) { return r.addFinalizer(ctx, prog, internal.BpfmanOperatorFinalizer) @@ -147,7 +147,7 @@ func reconcileBpfProgram(ctx context.Context, rec ProgramReconciler, prog client } func (r *ReconcilerCommon) removeFinalizer(ctx context.Context, prog client.Object, finalizer string) (ctrl.Result, error) { - r.Logger.V(1).Info("Program is deleted remove finalizer", "ProgramName", prog.GetName()) + r.Logger.Info("Calling KubeAPI to delete Program Finalizer", "Type", prog.GetObjectKind().GroupVersionKind().Kind, "Name", prog.GetName()) if changed := controllerutil.RemoveFinalizer(prog, finalizer); changed { err := r.Update(ctx, prog) @@ -163,6 +163,7 @@ func (r *ReconcilerCommon) removeFinalizer(ctx context.Context, prog client.Obje func (r *ReconcilerCommon) addFinalizer(ctx context.Context, prog client.Object, finalizer string) (ctrl.Result, error) { controllerutil.AddFinalizer(prog, finalizer) + r.Logger.Info("Calling KubeAPI to add Program Finalizer", "Type", prog.GetObjectKind().GroupVersionKind().Kind, "Name", prog.GetName()) err := r.Update(ctx, prog) if err != nil { r.Logger.V(1).Info("failed adding bpfman-operator finalizer to Program...requeuing") @@ -201,6 +202,7 @@ func (r *ReconcilerCommon) updateCondition(ctx context.Context, obj client.Objec if numConditions == 1 { if (*conditions)[0].Type == string(cond) { + r.Logger.Info("No change in status", "existing condition", (*conditions)[0].Type) // No change, so just return false -- not updated return ctrl.Result{}, nil } else { @@ -220,6 +222,8 @@ func (r *ReconcilerCommon) updateCondition(ctx context.Context, obj client.Objec meta.SetStatusCondition(conditions, cond.Condition(message)) + r.Logger.Info("Calling KubeAPI to update Program condition", "Type", obj.GetObjectKind().GroupVersionKind().Kind, + "Name", obj.GetName(), "condition", cond.Condition(message).Type) if err := r.Status().Update(ctx, obj); err != nil { r.Logger.V(1).Info("failed to set *Program object status...requeuing", "error", err) return ctrl.Result{Requeue: true, RequeueAfter: retryDurationOperator}, nil diff --git a/controllers/bpfman-operator/configmap.go b/controllers/bpfman-operator/configmap.go index 4049f3814..a351eca7c 100644 --- a/controllers/bpfman-operator/configmap.go +++ b/controllers/bpfman-operator/configmap.go @@ -37,7 +37,6 @@ import ( osv1 "github.com/openshift/api/security/v1" "sigs.k8s.io/controller-runtime/pkg/builder" "sigs.k8s.io/controller-runtime/pkg/controller/controllerutil" - "sigs.k8s.io/controller-runtime/pkg/log" "github.com/bpfman/bpfman-operator/internal" ) @@ -73,7 +72,7 @@ func (r *BpfmanConfigReconciler) SetupWithManager(mgr ctrl.Manager) error { } func (r *BpfmanConfigReconciler) Reconcile(ctx context.Context, req ctrl.Request) (ctrl.Result, error) { - r.Logger = log.FromContext(ctx) + r.Logger = ctrl.Log.WithName("configMap") bpfmanConfig := &corev1.ConfigMap{} if err := r.Get(ctx, req.NamespacedName, bpfmanConfig); err != nil { diff --git a/controllers/bpfman-operator/fentry-program.go b/controllers/bpfman-operator/fentry-program.go index 68f7d3c3b..f7c5c7ab0 100644 --- a/controllers/bpfman-operator/fentry-program.go +++ b/controllers/bpfman-operator/fentry-program.go @@ -27,7 +27,6 @@ import ( bpfmaniov1alpha1 "github.com/bpfman/bpfman-operator/apis/v1alpha1" "github.com/bpfman/bpfman-operator/internal" "sigs.k8s.io/controller-runtime/pkg/handler" - "sigs.k8s.io/controller-runtime/pkg/log" "sigs.k8s.io/controller-runtime/pkg/predicate" ) @@ -61,7 +60,8 @@ func (r *FentryProgramReconciler) SetupWithManager(mgr ctrl.Manager) error { } func (r *FentryProgramReconciler) Reconcile(ctx context.Context, req ctrl.Request) (ctrl.Result, error) { - r.Logger = log.FromContext(ctx) + r.Logger = ctrl.Log.WithName("fentry") + r.Logger.Info("bpfman-operator enter: fentry", "Name", req.NamespacedName.Name) fentryProgram := &bpfmaniov1alpha1.FentryProgram{} if err := r.Get(ctx, req.NamespacedName, fentryProgram); err != nil { diff --git a/controllers/bpfman-operator/fexit-program.go b/controllers/bpfman-operator/fexit-program.go index 4578bd0d6..7a5ec42c9 100644 --- a/controllers/bpfman-operator/fexit-program.go +++ b/controllers/bpfman-operator/fexit-program.go @@ -27,7 +27,6 @@ import ( bpfmaniov1alpha1 "github.com/bpfman/bpfman-operator/apis/v1alpha1" "github.com/bpfman/bpfman-operator/internal" "sigs.k8s.io/controller-runtime/pkg/handler" - "sigs.k8s.io/controller-runtime/pkg/log" "sigs.k8s.io/controller-runtime/pkg/predicate" ) @@ -61,7 +60,8 @@ func (r *FexitProgramReconciler) SetupWithManager(mgr ctrl.Manager) error { } func (r *FexitProgramReconciler) Reconcile(ctx context.Context, req ctrl.Request) (ctrl.Result, error) { - r.Logger = log.FromContext(ctx) + r.Logger = ctrl.Log.WithName("fexit") + r.Logger.Info("bpfman-operator enter: fexit", "Name", req.NamespacedName.Name) fexitProgram := &bpfmaniov1alpha1.FexitProgram{} if err := r.Get(ctx, req.NamespacedName, fexitProgram); err != nil { diff --git a/controllers/bpfman-operator/kprobe-program.go b/controllers/bpfman-operator/kprobe-program.go index f36af3c1c..71623e6e2 100644 --- a/controllers/bpfman-operator/kprobe-program.go +++ b/controllers/bpfman-operator/kprobe-program.go @@ -27,7 +27,6 @@ import ( bpfmaniov1alpha1 "github.com/bpfman/bpfman-operator/apis/v1alpha1" "github.com/bpfman/bpfman-operator/internal" "sigs.k8s.io/controller-runtime/pkg/handler" - "sigs.k8s.io/controller-runtime/pkg/log" "sigs.k8s.io/controller-runtime/pkg/predicate" ) @@ -61,7 +60,8 @@ func (r *KprobeProgramReconciler) SetupWithManager(mgr ctrl.Manager) error { } func (r *KprobeProgramReconciler) Reconcile(ctx context.Context, req ctrl.Request) (ctrl.Result, error) { - r.Logger = log.FromContext(ctx) + r.Logger = ctrl.Log.WithName("kprobe") + r.Logger.Info("bpfman-operator enter: kprobe", "Name", req.NamespacedName.Name) kprobeProgram := &bpfmaniov1alpha1.KprobeProgram{} if err := r.Get(ctx, req.NamespacedName, kprobeProgram); err != nil { diff --git a/controllers/bpfman-operator/tc-program.go b/controllers/bpfman-operator/tc-program.go index f3bc673c7..f8c5db136 100644 --- a/controllers/bpfman-operator/tc-program.go +++ b/controllers/bpfman-operator/tc-program.go @@ -27,7 +27,6 @@ import ( bpfmaniov1alpha1 "github.com/bpfman/bpfman-operator/apis/v1alpha1" "github.com/bpfman/bpfman-operator/internal" "sigs.k8s.io/controller-runtime/pkg/handler" - "sigs.k8s.io/controller-runtime/pkg/log" "sigs.k8s.io/controller-runtime/pkg/predicate" ) @@ -61,7 +60,8 @@ func (r *TcProgramReconciler) SetupWithManager(mgr ctrl.Manager) error { //+kubebuilder:rbac:groups=bpfman.io,resources=tcprograms/finalizers,verbs=update func (r *TcProgramReconciler) Reconcile(ctx context.Context, req ctrl.Request) (ctrl.Result, error) { - r.Logger = log.FromContext(ctx) + r.Logger = ctrl.Log.WithName("tc") + r.Logger.Info("bpfman-operator enter: tc", "Name", req.NamespacedName.Name) tcProgram := &bpfmaniov1alpha1.TcProgram{} if err := r.Get(ctx, req.NamespacedName, tcProgram); err != nil { diff --git a/controllers/bpfman-operator/tcx-program.go b/controllers/bpfman-operator/tcx-program.go index 05a9925fd..a13dc4f9d 100644 --- a/controllers/bpfman-operator/tcx-program.go +++ b/controllers/bpfman-operator/tcx-program.go @@ -27,7 +27,6 @@ import ( bpfmaniov1alpha1 "github.com/bpfman/bpfman-operator/apis/v1alpha1" "github.com/bpfman/bpfman-operator/internal" "sigs.k8s.io/controller-runtime/pkg/handler" - "sigs.k8s.io/controller-runtime/pkg/log" "sigs.k8s.io/controller-runtime/pkg/predicate" ) @@ -61,7 +60,8 @@ func (r *TcxProgramReconciler) SetupWithManager(mgr ctrl.Manager) error { //+kubebuilder:rbac:groups=bpfman.io,resources=tcxprograms/finalizers,verbs=update func (r *TcxProgramReconciler) Reconcile(ctx context.Context, req ctrl.Request) (ctrl.Result, error) { - r.Logger = log.FromContext(ctx) + r.Logger = ctrl.Log.WithName("tcx") + r.Logger.Info("bpfman-operator enter: tcx", "Name", req.NamespacedName.Name) tcxProgram := &bpfmaniov1alpha1.TcxProgram{} if err := r.Get(ctx, req.NamespacedName, tcxProgram); err != nil { diff --git a/controllers/bpfman-operator/tracepoint-program.go b/controllers/bpfman-operator/tracepoint-program.go index 84025f074..758d509b0 100644 --- a/controllers/bpfman-operator/tracepoint-program.go +++ b/controllers/bpfman-operator/tracepoint-program.go @@ -27,7 +27,6 @@ import ( bpfmaniov1alpha1 "github.com/bpfman/bpfman-operator/apis/v1alpha1" "github.com/bpfman/bpfman-operator/internal" "sigs.k8s.io/controller-runtime/pkg/handler" - "sigs.k8s.io/controller-runtime/pkg/log" "sigs.k8s.io/controller-runtime/pkg/predicate" ) @@ -61,7 +60,8 @@ func (r *TracepointProgramReconciler) SetupWithManager(mgr ctrl.Manager) error { } func (r *TracepointProgramReconciler) Reconcile(ctx context.Context, req ctrl.Request) (ctrl.Result, error) { - r.Logger = log.FromContext(ctx) + r.Logger = ctrl.Log.WithName("tracepoint") + r.Logger.Info("bpfman-operator enter: tracepoint", "Name", req.NamespacedName.Name) tracepointProgram := &bpfmaniov1alpha1.TracepointProgram{} if err := r.Get(ctx, req.NamespacedName, tracepointProgram); err != nil { diff --git a/controllers/bpfman-operator/uprobe-program.go b/controllers/bpfman-operator/uprobe-program.go index 16616202d..dd02d3643 100644 --- a/controllers/bpfman-operator/uprobe-program.go +++ b/controllers/bpfman-operator/uprobe-program.go @@ -27,7 +27,6 @@ import ( bpfmaniov1alpha1 "github.com/bpfman/bpfman-operator/apis/v1alpha1" "github.com/bpfman/bpfman-operator/internal" "sigs.k8s.io/controller-runtime/pkg/handler" - "sigs.k8s.io/controller-runtime/pkg/log" "sigs.k8s.io/controller-runtime/pkg/predicate" ) @@ -61,7 +60,8 @@ func (r *UprobeProgramReconciler) SetupWithManager(mgr ctrl.Manager) error { } func (r *UprobeProgramReconciler) Reconcile(ctx context.Context, req ctrl.Request) (ctrl.Result, error) { - r.Logger = log.FromContext(ctx) + r.Logger = ctrl.Log.WithName("uprobe") + r.Logger.Info("bpfman-operator enter: uprobe", "Name", req.NamespacedName.Name) uprobeProgram := &bpfmaniov1alpha1.UprobeProgram{} if err := r.Get(ctx, req.NamespacedName, uprobeProgram); err != nil { diff --git a/controllers/bpfman-operator/xdp-program.go b/controllers/bpfman-operator/xdp-program.go index ea9bd7e9b..c8603c588 100644 --- a/controllers/bpfman-operator/xdp-program.go +++ b/controllers/bpfman-operator/xdp-program.go @@ -27,7 +27,6 @@ import ( bpfmaniov1alpha1 "github.com/bpfman/bpfman-operator/apis/v1alpha1" "github.com/bpfman/bpfman-operator/internal" "sigs.k8s.io/controller-runtime/pkg/handler" - "sigs.k8s.io/controller-runtime/pkg/log" "sigs.k8s.io/controller-runtime/pkg/predicate" ) @@ -61,7 +60,8 @@ func (r *XdpProgramReconciler) SetupWithManager(mgr ctrl.Manager) error { } func (r *XdpProgramReconciler) Reconcile(ctx context.Context, req ctrl.Request) (ctrl.Result, error) { - r.Logger = log.FromContext(ctx) + r.Logger = ctrl.Log.WithName("xdp") + r.Logger.Info("bpfman-operator enter: xdp", "Name", req.NamespacedName.Name) xdpProgram := &bpfmaniov1alpha1.XdpProgram{} if err := r.Get(ctx, req.NamespacedName, xdpProgram); err != nil {