Heim > Backend-Entwicklung > Python-Tutorial > Rufen Sie Openshift-ConfigMap-Daten mit Python ab

Rufen Sie Openshift-ConfigMap-Daten mit Python ab

王林
Freigeben: 2024-02-22 12:31:11
nach vorne
611 Leute haben es durchsucht

使用 python 获取 Openshift ConfigMap 数据

Frageninhalt

Ich versuche, die OpenShift-Python-Bibliothek zu verwenden, um die Daten der ConfigMap im Projekt abzurufen. Ich habe den Namen der Konfigurationszuordnung herausgefunden, kann aber in der Dokumentation Funktionen oder Beispiele zum Extrahieren der Daten finden. Ist jemand auf dieses Problem gestoßen oder weiß, wie man das macht?

Dies ist der Code, den ich verwende, um den cm-Namen zu erhalten (gibt ein Wörterbuch zurück):

import openshift as oc

if __name__ == '__main__':
    project_selector = oc.selector('projects')
    projects = project_selector.objects()
    number_of_projects = len(projects)
    for project in projects:
        name = project.model.metadata.name
        oc.invoke('project', name)
        tokens = oc.invoke('get', ['configmaps']).actions()[0].as_dict()['out'].replace('\n', ' ').split(' ')
        configmap_data = [x for x in tokens if len(x) > 0 and not x.isupper()]
        print(configmap_data)
Nach dem Login kopieren

Ich habe versucht, mit oc.selector 并使用 with oc.selector(project_name): einige Daten abzurufen, konnte aber keine Möglichkeit finden, sie abzurufen.

Bitte beachten Sie, dass ich nicht den Befehl oc cmd verwenden muss, sondern Python verwenden muss. Im Moment brauche ich nur die Daten und schaue, wie ich sie später ändern kann.

Vielen Dank.


Richtige Antwort


Wenn Sie oc.invoke verwenden, müssen Sie die entsprechenden Befehlszeilenargumente übergeben. Überlegen Sie, was passieren würde, wenn Sie denselben Befehl manuell ausführen würden:

$ oc get configmaps
name                                                   data   age
coredns                                                1      54d
extension-apiserver-authentication                     6      54d
kube-apiserver-legacy-service-account-token-tracking   1      54d
kube-proxy                                             2      54d
kube-root-ca.crt                                       1      54d
kubeadm-config                                         1      54d
kubelet-config                                         1      54d
Nach dem Login kopieren

Sie erfahren den Namen, aber nicht den Inhalt. Wenn Sie Inhalte wünschen, müssen Sie ein geeigneteres Ausgabeformat wählen, z. B. -o json:

$ oc get configmaps kubelet-config -o json
{
    "apiversion": "v1",
    "data": {
        ...
    },
    "kind": "configmap",
    "metadata": {
        "name": "kubelet-config",
        "namespace": "kube-system",
    }
}
Nach dem Login kopieren

Sie müssen die gleichen Parameter in den Aufruf von oc.invoke einbeziehen. So etwas zeigt, wie die Dinge funktionieren:

import openshift as oc
import json

project_selector = oc.selector('projects')
projects = project_selector.objects()
for project in projects:
    # get a list of configmap names
    configmaps = oc.invoke('get', ['-n', project.name(), '-o', 'name', 'configmaps'])

    # for each configmap, get the content
    for cm in configmaps.out().splitlines():
        out = oc.invoke('get', ['-n', project.name(), '-o', 'json', cm])
        manifest = json.loads(out.out())
        data = manifest['data']
        print(data)
Nach dem Login kopieren

Das funktioniert, aber tu es nicht.

Natürlich wissen Sie bereits, wie man Selektoren verwendet, denn auf diese Weise iterieren Sie über Ihre Elemente. Sie sollten die gleiche Technik verwenden, um die Konfigurationszuordnung zu durchlaufen:

import openshift as oc

projects = oc.selector('projects')
for project in projects.objects():
    with oc.project(project.name()):
        configmaps = oc.selector('configmaps')
        for cm in configmaps.objects():
            data = cm.as_dict()['data']
            print(data)
Nach dem Login kopieren

Dies basiert stark auf Beispielen direkt aus der Dokumentation. Iterieren Sie configmaps.objects(), um ein API-Objekt für jede Konfigurationszuordnung zu erhalten. Sie können auf den Namen und den Inhalt zugreifen.

Das obige ist der detaillierte Inhalt vonRufen Sie Openshift-ConfigMap-Daten mit Python ab. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:stackoverflow.com
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage