使用 Django 构建支持 Kubernetes API 测试连接的 POST 接口
文章目录
- 使用 Django 构建支持 Kubernetes API 测试连接的 POST 接口
- 功能需求
- 使用 kubectl 获取 Token
- 命令解析
- 输出示例
- 完整代码实现
- Kubernetes API 客户端类
- 功能说明
- Django 接口视图
- 关键点解析
- 路由配置
- 接口测试
- 请求示例
- 响应结果
- 成功
- 错误
- 优化建议
- 1. 安全性
- 2. 错误处理
- 3. 扩展返回数据
- 完整代码示例
- Kubernetes API 客户端类
- Django 接口视图
- 路由配置
- 完整代码说明
- 总结
使用 Django 构建支持 Kubernetes API 测试连接的 POST 接口
在 Kubernetes 集群运维和开发中,验证集群的连通性和资源访问权限是常见需求。本文将以 Django 框架为基础,构建一个只支持 POST 请求的接口,用于测试 Kubernetes 集群连接并获取默认命名空间中的 Pod 列表。
功能需求
- 用户通过 HTTP 接口传递 Kubernetes API 地址、Token 和端口。
- 系统验证请求参数的完整性并测试 Kubernetes 集群的连通性。
- 返回默认命名空间的 Pod 列表或具体的错误信息。
- 限制接口仅支持
POST请求。
使用 kubectl 获取 Token
在 Kubernetes 中,Token 通常存储在 Secret 资源中,并且用于访问集群的 API。以下命令可以帮助您获取 Kubernetes 系统命名空间中的 Token:
kubectl -n kube-system describe $(kubectl -n kube-system get secret -n kube-system -o name | grep namespace) | grep token
命令解析
kubectl -n kube-system get secret -n kube-system -o name: 该命令列出kube-system命名空间中的所有 Secret 资源,并只输出 Secret 的名字。grep namespace: 过滤出包含namespace字符串的 Secret 名称。通常,集群的服务账户 Token 存储在名为namespace-xxxxx的 Secret 中。kubectl -n kube-system describe <secret_name>: 通过describe命令获取该 Secret 的详细信息。grep token: 从 Secret 的详细信息中提取包含 Token 的部分。
输出示例
该命令会输出类似于以下内容的 Token:
token: eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9...
完整代码实现
以下代码基于 Python 和 Django 框架,分为 Kubernetes API 客户端类、接口视图函数以及路由配置三部分。
Kubernetes API 客户端类
我们定义了一个 KubernetesClient 类,封装与 Kubernetes API 的交互逻辑。
from kubernetes import clientclass KubernetesClient:def __init__(self, host, token):"""初始化 Kubernetes API 客户端"""# 配置 Kubernetes API 客户端k8s_config = client.Configuration()k8s_config.host = hostk8s_config.verify_ssl = False # 禁用 SSL 验证(仅测试环境使用)k8s_config.api_key = {"authorization": "Bearer " + token}client.Configuration.set_default(k8s_config)# 初始化核心和应用 APIself.k8s_core_v1 = client.CoreV1Api()def get_pods(self, namespace="default"):"""获取指定命名空间中的 Pod 列表"""try:pods = self.k8s_core_v1.list_namespaced_pod(namespace=namespace)return [pod.metadata.name for pod in pods.items]except client.ApiException as e:raise Exception(f"获取 Pod 列表失败:{e}")
功能说明
- 初始化时配置 Kubernetes API 地址和认证 Token。
get_pods方法通过list_namespaced_pod获取 Pod 列表并返回 Pod 名称。
Django 接口视图
在 Django 中,我们通过视图函数实现接口逻辑,并限制只支持 POST 请求。
from django.http import JsonResponse
import jsondef test_join(request):"""测试 Kubernetes 集群的连接"""# 检查请求方法是否为 POSTif request.method != "POST":return JsonResponse({"code": 405, "message": "仅支持 POST 请求"})# 提取请求参数try:body = json.loads(request.body)ipaddr = body.get("ipaddr")token = body.get("secret_key")port = body.get("port")if not all([ipaddr, token, port]):return JsonResponse({"code": 400, "message": "请输入正确的参数"})except json.JSONDecodeError:return JsonResponse({"code": 400, "message": "请求数据格式错误"})# 构造 Kubernetes API 地址host = f"https://{ipaddr}:{port}"try:# 初始化 Kubernetes 客户端kube_client = KubernetesClient(host, token)pods = kube_client.get_pods()return JsonResponse({"code": 200, "message": "连接成功", "data": pods})except Exception as e:return JsonResponse({"code": 400, "message": f"连接失败: {str(e)}"})
关键点解析
- 请求方法限制:
- 使用
request.method检查请求类型,如果不是POST返回 HTTP 405 状态码。
- 使用
- 参数验证:
- 从请求体中解析
ipaddr、token和port,确保参数完整且格式正确。
- 从请求体中解析
- 连接测试:
- 通过
KubernetesClient测试连接并获取默认命名空间中的 Pod 列表。
- 通过
- 错误处理:
- 捕获参数错误、Kubernetes API 异常等,并返回详细的错误信息。
路由配置
将视图函数绑定到路由,使其可以通过 HTTP 调用:
from django.urls import path
from .views import test_joinurlpatterns = [path('join_test/', test_join),
]
接口测试
以下是测试接口的示例。
请求示例
使用 curl 工具发送 POST 请求:
curl -X POST http://127.0.0.1:8000/join_test/ \
-H "Content-Type: application/json" \
-d '{"ipaddr": "192.168.1.10","secret_key": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9...","port": 6443
}'
响应结果
成功
如果连接成功并获取到 Pod 列表,返回如下结果:
{"code": 200,"message": "连接成功","data": ["nginx-deployment-7c77f6df69-8wmdt", "redis-pod"]
}
错误
- 非
POST请求:{"code": 405,"message": "仅支持 POST 请求" } - 参数缺失:
{"code": 400,"message": "请输入正确的参数" } - 集群认证失败:
{"code": 400,"message": "连接失败: Unauthorized" }
优化建议
1. 安全性
- 启用 SSL 验证:将
verify_ssl设置为True,并配置证书路径。 - 使用环境变量管理敏感信息(如 Token)。
2. 错误处理
- 针对不同异常返回精确的错误码(如认证失败返回
401,资源未找到返回404)。
3. 扩展返回数据
在返回的 Pod 列表中附加更多信息,例如 Pod 的状态、节点信息等:
return [{"name": pod.metadata.name,"status": pod.status.phase,"node": pod.spec.node_name
} for pod in pods.items]
完整代码示例
以下是完整的代码示例,包括 Kubernetes API 客户端类、Django 视图函数和路由配置,确保能够实现测试 Kubernetes 集群连接并返回 Pod 列表的功能:
Kubernetes API 客户端类
from kubernetes import clientclass KubernetesClient:def __init__(self, host, token):"""初始化 Kubernetes API 客户端"""# 配置 Kubernetes API 客户端k8s_config = client.Configuration()k8s_config.host = hostk8s_config.verify_ssl = False # 禁用 SSL 验证(仅测试环境使用)k8s_config.api_key = {"authorization": "Bearer " + token}client.Configuration.set_default(k8s_config)# 初始化核心和应用 APIself.k8s_core_v1 = client.CoreV1Api()def get_pods(self, namespace="default"):"""获取指定命名空间中的 Pod 列表"""try:pods = self.k8s_core_v1.list_namespaced_pod(namespace=namespace)return [pod.metadata.name for pod in pods.items]except client.ApiException as e:raise Exception(f"获取 Pod 列表失败:{e}")
Django 接口视图
from django.http import JsonResponse
import json
from .kubernetes_client import KubernetesClientdef test_join(request):"""测试 Kubernetes 集群的连接"""# 检查请求方法是否为 POSTif request.method != "POST":return JsonResponse({"code": 405, "message": "仅支持 POST 请求"}, status=405)# 提取请求参数try:body = json.loads(request.body)ipaddr = body.get("ipaddr")token = body.get("secret_key")port = body.get("port")if not all([ipaddr, token, port]):return JsonResponse({"code": 400, "message": "请输入正确的参数"})except json.JSONDecodeError:return JsonResponse({"code": 400, "message": "请求数据格式错误"})# 构造 Kubernetes API 地址host = f"https://{ipaddr}:{port}"try:# 初始化 Kubernetes 客户端kube_client = KubernetesClient(host, token)pods = kube_client.get_pods()return JsonResponse({"code": 200, "message": "连接成功", "data": pods})except Exception as e:return JsonResponse({"code": 400, "message": f"连接失败: {str(e)}"})
路由配置
from django.urls import path
from .views import test_joinurlpatterns = [path('join_test/', test_join),
]
完整代码说明
-
KubernetesClient 类:
KubernetesClient类封装了与 Kubernetes 集群的连接和交互,特别是获取 Pod 列表的功能。get_pods方法通过 Kubernetes API 获取指定命名空间中的 Pod 列表。
-
test_join 视图函数:
- 视图函数仅支持
POST请求,使用request.method检查请求类型。 - 提取请求体中的
ipaddr、secret_key和port参数,确保这些参数完整且正确。 - 使用
KubernetesClient测试 Kubernetes 集群连接并返回 Pod 列表。
- 视图函数仅支持
-
路由配置:
- 配置了路由,使得用户可以通过
POST请求访问/join_test/路径进行集群连接测试。
- 配置了路由,使得用户可以通过
总结
本文详细介绍了如何通过 Django 构建一个只支持 POST 请求的接口,用于测试 Kubernetes 集群连接和获取 Pod 列表。通过请求方法限制、参数验证和异常处理,该接口在功能性和安全性上都有较好的保障。希望对您有所帮助!
相关文章:
使用 Django 构建支持 Kubernetes API 测试连接的 POST 接口
文章目录 使用 Django 构建支持 Kubernetes API 测试连接的 POST 接口功能需求使用 kubectl 获取 Token命令解析输出示例 完整代码实现Kubernetes API 客户端类功能说明 Django 接口视图关键点解析 路由配置 接口测试请求示例响应结果成功错误 优化建议1. 安全性2. 错误处理3. …...
十二、正则表达式、元字符、替换修饰符、手势和对话框插件
1. 正则表达式 1.1 基本使用 <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>Document</title&g…...
计算机毕业设计Python+大模型美食推荐系统 美食可视化 美食数据分析大屏 美食爬虫 美团爬虫 机器学习 大数据毕业设计 Django Vue.js
温馨提示:文末有 CSDN 平台官方提供的学长联系方式的名片! 温馨提示:文末有 CSDN 平台官方提供的学长联系方式的名片! 温馨提示:文末有 CSDN 平台官方提供的学长联系方式的名片! 作者简介:Java领…...
【后端面试总结】MySQL索引
数据库索引不只一种实现方法,但是其中最具代表性,也是我们面试中遇到最多的无疑是B树。 索引为什么选择B树 数据量很大的查找,是不能直接放入内存的,而是需要什么数据就通过磁盘IO去获得。 红黑树,AVL树等二叉查找树…...
[蓝桥杯 2021 省 AB2] 小平方
题目描述 小蓝发现,对于一个正整数 nn 和一个小于 nn 的正整数 vv,将 vv 平方后对 nn 取余可能小于 nn 的一半,也可能大于等于 nn 的一半。 请问,在 11 到 n−1n−1 中, 有多少个数平方后除以 nn 的余数小于 nn 的一半。 例如&…...
Jmeter测试工具的安装和使用,mac版本,jmeter版本5.2.1
Jmeter测试工具的安装和使用JSON格式请求 一、安装1、安装jdk包和设置java环境2、去官网下载Jmeter3、解压后,打开mac终端,进入apache-jmeter的bin文件开启jmeter 二、使用jmeter1、添加线程2、添加HTTP请求3、配置请求的协议、IP地址、端口号、请求方法…...
kmeans 最佳聚类个数 | 轮廓系数(越大越好)
轮廓系数越大,表示簇内实例之间紧凑,簇间距离大,这正是聚类的标准概念。 簇内的样本应该尽可能相似。不同簇之间应该尽可能不相似。 目的:鸢尾花数据进行kmeans聚类,最佳聚类个数是多少? plot(iris[,1:4…...
【纪念365天】我的创作纪念日
过去的一年 没有注意加入csdn已经有一年了。 这几天翻看小猴儿的通知才发现时间来到了一年的纪念日。稍稍思索想要将这一段时间的学习到的知识以及偶然遇到的机遇做一下总结。 上一次写纪念日是来到csdn128天的时候, 200天前我的学习状态是非常疯狂的。 只记得我当时…...
Opencv+ROS实现颜色识别应用
目录 一、工具 二、原理 概念 本质 三、实践 添加发布话题 主要代码 四、成果 五、总结 一、工具 opencvros ubuntu18.04 摄像头 二、原理 概念 彩色图像:RGB(红,绿,蓝) HSV图像:H࿰…...
蓝桥杯c++算法秒杀【6】之动态规划【下】(数字三角形、砝码称重(背包问题)、括号序列、异或三角:::非常典型的必刷例题!!!)
别忘了请点个赞收藏关注支持一下博主喵!!!! ! ! ! ! 关注博主,更多蓝桥杯nice题目静待更新:) 动态规划 三、括号序列 【问题描述】 给定一个括号序列,要求尽可能少地添加若干括号使得括号序列变得合…...
C++设计模式(单例模式)
一、介绍 1.动机 在软件系统中,经常有这样一些特殊的类,必须保证它们在系统中只存在一个实例,才能确保它们的逻辑正确性、以及良好的效率。 如何绕过常规的构造器,提供一种机制来保证一个类只有一个实例? 这应该是类设计者的…...
前端---CSS(部分用法)
HTML画页面--》这个页面就是页面上需要的元素罗列起来,但是页面效果很差,不好看,为了让页面好看,为了修饰页面---》CSS CSS的作用:修饰HTML页面 用了CSS之后,样式和元素本身做到了分离的效果。---》降低了代…...
2024年最新版Java八股文复习
最新版本Java八股文复习,每天更新一篇,博主正在持续努力更新中~~~ 一、Java基础篇1、怎么理解面向对象?简单说说封装、继承、多态三大特性?2、多态体现在哪几个方面?3、面向对象的设计原则你知道有哪些吗?4…...
计算机毕业设计Hadoop+Spark音乐推荐系统 音乐预测系统 音乐可视化大屏 音乐爬虫 HDFS hive数据仓库 机器学习 深度学习 大数据毕业设计
温馨提示:文末有 CSDN 平台官方提供的学长联系方式的名片! 温馨提示:文末有 CSDN 平台官方提供的学长联系方式的名片! 温馨提示:文末有 CSDN 平台官方提供的学长联系方式的名片! 作者简介:Java领…...
MyBatis高级扩展
一、Mapper批量映射优化: 1.需求: Mapper 配置文件很多时,在全局配置文件中一个一个注册太麻烦,希望有一个办法能够一劳永逸 2.配置方式: Mybatis允许在指定Mapper映射文件时,只指定其所在的包: <mappers><package name"c…...
代码美学2:MATLAB制作渐变色
效果: %代码美学:MATLAB制作渐变色 % 创建一个10x10的矩阵来表示热力图的数据 data reshape(1:100, [10, 10]);% 创建热力图 figure; imagesc(data);% 设置颜色映射为“cool” colormap(cool);% 在热力图上添加边框 axis on; grid on;% 设置热力图的颜色…...
浅谈- “ 变量中 无符号 与 有符号 的 值转换 ”
在同一个表达式中,若同时出现 无符号变量 与 有符号变量 : 1、都转换为无符号类型:(注:2^324294967296)即unsigned int 的最大值 2、然后再运行表达式 实例: #include <stdio.h>char fun(…...
【AI绘画】Midjourney进阶:色调详解(上)
博客主页: [小ᶻ☡꙳ᵃⁱᵍᶜ꙳] 本文专栏: AI绘画 | Midjourney 文章目录 💯前言💯Midjourney中的色彩控制为什么要控制色彩?为什么要在Midjourney中控制色彩? 💯色调白色调淡色调明色调 💯…...
代码管理之Gitlab
文章目录 Git基础概述场景本地修改未提交,拉取远程代码修改提交本地,远程已有新提交 GitIDEA引入Git拉取仓库代码最后位置 Git基础 概述 workspace 工作区:本地电脑上看到的目录; repository 本地仓库:就是工作区中隐…...
防御网络攻击的创新策略
关键要点 ● 了解各种类型的网络攻击对于组织加强防御至关重要。 ● 制定敏捷的网络安全策略可帮助企业快速应对新出现的威胁。 ● 跨行业协作和威胁情报共享可以增强整体安全性。 网络攻击威胁日益严重 网络攻击的数量和复杂程度急剧增加,对全球组织构成了重大…...
龙虎榜——20250610
上证指数放量收阴线,个股多数下跌,盘中受消息影响大幅波动。 深证指数放量收阴线形成顶分型,指数短线有调整的需求,大概需要一两天。 2025年6月10日龙虎榜行业方向分析 1. 金融科技 代表标的:御银股份、雄帝科技 驱动…...
【杂谈】-递归进化:人工智能的自我改进与监管挑战
递归进化:人工智能的自我改进与监管挑战 文章目录 递归进化:人工智能的自我改进与监管挑战1、自我改进型人工智能的崛起2、人工智能如何挑战人类监管?3、确保人工智能受控的策略4、人类在人工智能发展中的角色5、平衡自主性与控制力6、总结与…...
Linux简单的操作
ls ls 查看当前目录 ll 查看详细内容 ls -a 查看所有的内容 ls --help 查看方法文档 pwd pwd 查看当前路径 cd cd 转路径 cd .. 转上一级路径 cd 名 转换路径 …...
《用户共鸣指数(E)驱动品牌大模型种草:如何抢占大模型搜索结果情感高地》
在注意力分散、内容高度同质化的时代,情感连接已成为品牌破圈的关键通道。我们在服务大量品牌客户的过程中发现,消费者对内容的“有感”程度,正日益成为影响品牌传播效率与转化率的核心变量。在生成式AI驱动的内容生成与推荐环境中࿰…...
Java多线程实现之Callable接口深度解析
Java多线程实现之Callable接口深度解析 一、Callable接口概述1.1 接口定义1.2 与Runnable接口的对比1.3 Future接口与FutureTask类 二、Callable接口的基本使用方法2.1 传统方式实现Callable接口2.2 使用Lambda表达式简化Callable实现2.3 使用FutureTask类执行Callable任务 三、…...
3403. 从盒子中找出字典序最大的字符串 I
3403. 从盒子中找出字典序最大的字符串 I 题目链接:3403. 从盒子中找出字典序最大的字符串 I 代码如下: class Solution { public:string answerString(string word, int numFriends) {if (numFriends 1) {return word;}string res;for (int i 0;i &…...
Typeerror: cannot read properties of undefined (reading ‘XXX‘)
最近需要在离线机器上运行软件,所以得把软件用docker打包起来,大部分功能都没问题,出了一个奇怪的事情。同样的代码,在本机上用vscode可以运行起来,但是打包之后在docker里出现了问题。使用的是dialog组件,…...
C/C++ 中附加包含目录、附加库目录与附加依赖项详解
在 C/C 编程的编译和链接过程中,附加包含目录、附加库目录和附加依赖项是三个至关重要的设置,它们相互配合,确保程序能够正确引用外部资源并顺利构建。虽然在学习过程中,这些概念容易让人混淆,但深入理解它们的作用和联…...
push [特殊字符] present
push 🆚 present 前言present和dismiss特点代码演示 push和pop特点代码演示 前言 在 iOS 开发中,push 和 present 是两种不同的视图控制器切换方式,它们有着显著的区别。 present和dismiss 特点 在当前控制器上方新建视图层级需要手动调用…...
解读《网络安全法》最新修订,把握网络安全新趋势
《网络安全法》自2017年施行以来,在维护网络空间安全方面发挥了重要作用。但随着网络环境的日益复杂,网络攻击、数据泄露等事件频发,现行法律已难以完全适应新的风险挑战。 2025年3月28日,国家网信办会同相关部门起草了《网络安全…...
