我开发了一个k8s操作符,在第一个命名空间中部署了第一个操作符之后,它运行得很好。然后,我在第二个名称空间中部署了第二个操作符,我看到了第二个控制器来获得请求,这个请求的名称空间仍然是第一个名称,但是预期的名称空间应该是第二个。
请看下面的代码,当我在第二个名称空间中使用第二个运算符时,请求的名称空间仍然是第一个名称空间。
func (r *AnexampleReconciler) Reconcile(request ctrl.Request) (ctrl.Result, error) {
log := r.Log.WithValues("Anexample", request.NamespacedName)
instance := &v1alpha1.Anexample{}
err := r.Get(context.TODO(), request.NamespacedName, instance)
if err != nil {
if errors.IsNotFound(err) {
log.Info("Anexample resource not found. Ignoring since object must be deleted.")
return reconcile.Result{}, nil
}
log.Error(err, "Failed to get Anexample.")
return reconcile.Result{}, err
}
我怀疑这可能与选举有关,但我不明白。
mgr, err := ctrl.NewManager(ctrl.GetConfigOrDie(), ctrl.Options{
Scheme: scheme,
MetricsBindAddress: metricsAddr,
Port: 9443,
LeaderElection: enableLeaderElection,
LeaderElectionID: "2eeda3e4.com.aaa.bbb.ccc",
})
if err != nil {
setupLog.Error(err, "unable to start manager")
os.Exit(1)
}
在控制器里发生了什么?怎么修呢?
发布于 2022-03-17 15:13:27
我们也看到了类似的问题。问题在于获取错误的命名空间。可能是控制器运行时的错误。
来自控制器运行时的request.NamespacedName返回错误的命名空间。
发布于 2022-02-07 13:13:41
request.Namespaced
取决于您正在部署的自定义资源的命名空间。
运算符部署在命名空间中,但仍然可以配置为侦听所有命名空间中的自定义资源。这不应与选举有关,而应与您设置经理的方式有关。您没有在ctrl.Options
中为管理器指定名称空间,因此它将侦听所有名称空间中的CR更改。如果希望运算符只侦听一个名称空间,请将名称空间传递给经理。
mgr, err := ctrl.NewManager(ctrl.GetConfigOrDie(), ctrl.Options{
Scheme: scheme,
MetricsBindAddress: metricsAddr,
Port: 9443,
LeaderElection: enableLeaderElection,
LeaderElectionID: "2eeda3e4.com.aaa.bbb.ccc",
Namesace: "<namespace-of-operator-two>",
})
if err != nil {
setupLog.Error(err, "unable to start manager")
os.Exit(1)
}
https://stackoverflow.com/questions/64653465
复制相似问题