mirror of
				https://github.com/optim-enterprises-bv/kubernetes.git
				synced 2025-11-03 19:58:17 +00:00 
			
		
		
		
	Merge pull request #91712 from KobayashiD27/structured-logging-in-event
Migrate log to klog.InfoS for staging/src/k8s.io/client-go
This commit is contained in:
		@@ -32,7 +32,6 @@ go_library(
 | 
			
		||||
        "//staging/src/k8s.io/client-go/tools/record:go_default_library",
 | 
			
		||||
        "//staging/src/k8s.io/cloud-provider:go_default_library",
 | 
			
		||||
        "//staging/src/k8s.io/component-base/cli/flag:go_default_library",
 | 
			
		||||
        "//vendor/k8s.io/klog/v2:go_default_library",
 | 
			
		||||
    ],
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -36,7 +36,6 @@ import (
 | 
			
		||||
	"k8s.io/client-go/tools/record"
 | 
			
		||||
	ports "k8s.io/cloud-provider"
 | 
			
		||||
	cliflag "k8s.io/component-base/cli/flag"
 | 
			
		||||
	"k8s.io/klog/v2"
 | 
			
		||||
	ccmconfig "k8s.io/kubernetes/cmd/cloud-controller-manager/app/apis/config"
 | 
			
		||||
	ccmconfigscheme "k8s.io/kubernetes/cmd/cloud-controller-manager/app/apis/config/scheme"
 | 
			
		||||
	ccmconfigv1alpha1 "k8s.io/kubernetes/cmd/cloud-controller-manager/app/apis/config/v1alpha1"
 | 
			
		||||
@@ -267,7 +266,7 @@ func (o *CloudControllerManagerOptions) Config(allControllers, disabledByDefault
 | 
			
		||||
 | 
			
		||||
func createRecorder(kubeClient clientset.Interface, userAgent string) record.EventRecorder {
 | 
			
		||||
	eventBroadcaster := record.NewBroadcaster()
 | 
			
		||||
	eventBroadcaster.StartLogging(klog.Infof)
 | 
			
		||||
	eventBroadcaster.StartStructuredLogging(0)
 | 
			
		||||
	eventBroadcaster.StartRecordingToSink(&v1core.EventSinkImpl{Interface: kubeClient.CoreV1().Events("")})
 | 
			
		||||
	return eventBroadcaster.NewRecorder(scheme.Scheme, v1.EventSource{Component: userAgent})
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
@@ -75,7 +75,6 @@ go_library(
 | 
			
		||||
        "//staging/src/k8s.io/component-base/metrics:go_default_library",
 | 
			
		||||
        "//staging/src/k8s.io/kube-controller-manager/config/v1alpha1:go_default_library",
 | 
			
		||||
        "//vendor/github.com/spf13/pflag:go_default_library",
 | 
			
		||||
        "//vendor/k8s.io/klog/v2:go_default_library",
 | 
			
		||||
    ],
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -45,8 +45,6 @@ import (
 | 
			
		||||
 | 
			
		||||
	// add the kubernetes feature gates
 | 
			
		||||
	_ "k8s.io/kubernetes/pkg/features"
 | 
			
		||||
 | 
			
		||||
	"k8s.io/klog/v2"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
const (
 | 
			
		||||
@@ -442,7 +440,7 @@ func (s KubeControllerManagerOptions) Config(allControllers []string, disabledBy
 | 
			
		||||
 | 
			
		||||
func createRecorder(kubeClient clientset.Interface, userAgent string) record.EventRecorder {
 | 
			
		||||
	eventBroadcaster := record.NewBroadcaster()
 | 
			
		||||
	eventBroadcaster.StartLogging(klog.Infof)
 | 
			
		||||
	eventBroadcaster.StartStructuredLogging(0)
 | 
			
		||||
	eventBroadcaster.StartRecordingToSink(&v1core.EventSinkImpl{Interface: kubeClient.CoreV1().Events("")})
 | 
			
		||||
	return eventBroadcaster.NewRecorder(clientgokubescheme.Scheme, v1.EventSource{Component: userAgent})
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
@@ -456,7 +456,7 @@ func makeEventRecorder(kubeDeps *kubelet.Dependencies, nodeName types.NodeName)
 | 
			
		||||
	}
 | 
			
		||||
	eventBroadcaster := record.NewBroadcaster()
 | 
			
		||||
	kubeDeps.Recorder = eventBroadcaster.NewRecorder(legacyscheme.Scheme, v1.EventSource{Component: componentKubelet, Host: string(nodeName)})
 | 
			
		||||
	eventBroadcaster.StartLogging(klog.V(3).Infof)
 | 
			
		||||
	eventBroadcaster.StartStructuredLogging(3)
 | 
			
		||||
	if kubeDeps.EventClient != nil {
 | 
			
		||||
		klog.V(4).Infof("Sending events to api server.")
 | 
			
		||||
		eventBroadcaster.StartRecordingToSink(&v1core.EventSinkImpl{Interface: kubeDeps.EventClient.Events("")})
 | 
			
		||||
 
 | 
			
		||||
@@ -61,7 +61,7 @@ func NewCertificateController(
 | 
			
		||||
) *CertificateController {
 | 
			
		||||
	// Send events to the apiserver
 | 
			
		||||
	eventBroadcaster := record.NewBroadcaster()
 | 
			
		||||
	eventBroadcaster.StartLogging(klog.Infof)
 | 
			
		||||
	eventBroadcaster.StartStructuredLogging(0)
 | 
			
		||||
	eventBroadcaster.StartRecordingToSink(&v1core.EventSinkImpl{Interface: kubeClient.CoreV1().Events("")})
 | 
			
		||||
 | 
			
		||||
	cc := &CertificateController{
 | 
			
		||||
 
 | 
			
		||||
@@ -70,7 +70,7 @@ type Controller struct {
 | 
			
		||||
// NewController creates and initializes a new Controller.
 | 
			
		||||
func NewController(kubeClient clientset.Interface) (*Controller, error) {
 | 
			
		||||
	eventBroadcaster := record.NewBroadcaster()
 | 
			
		||||
	eventBroadcaster.StartLogging(klog.Infof)
 | 
			
		||||
	eventBroadcaster.StartStructuredLogging(0)
 | 
			
		||||
	eventBroadcaster.StartRecordingToSink(&v1core.EventSinkImpl{Interface: kubeClient.CoreV1().Events("")})
 | 
			
		||||
 | 
			
		||||
	if kubeClient != nil && kubeClient.CoreV1().RESTClient().GetRateLimiter() != nil {
 | 
			
		||||
 
 | 
			
		||||
@@ -139,7 +139,7 @@ func NewDaemonSetsController(
 | 
			
		||||
	failedPodsBackoff *flowcontrol.Backoff,
 | 
			
		||||
) (*DaemonSetsController, error) {
 | 
			
		||||
	eventBroadcaster := record.NewBroadcaster()
 | 
			
		||||
	eventBroadcaster.StartLogging(klog.Infof)
 | 
			
		||||
	eventBroadcaster.StartStructuredLogging(0)
 | 
			
		||||
	eventBroadcaster.StartRecordingToSink(&v1core.EventSinkImpl{Interface: kubeClient.CoreV1().Events("")})
 | 
			
		||||
 | 
			
		||||
	if kubeClient != nil && kubeClient.CoreV1().RESTClient().GetRateLimiter() != nil {
 | 
			
		||||
 
 | 
			
		||||
@@ -100,7 +100,7 @@ type DeploymentController struct {
 | 
			
		||||
// NewDeploymentController creates a new DeploymentController.
 | 
			
		||||
func NewDeploymentController(dInformer appsinformers.DeploymentInformer, rsInformer appsinformers.ReplicaSetInformer, podInformer coreinformers.PodInformer, client clientset.Interface) (*DeploymentController, error) {
 | 
			
		||||
	eventBroadcaster := record.NewBroadcaster()
 | 
			
		||||
	eventBroadcaster.StartLogging(klog.Infof)
 | 
			
		||||
	eventBroadcaster.StartStructuredLogging(0)
 | 
			
		||||
	eventBroadcaster.StartRecordingToSink(&v1core.EventSinkImpl{Interface: client.CoreV1().Events("")})
 | 
			
		||||
 | 
			
		||||
	if client != nil && client.CoreV1().RESTClient().GetRateLimiter() != nil {
 | 
			
		||||
 
 | 
			
		||||
@@ -80,7 +80,7 @@ const (
 | 
			
		||||
func NewEndpointController(podInformer coreinformers.PodInformer, serviceInformer coreinformers.ServiceInformer,
 | 
			
		||||
	endpointsInformer coreinformers.EndpointsInformer, client clientset.Interface, endpointUpdatesBatchPeriod time.Duration) *EndpointController {
 | 
			
		||||
	broadcaster := record.NewBroadcaster()
 | 
			
		||||
	broadcaster.StartLogging(klog.Infof)
 | 
			
		||||
	broadcaster.StartStructuredLogging(0)
 | 
			
		||||
	broadcaster.StartRecordingToSink(&v1core.EventSinkImpl{Interface: client.CoreV1().Events("")})
 | 
			
		||||
	recorder := broadcaster.NewRecorder(scheme.Scheme, v1.EventSource{Component: "endpoint-controller"})
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -82,7 +82,7 @@ func NewController(podInformer coreinformers.PodInformer,
 | 
			
		||||
	endpointUpdatesBatchPeriod time.Duration,
 | 
			
		||||
) *Controller {
 | 
			
		||||
	broadcaster := record.NewBroadcaster()
 | 
			
		||||
	broadcaster.StartLogging(klog.Infof)
 | 
			
		||||
	broadcaster.StartStructuredLogging(0)
 | 
			
		||||
	broadcaster.StartRecordingToSink(&v1core.EventSinkImpl{Interface: client.CoreV1().Events("")})
 | 
			
		||||
	recorder := broadcaster.NewRecorder(scheme.Scheme, v1.EventSource{Component: "endpoint-slice-controller"})
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -96,7 +96,7 @@ type Controller struct {
 | 
			
		||||
// in sync with their corresponding Job objects.
 | 
			
		||||
func NewController(podInformer coreinformers.PodInformer, jobInformer batchinformers.JobInformer, kubeClient clientset.Interface) *Controller {
 | 
			
		||||
	eventBroadcaster := record.NewBroadcaster()
 | 
			
		||||
	eventBroadcaster.StartLogging(klog.Infof)
 | 
			
		||||
	eventBroadcaster.StartStructuredLogging(0)
 | 
			
		||||
	eventBroadcaster.StartRecordingToSink(&v1core.EventSinkImpl{Interface: kubeClient.CoreV1().Events("")})
 | 
			
		||||
 | 
			
		||||
	if kubeClient != nil && kubeClient.CoreV1().RESTClient().GetRateLimiter() != nil {
 | 
			
		||||
 
 | 
			
		||||
@@ -51,7 +51,7 @@ func newAdapter(k8s clientset.Interface, cloud *gce.Cloud) *adapter {
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	broadcaster := record.NewBroadcaster()
 | 
			
		||||
	broadcaster.StartLogging(klog.Infof)
 | 
			
		||||
	broadcaster.StartStructuredLogging(0)
 | 
			
		||||
	ret.recorder = broadcaster.NewRecorder(scheme.Scheme, v1.EventSource{Component: "cloudCIDRAllocator"})
 | 
			
		||||
	klog.V(0).Infof("Sending events to api server.")
 | 
			
		||||
	broadcaster.StartRecordingToSink(&v1core.EventSinkImpl{
 | 
			
		||||
 
 | 
			
		||||
@@ -88,7 +88,7 @@ func NewCloudCIDRAllocator(client clientset.Interface, cloud cloudprovider.Inter
 | 
			
		||||
 | 
			
		||||
	eventBroadcaster := record.NewBroadcaster()
 | 
			
		||||
	recorder := eventBroadcaster.NewRecorder(scheme.Scheme, v1.EventSource{Component: "cidrAllocator"})
 | 
			
		||||
	eventBroadcaster.StartLogging(klog.Infof)
 | 
			
		||||
	eventBroadcaster.StartStructuredLogging(0)
 | 
			
		||||
	klog.V(0).Infof("Sending events to api server.")
 | 
			
		||||
	eventBroadcaster.StartRecordingToSink(&v1core.EventSinkImpl{Interface: client.CoreV1().Events("")})
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -78,7 +78,7 @@ func NewCIDRRangeAllocator(client clientset.Interface, nodeInformer informers.No
 | 
			
		||||
 | 
			
		||||
	eventBroadcaster := record.NewBroadcaster()
 | 
			
		||||
	recorder := eventBroadcaster.NewRecorder(scheme.Scheme, v1.EventSource{Component: "cidrAllocator"})
 | 
			
		||||
	eventBroadcaster.StartLogging(klog.Infof)
 | 
			
		||||
	eventBroadcaster.StartStructuredLogging(0)
 | 
			
		||||
	klog.V(0).Infof("Sending events to api server.")
 | 
			
		||||
	eventBroadcaster.StartRecordingToSink(&v1core.EventSinkImpl{Interface: client.CoreV1().Events("")})
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -89,7 +89,7 @@ func NewNodeIpamController(
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	eventBroadcaster := record.NewBroadcaster()
 | 
			
		||||
	eventBroadcaster.StartLogging(klog.Infof)
 | 
			
		||||
	eventBroadcaster.StartStructuredLogging(0)
 | 
			
		||||
 | 
			
		||||
	klog.Infof("Sending events to api server.")
 | 
			
		||||
	eventBroadcaster.StartRecordingToSink(
 | 
			
		||||
 
 | 
			
		||||
@@ -375,7 +375,7 @@ func NewNodeLifecycleController(
 | 
			
		||||
 | 
			
		||||
	eventBroadcaster := record.NewBroadcaster()
 | 
			
		||||
	recorder := eventBroadcaster.NewRecorder(scheme.Scheme, v1.EventSource{Component: "node-controller"})
 | 
			
		||||
	eventBroadcaster.StartLogging(klog.Infof)
 | 
			
		||||
	eventBroadcaster.StartStructuredLogging(0)
 | 
			
		||||
 | 
			
		||||
	klog.Infof("Sending events to api server.")
 | 
			
		||||
	eventBroadcaster.StartRecordingToSink(
 | 
			
		||||
 
 | 
			
		||||
@@ -158,7 +158,7 @@ func getMinTolerationTime(tolerations []v1.Toleration) time.Duration {
 | 
			
		||||
func NewNoExecuteTaintManager(c clientset.Interface, getPod GetPodFunc, getNode GetNodeFunc, getPodsAssignedToNode GetPodsByNodeNameFunc) *NoExecuteTaintManager {
 | 
			
		||||
	eventBroadcaster := record.NewBroadcaster()
 | 
			
		||||
	recorder := eventBroadcaster.NewRecorder(scheme.Scheme, v1.EventSource{Component: "taint-controller"})
 | 
			
		||||
	eventBroadcaster.StartLogging(klog.Infof)
 | 
			
		||||
	eventBroadcaster.StartStructuredLogging(0)
 | 
			
		||||
	if c != nil {
 | 
			
		||||
		klog.V(0).Infof("Sending events to api server.")
 | 
			
		||||
		eventBroadcaster.StartRecordingToSink(&v1core.EventSinkImpl{Interface: c.CoreV1().Events("")})
 | 
			
		||||
 
 | 
			
		||||
@@ -119,7 +119,7 @@ func NewHorizontalController(
 | 
			
		||||
 | 
			
		||||
) *HorizontalController {
 | 
			
		||||
	broadcaster := record.NewBroadcaster()
 | 
			
		||||
	broadcaster.StartLogging(klog.Infof)
 | 
			
		||||
	broadcaster.StartStructuredLogging(0)
 | 
			
		||||
	broadcaster.StartRecordingToSink(&v1core.EventSinkImpl{Interface: evtNamespacer.Events("")})
 | 
			
		||||
	recorder := broadcaster.NewRecorder(scheme.Scheme, v1.EventSource{Component: "horizontal-pod-autoscaler"})
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -111,7 +111,7 @@ type ReplicaSetController struct {
 | 
			
		||||
// NewReplicaSetController configures a replica set controller with the specified event recorder
 | 
			
		||||
func NewReplicaSetController(rsInformer appsinformers.ReplicaSetInformer, podInformer coreinformers.PodInformer, kubeClient clientset.Interface, burstReplicas int) *ReplicaSetController {
 | 
			
		||||
	eventBroadcaster := record.NewBroadcaster()
 | 
			
		||||
	eventBroadcaster.StartLogging(klog.Infof)
 | 
			
		||||
	eventBroadcaster.StartStructuredLogging(0)
 | 
			
		||||
	eventBroadcaster.StartRecordingToSink(&v1core.EventSinkImpl{Interface: kubeClient.CoreV1().Events("")})
 | 
			
		||||
	return NewBaseController(rsInformer, podInformer, kubeClient, burstReplicas,
 | 
			
		||||
		apps.SchemeGroupVersion.WithKind("ReplicaSet"),
 | 
			
		||||
 
 | 
			
		||||
@@ -39,7 +39,6 @@ go_library(
 | 
			
		||||
        "//staging/src/k8s.io/client-go/listers/core/v1:go_default_library",
 | 
			
		||||
        "//staging/src/k8s.io/client-go/tools/cache:go_default_library",
 | 
			
		||||
        "//staging/src/k8s.io/client-go/tools/record:go_default_library",
 | 
			
		||||
        "//vendor/k8s.io/klog/v2:go_default_library",
 | 
			
		||||
    ],
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -32,7 +32,6 @@ import (
 | 
			
		||||
	"k8s.io/client-go/kubernetes/scheme"
 | 
			
		||||
	v1core "k8s.io/client-go/kubernetes/typed/core/v1"
 | 
			
		||||
	"k8s.io/client-go/tools/record"
 | 
			
		||||
	"k8s.io/klog/v2"
 | 
			
		||||
	"k8s.io/kubernetes/pkg/controller"
 | 
			
		||||
	"k8s.io/kubernetes/pkg/controller/replicaset"
 | 
			
		||||
)
 | 
			
		||||
@@ -51,7 +50,7 @@ type ReplicationManager struct {
 | 
			
		||||
// NewReplicationManager configures a replication manager with the specified event recorder
 | 
			
		||||
func NewReplicationManager(podInformer coreinformers.PodInformer, rcInformer coreinformers.ReplicationControllerInformer, kubeClient clientset.Interface, burstReplicas int) *ReplicationManager {
 | 
			
		||||
	eventBroadcaster := record.NewBroadcaster()
 | 
			
		||||
	eventBroadcaster.StartLogging(klog.Infof)
 | 
			
		||||
	eventBroadcaster.StartStructuredLogging(0)
 | 
			
		||||
	eventBroadcaster.StartRecordingToSink(&v1core.EventSinkImpl{Interface: kubeClient.CoreV1().Events("")})
 | 
			
		||||
	return &ReplicationManager{
 | 
			
		||||
		*replicaset.NewBaseController(informerAdapter{rcInformer}, podInformer, clientsetAdapter{kubeClient}, burstReplicas,
 | 
			
		||||
 
 | 
			
		||||
@@ -82,7 +82,7 @@ func NewStatefulSetController(
 | 
			
		||||
	kubeClient clientset.Interface,
 | 
			
		||||
) *StatefulSetController {
 | 
			
		||||
	eventBroadcaster := record.NewBroadcaster()
 | 
			
		||||
	eventBroadcaster.StartLogging(klog.Infof)
 | 
			
		||||
	eventBroadcaster.StartStructuredLogging(0)
 | 
			
		||||
	eventBroadcaster.StartRecordingToSink(&v1core.EventSinkImpl{Interface: kubeClient.CoreV1().Events("")})
 | 
			
		||||
	recorder := eventBroadcaster.NewRecorder(scheme.Scheme, v1.EventSource{Component: "statefulset-controller"})
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -72,7 +72,7 @@ type Controller struct {
 | 
			
		||||
// New creates an instance of Controller
 | 
			
		||||
func New(jobInformer batchinformers.JobInformer, client clientset.Interface) *Controller {
 | 
			
		||||
	eventBroadcaster := record.NewBroadcaster()
 | 
			
		||||
	eventBroadcaster.StartLogging(klog.Infof)
 | 
			
		||||
	eventBroadcaster.StartStructuredLogging(0)
 | 
			
		||||
	eventBroadcaster.StartRecordingToSink(&v1core.EventSinkImpl{Interface: client.CoreV1().Events("")})
 | 
			
		||||
 | 
			
		||||
	if client != nil && client.CoreV1().RESTClient().GetRateLimiter() != nil {
 | 
			
		||||
 
 | 
			
		||||
@@ -151,7 +151,7 @@ func NewAttachDetachController(
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	eventBroadcaster := record.NewBroadcaster()
 | 
			
		||||
	eventBroadcaster.StartLogging(klog.Infof)
 | 
			
		||||
	eventBroadcaster.StartStructuredLogging(0)
 | 
			
		||||
	eventBroadcaster.StartRecordingToSink(&v1core.EventSinkImpl{Interface: kubeClient.CoreV1().Events("")})
 | 
			
		||||
	recorder := eventBroadcaster.NewRecorder(scheme.Scheme, v1.EventSource{Component: "attachdetach-controller"})
 | 
			
		||||
	blkutil := volumepathhandler.NewBlockVolumePathHandler()
 | 
			
		||||
 
 | 
			
		||||
@@ -134,7 +134,7 @@ func NewExpandController(
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	eventBroadcaster := record.NewBroadcaster()
 | 
			
		||||
	eventBroadcaster.StartLogging(klog.Infof)
 | 
			
		||||
	eventBroadcaster.StartStructuredLogging(0)
 | 
			
		||||
	eventBroadcaster.StartRecordingToSink(&v1core.EventSinkImpl{Interface: kubeClient.CoreV1().Events("")})
 | 
			
		||||
	expc.recorder = eventBroadcaster.NewRecorder(scheme.Scheme, v1.EventSource{Component: "volume_expand"})
 | 
			
		||||
	blkutil := volumepathhandler.NewBlockVolumePathHandler()
 | 
			
		||||
 
 | 
			
		||||
@@ -77,7 +77,7 @@ func NewController(p ControllerParameters) (*PersistentVolumeController, error)
 | 
			
		||||
	eventRecorder := p.EventRecorder
 | 
			
		||||
	if eventRecorder == nil {
 | 
			
		||||
		broadcaster := record.NewBroadcaster()
 | 
			
		||||
		broadcaster.StartLogging(klog.Infof)
 | 
			
		||||
		broadcaster.StartStructuredLogging(0)
 | 
			
		||||
		broadcaster.StartRecordingToSink(&v1core.EventSinkImpl{Interface: p.KubeClient.CoreV1().Events("")})
 | 
			
		||||
		eventRecorder = broadcaster.NewRecorder(scheme.Scheme, v1.EventSource{Component: "persistentvolume-controller"})
 | 
			
		||||
	}
 | 
			
		||||
 
 | 
			
		||||
@@ -121,6 +121,10 @@ type EventBroadcaster interface {
 | 
			
		||||
	// function. The return value can be ignored or used to stop recording, if desired.
 | 
			
		||||
	StartLogging(logf func(format string, args ...interface{})) watch.Interface
 | 
			
		||||
 | 
			
		||||
	// StartStructuredLogging starts sending events received from this EventBroadcaster to the structured
 | 
			
		||||
	// logging function. The return value can be ignored or used to stop recording, if desired.
 | 
			
		||||
	StartStructuredLogging(verbosity klog.Level) watch.Interface
 | 
			
		||||
 | 
			
		||||
	// NewRecorder returns an EventRecorder that can be used to send events to this EventBroadcaster
 | 
			
		||||
	// with the event source set to the given event source.
 | 
			
		||||
	NewRecorder(scheme *runtime.Scheme, source v1.EventSource) EventRecorder
 | 
			
		||||
@@ -279,6 +283,15 @@ func (e *eventBroadcasterImpl) StartLogging(logf func(format string, args ...int
 | 
			
		||||
		})
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// StartStructuredLogging starts sending events received from this EventBroadcaster to the structured logging function.
 | 
			
		||||
// The return value can be ignored or used to stop recording, if desired.
 | 
			
		||||
func (e *eventBroadcasterImpl) StartStructuredLogging(verbosity klog.Level) watch.Interface {
 | 
			
		||||
	return e.StartEventWatcher(
 | 
			
		||||
		func(e *v1.Event) {
 | 
			
		||||
			klog.V(verbosity).InfoS("Event occurred", "object", klog.KRef(e.InvolvedObject.Namespace, e.InvolvedObject.Name), "kind", e.InvolvedObject.Kind, "apiVersion", e.InvolvedObject.APIVersion, "type", e.Type, "reason", e.Reason, "message", e.Message)
 | 
			
		||||
		})
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// StartEventWatcher starts sending events received from this EventBroadcaster to the given event handler function.
 | 
			
		||||
// The return value can be ignored or used to stop recording, if desired.
 | 
			
		||||
func (e *eventBroadcasterImpl) StartEventWatcher(eventHandler func(*v1.Event)) watch.Interface {
 | 
			
		||||
 
 | 
			
		||||
@@ -44,7 +44,6 @@ go_test(
 | 
			
		||||
        "//staging/src/k8s.io/cloud-provider/fake:go_default_library",
 | 
			
		||||
        "//vendor/github.com/google/go-cmp/cmp:go_default_library",
 | 
			
		||||
        "//vendor/github.com/stretchr/testify/assert:go_default_library",
 | 
			
		||||
        "//vendor/k8s.io/klog/v2:go_default_library",
 | 
			
		||||
    ],
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -103,7 +103,7 @@ func NewCloudNodeController(
 | 
			
		||||
 | 
			
		||||
	eventBroadcaster := record.NewBroadcaster()
 | 
			
		||||
	recorder := eventBroadcaster.NewRecorder(scheme.Scheme, v1.EventSource{Component: "cloud-node-controller"})
 | 
			
		||||
	eventBroadcaster.StartLogging(klog.Infof)
 | 
			
		||||
	eventBroadcaster.StartStructuredLogging(0)
 | 
			
		||||
 | 
			
		||||
	klog.Infof("Sending events to api server.")
 | 
			
		||||
	eventBroadcaster.StartRecordingToSink(&v1core.EventSinkImpl{Interface: kubeClient.CoreV1().Events("")})
 | 
			
		||||
 
 | 
			
		||||
@@ -37,8 +37,6 @@ import (
 | 
			
		||||
 | 
			
		||||
	"github.com/google/go-cmp/cmp"
 | 
			
		||||
	"github.com/stretchr/testify/assert"
 | 
			
		||||
 | 
			
		||||
	"k8s.io/klog/v2"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
func TestEnsureNodeExistsByProviderID(t *testing.T) {
 | 
			
		||||
@@ -692,7 +690,7 @@ func Test_AddCloudNode(t *testing.T) {
 | 
			
		||||
				recorder:                  eventBroadcaster.NewRecorder(scheme.Scheme, v1.EventSource{Component: "cloud-node-controller"}),
 | 
			
		||||
				nodeStatusUpdateFrequency: 1 * time.Second,
 | 
			
		||||
			}
 | 
			
		||||
			eventBroadcaster.StartLogging(klog.Infof)
 | 
			
		||||
			eventBroadcaster.StartLogging(t.Logf)
 | 
			
		||||
 | 
			
		||||
			cloudNodeController.AddCloudNode(context.TODO(), test.existingNode)
 | 
			
		||||
 | 
			
		||||
@@ -770,7 +768,7 @@ func TestGCECondition(t *testing.T) {
 | 
			
		||||
		recorder:                  eventBroadcaster.NewRecorder(scheme.Scheme, v1.EventSource{Component: "cloud-node-controller"}),
 | 
			
		||||
		nodeStatusUpdateFrequency: 1 * time.Second,
 | 
			
		||||
	}
 | 
			
		||||
	eventBroadcaster.StartLogging(klog.Infof)
 | 
			
		||||
	eventBroadcaster.StartLogging(t.Logf)
 | 
			
		||||
 | 
			
		||||
	cloudNodeController.AddCloudNode(context.TODO(), existingNode)
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -72,7 +72,7 @@ func NewCloudNodeLifecycleController(
 | 
			
		||||
 | 
			
		||||
	eventBroadcaster := record.NewBroadcaster()
 | 
			
		||||
	recorder := eventBroadcaster.NewRecorder(scheme.Scheme, v1.EventSource{Component: "cloud-node-lifecycle-controller"})
 | 
			
		||||
	eventBroadcaster.StartLogging(klog.Infof)
 | 
			
		||||
	eventBroadcaster.StartStructuredLogging(0)
 | 
			
		||||
 | 
			
		||||
	klog.Info("Sending events to api server")
 | 
			
		||||
	eventBroadcaster.StartRecordingToSink(&v1core.EventSinkImpl{Interface: kubeClient.CoreV1().Events("")})
 | 
			
		||||
 
 | 
			
		||||
@@ -290,7 +290,7 @@ func Test_NodesDeleted(t *testing.T) {
 | 
			
		||||
				nodeMonitorPeriod: 1 * time.Second,
 | 
			
		||||
			}
 | 
			
		||||
 | 
			
		||||
			eventBroadcaster.StartLogging(klog.Infof)
 | 
			
		||||
			eventBroadcaster.StartLogging(t.Logf)
 | 
			
		||||
			cloudNodeLifecycleController.MonitorNodes()
 | 
			
		||||
 | 
			
		||||
			updatedNode, err := clientset.CoreV1().Nodes().Get(context.TODO(), testcase.existingNode.Name, metav1.GetOptions{})
 | 
			
		||||
 
 | 
			
		||||
@@ -77,7 +77,7 @@ func New(routes cloudprovider.Routes, kubeClient clientset.Interface, nodeInform
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	eventBroadcaster := record.NewBroadcaster()
 | 
			
		||||
	eventBroadcaster.StartLogging(klog.Infof)
 | 
			
		||||
	eventBroadcaster.StartStructuredLogging(0)
 | 
			
		||||
	recorder := eventBroadcaster.NewRecorder(scheme.Scheme, v1.EventSource{Component: "route_controller"})
 | 
			
		||||
 | 
			
		||||
	rc := &RouteController{
 | 
			
		||||
 
 | 
			
		||||
@@ -53,7 +53,6 @@ go_test(
 | 
			
		||||
        "//staging/src/k8s.io/client-go/util/workqueue:go_default_library",
 | 
			
		||||
        "//staging/src/k8s.io/cloud-provider/fake:go_default_library",
 | 
			
		||||
        "//staging/src/k8s.io/cloud-provider/service/helpers:go_default_library",
 | 
			
		||||
        "//vendor/k8s.io/klog/v2:go_default_library",
 | 
			
		||||
    ],
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -126,7 +126,7 @@ func New(
 | 
			
		||||
	featureGate featuregate.FeatureGate,
 | 
			
		||||
) (*Controller, error) {
 | 
			
		||||
	broadcaster := record.NewBroadcaster()
 | 
			
		||||
	broadcaster.StartLogging(klog.Infof)
 | 
			
		||||
	broadcaster.StartStructuredLogging(0)
 | 
			
		||||
	broadcaster.StartRecordingToSink(&v1core.EventSinkImpl{Interface: kubeClient.CoreV1().Events("")})
 | 
			
		||||
	recorder := broadcaster.NewRecorder(scheme.Scheme, v1.EventSource{Component: "service-controller"})
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -42,7 +42,6 @@ import (
 | 
			
		||||
	"k8s.io/client-go/util/workqueue"
 | 
			
		||||
	fakecloud "k8s.io/cloud-provider/fake"
 | 
			
		||||
	servicehelper "k8s.io/cloud-provider/service/helpers"
 | 
			
		||||
	"k8s.io/klog/v2"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
const region = "us-central"
 | 
			
		||||
@@ -79,7 +78,7 @@ func newController() (*Controller, *fakecloud.Cloud, *fake.Clientset) {
 | 
			
		||||
	nodeInformer := informerFactory.Core().V1().Nodes()
 | 
			
		||||
 | 
			
		||||
	broadcaster := record.NewBroadcaster()
 | 
			
		||||
	broadcaster.StartLogging(klog.Infof)
 | 
			
		||||
	broadcaster.StartStructuredLogging(0)
 | 
			
		||||
	broadcaster.StartRecordingToSink(&v1core.EventSinkImpl{Interface: kubeClient.CoreV1().Events("")})
 | 
			
		||||
	recorder := broadcaster.NewRecorder(scheme.Scheme, v1.EventSource{Component: "service-controller"})
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -1369,7 +1369,7 @@ func (c *Cloud) Initialize(clientBuilder cloudprovider.ControllerClientBuilder,
 | 
			
		||||
	c.clientBuilder = clientBuilder
 | 
			
		||||
	c.kubeClient = clientBuilder.ClientOrDie("aws-cloud-provider")
 | 
			
		||||
	c.eventBroadcaster = record.NewBroadcaster()
 | 
			
		||||
	c.eventBroadcaster.StartLogging(klog.Infof)
 | 
			
		||||
	c.eventBroadcaster.StartStructuredLogging(0)
 | 
			
		||||
	c.eventBroadcaster.StartRecordingToSink(&v1core.EventSinkImpl{Interface: c.kubeClient.CoreV1().Events("")})
 | 
			
		||||
	c.eventRecorder = c.eventBroadcaster.NewRecorder(scheme.Scheme, v1.EventSource{Component: "aws-cloud-provider"})
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
@@ -97,7 +97,7 @@ func NewController(
 | 
			
		||||
	utilruntime.Must(samplescheme.AddToScheme(scheme.Scheme))
 | 
			
		||||
	klog.V(4).Info("Creating event broadcaster")
 | 
			
		||||
	eventBroadcaster := record.NewBroadcaster()
 | 
			
		||||
	eventBroadcaster.StartLogging(klog.Infof)
 | 
			
		||||
	eventBroadcaster.StartStructuredLogging(0)
 | 
			
		||||
	eventBroadcaster.StartRecordingToSink(&typedcorev1.EventSinkImpl{Interface: kubeclientset.CoreV1().Events("")})
 | 
			
		||||
	recorder := eventBroadcaster.NewRecorder(scheme.Scheme, corev1.EventSource{Component: controllerAgentName})
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user