Heim > Artikel > Backend-Entwicklung > Rufen Sie Openshift-ConfigMap-Daten mit Python ab
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)
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.
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
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", } }
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)
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)
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!