Maison > développement back-end > Golang > Comment surveiller les modifications des ressources personnalisées externes dans Kubebuilder sans importer de types externes

Comment surveiller les modifications des ressources personnalisées externes dans Kubebuilder sans importer de types externes

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
Libérer: 2024-02-06 10:00:11
avant
668 Les gens l'ont consulté

如何在 kubebuilder 中监视外部自定义资源更改而不导入外部类型

Contenu de la question

Supposons que j'ai l'extrait de code suivant, qui configure un coordinateur qui surveille une ressource externe "externe" :

// SetupWithManager sets up the controller with the Manager.
func (r *SomethingReconciler) SetupWithManager(mgr ctrl.Manager) error {
    return ctrl.NewControllerManagedBy(mgr).
        For(&api.Something{}).
        WithOptions(controller.Options{
            MaxConcurrentReconciles: stdruntime.NumCPU(),
            RecoverPanic:            true,
        }).
        Watches(
            &source.Kind{Type: &somev1.External{}},
            handler.EnqueueRequestsFromMapFunc(r.findInternalObjectsForExternal),
            builder.WithPredicates(predicate.Funcs{
                UpdateFunc: func(ue event.UpdateEvent) bool { return true },
                DeleteFunc: func(de event.DeleteEvent) bool { return true },
            }),
        ).
        Complete(r)
}
Copier après la connexion

Mon problème est que je ne peux pas importer le type somev1.external dans mon projet car importer un module go contenant ce type briserait les dépendances de mon projet actuel.

Existe-t-il un moyen dans Kubebuilder de surveiller les ressources externes sans importer explicitement leurs types ? Comme gvk ou quelque chose comme ça ?


Bonne réponse


Oui, c'est possible.

Vous pouvez créer un client de repos pour votre ressource dans main.go comme ceci :

gvkexternal := schema.groupversionkind{
    group:   "some.group.io",
    version: "v1",
    kind:    "external",
}

restclient, err := apiutil.restclientforgvk(gvkexternal, false, mgr.getconfig(), serializer.newcodecfactory(mgr.getscheme()))
if err != nil {
    setuplog.error(err, "unable to create rest client")
}
Copier après la connexion

Puis mettez cette structure reste client (rest.interface) 的字段添加到您的协调器 (yournativeresource_controller.go), par exemple :

type yournativeresourcereconciler struct {
    client.client
    scheme        *runtime.scheme
    // add this
    restclient    rest.interface
}
Copier après la connexion

Enfin, initialisez votre coordinateur à l'aide de ce client de repos (main.go) :

if err = (&controllers.yournativeresourcereconciler{
    client:        mgr.getclient(),
    scheme:        mgr.getscheme(),
    restclient:    restclient,
}).setupwithmanager(mgr); err != nil {
    setuplog.error(err, "unable to create controller", "controller", "yournativeresource")
    os.exit(1)
}
Copier après la connexion

N'oubliez pas d'ajouter le tag rbac à votre projet (le coordinateur de préférence), il générera des règles rbac vous permettant de fonctionner external Ressources :

//+kubebuilder:rbac:groups=some.group.io,resources=externals,verbs=get;list;watch;create;update;patch;delete
Copier après la connexion

Après avoir terminé ces étapes, vous pouvez utiliser le client rest via le coordinateur yournativeresource (utilisez r.restclient pour manipuler la ressource yournativeresource 协调器(使用 r.restclient 来操作 external.

)

Éditeur :

Si vous souhaitez regarder des sources, un client dynamique peut être utile. Créez un client dynamique dans main.go :

dynamicclient, err := dynamic.newforconfig(mgr.getconfig())
if err != nil {
    setuplog.error(err, "unable to create dynamic client")
}
Copier après la connexion

Appliquez les étapes ci-dessus, ajoutez-le à votre coordinateur, etc. Vous pourrez alors regarder la external ressource comme indiqué ci-dessous :

resourceInterface := r.DynamicClient.Resource(schema.GroupVersionResource{
    Group:    "some.group.io",
    Version:  "",
    Resource: "externals",
})
externalWatcher, err := resourceInterface.Watch(ctx, metav1.ListOptions{})
if err != nil {
    return err
}

defer externalWatcher.Stop()

select {
case event := <-externalWatcher.ResultChan():
    if event.Type == watch.Deleted {
        logger.Info("FINALIZER: An external resource is deleted.")
    }
}
Copier après la connexion

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

source:stackoverflow.com
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal