【云原生--K8S】K8S python接口研究

本文介绍了如何在Ubuntu容器环境中使用Python操作Kubernetes集群,包括复制kubeconfig文件到容器、获取节点和Service信息,以及探讨了常用的Kubernetes API。通过示例展示了Python程序如何调用接口获取详细的JSON格式数据,并提取关键信息。
摘要由CSDN通过智能技术生成


前言

在前面的文章中我们都是通过kubectl命令行来访问操作K8S,但是在实际应用中可能需要提供更方便操作的图形化界面,所以K8S官方就提供了两种API接口:基于GO语言的client-go和基于python的kubernetes。本篇我们先来研究一下基于python的kubernetes接口。


一、搭建ubuntu运行环境

由于我们的k8s环境还是部署在windows11的Docker Desktop中的,为了便于研究演示,我们准备在docker中运行一个带python的ubuntu镜像,在这个镜像容器中编写python程序访问k8s。

1.运行ubuntu容器

首先我们编写一个ubuntu-dockerfile如下:

# 使用Ubuntu20.04作为基础镜像
FROM ubuntu:20.04
 
# 安装Python
RUN apt-get update && apt-get install -y python3 python3-pip

# 安装vim
RUN apt-get update && apt-get install -y vim

# 下载kubernetes python接口
RUN pip install kubernetes

生成ubuntu-test:v1镜像:docker build -f ./ubuntu-dockerfile -t ubuntu-test:v1 .
运行并命令行进入ubuntu-test:v1容器:docker run -it ubuntu-test:v1 bash
在这里插入图片描述
在这个容器/usr/local目录下创建test目录,然后在test目录下创建config目录。注意上图标红的为容器ID。

2.拷贝kubeconfig文件

在windows系统C:\Users\目录下找到.kube文件夹,里面有一个config文件,这个文件保存kubectl命令行连接k8s的信息,我们需要把这个文件拷贝到ubuntu-test:v1容器中,然后改名为kubeconfig.yaml。
docker cp config CONTAINER_ID:/usr/local/test/config命令可以把本机的文件拷贝到容器指定目录中,如下图所示:
在这里插入图片描述

二、python程序获取k8s信息

环境准备好后我们就可以在这个容器中编写python程序,通过调用kubernetes接口获取k8s信息。

1.获取node信息

编写node.py程序调用list_node函数获取node信息。

from kubernetes import client, config
import json
print("get k8s node")

def list_allnode():
    config_file="/usr/local/test/config/kubeconfig.yaml"
    config.load_kube_config(config_file=config_file)

    v1 = client.CoreV1Api()

    api_response = v1.list_node()

    return api_re
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值