Kubernetes 集群到 Jumpserver

news2025/7/22 11:49:24

以下是使用 ServiceAccount Token(令牌) 连接 Kubernetes 集群到 Jumpserver 的 详细分步指南,包括权限配置、Token 获取和常见问题排查。


1. 创建 ServiceAccount 并分配权限

1.1 创建 ServiceAccount

在 Kubernetes 集群中创建一个专用于 Jumpserver 的 ServiceAccount(如 jumpserver-admin):

kubectl create serviceaccount jumpserver-admin -n kube-system

1.2 绑定 ClusterRole(赋予管理员权限)
kubectl create clusterrolebinding jumpserver-admin \
  --clusterrole=cluster-admin \
  --serviceaccount=kube-system:jumpserver-admin
  • 说明

    • cluster-admin 是 Kubernetes 内置的最高权限角色(生产环境建议按需缩小权限)。

    • 如果只需要特定命名空间的权限,改用 RoleBinding 和自定义 Role


2. 使用 TokenRequest API(推荐新方法)

更现代的方法是直接通过 API 获取 Token:

kubectl create token jumpserver-admin -n kube-system --duration=8760h
  • --duration=8760h 设置 Token 有效期(1年),按需调整。

复制输出的 Token,用以下命令测试:

curl -k -H "Authorization: Bearer <粘贴Token>" https://<k8s-api-server>:6443/api/v1/namespaces/default/pods

  • 应返回 JSON 格式的 Pod 列表或权限相关信息。


3. 在 Jumpserver 中配置密文

  1. 进入 Jumpserver

    • 导航到 "凭据管理" → "密文" → 点击 "创建密文"

  2. 填写密文信息

    • 名称k8s-admin-token(自定义)

    • 密文类型:选择 "令牌"(关键步骤!)

    • 密钥:粘贴从步骤 2 复制的 Token。

    • 其他字段(如描述)按需填写。

  3. 点击 "提交" 保存。


4. 在 Jumpserver 中添加 Kubernetes 集群

  1. 进入 Kubernetes 管理

    • 导航到 "Kubernetes" → "集群管理" → 点击 "创建集群"

  2. 填写集群信息

    • 名称prod-cluster(自定义)

    • API Server:填写 k8s API 地址,例如:

      • 默认端口:https://<k8s-master-ip>:6443

      • 如果通过负载均衡器访问,填写对应的 URL。

    • 认证方式:选择 "Bearer Token"(或类似选项)。

    • 关联密文:选择刚才创建的 k8s-admin-token

    • 其他选项

      • 跳过证书验证:如果使用自签名证书且未上传 CA,勾选此项(仅限测试环境)。

      • 集群别名:按需填写(显示在 Web 终端中的名称)。

  3. 测试连接

    • 点击 "测试连接",确认返回成功(绿色提示)。

  4. 点击 "提交" 完成配置。


5. 验证连接

  1. 在 Jumpserver Web 终端访问

    • 登录 Jumpserver 用户账号。

    • 进入 "Web 终端" → 选择刚添加的 Kubernetes 集群。

    • 执行命令测试(如 kubectl get nodes),应能正常返回节点列表。

  2. 检查权限

    • 执行 kubectl auth can-i --list 确认权限符合预期。


6. 常见问题排查

问题 1:Token 无效或过期
  • 现象:连接测试失败,提示 Unauthorized

  • 解决

    • 重新生成 Token(ServiceAccount 的 Token 默认永久有效,但 Secret 可能被删除)。

    • 检查 Secret 是否存在:

      kubectl get secret -n kube-system | grep jumpserver-admin
问题 2:证书验证失败
  • 现象x509: certificate signed by unknown authority

  • 解决

    • 方法 1:在 Jumpserver 集群配置中上传 k8s 的 CA 证书(路径通常为 /etc/kubernetes/pki/ca.crt)。

    • 方法 2(临时方案):勾选 "跳过证书验证"(不推荐生产环境)。

问题 3:网络不通
  • 现象:连接超时或 Connection refused

  • 解决

    • 从 Jumpserver 服务器测试网络连通性:

      curl -k https://<k8s-api-server>:6443
    • 检查 k8s API Server 是否监听正确端口:

      netstat -tuln | grep 6443
    • 确保防火墙/安全组放行 6443 端口

问题 4:权限不足
  • 现象:执行命令时提示 Forbidden

  • 解决

    • 检查 ClusterRoleBinding 是否正确:

      kubectl get clusterrolebinding jumpserver-admin -o yaml
    • 按需调整权限(参考 Kubernetes RBAC 文档)。


7. 安全建议

  1. 最小权限原则:不要滥用 cluster-admin,按需限制权限,例如:

    # 仅允许读取所有命名空间的 Pod
    kubectl create clusterrole jumpserver-view --verb=get,list --resource=pods
    kubectl create clusterrolebinding jumpserver-view --clusterrole=jumpserver-view --serviceaccount=kube-system:jumpserver-admin
  2. 定期轮换 Token:删除旧 Secret 触发自动生成新 Token:

    kubectl delete secret <secret-name> -n kube-system
  3. 审计日志:在 Jumpserver 中启用会话录制,定期检查 k8s 的审计日志。


通过以上步骤,你能成功将 Kubernetes 集群集成到 Jumpserver。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2401710.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

为什么要选择VR看房?VR看房有什么优点?

VR看房&#xff1a;革新传统&#xff0c;重塑体验 在当今社会&#xff0c;虚拟现实&#xff08;VR&#xff09;技术正以前所未有的速度渗透到我们生活的各个领域&#xff0c;其中VR看房作为房地产领域的重要创新。本文将讨论为什么要选择VR看房以及VR看房的主要优点&#xff0…

pytorch基本运算-范数

引言 前序学习进程中&#xff0c;已经对pytorch基本运算有了详细探索&#xff0c;文章链接有&#xff1a; 基本运算 广播失效 乘除法和幂运算 hadamard积、点积和矩阵乘法 上述计算都是以pytorch张量为运算元素&#xff0c;这些张量基本上也集中在一维向量和二维矩阵&#x…

Transformer实战——词嵌入技术详解

Transformer实战——词嵌入技术详解 0. 前言1. 词嵌入基础2. 分布式表示3. 静态嵌入3.1 Word2Vec3.2 GloVe 4. 使用 Gensim 构建词嵌入5. 使用 Gensim 探索嵌入空间6. 动态嵌入小结系列链接 0. 前言 在本节中&#xff0c;我们首先介绍词嵌入的概念&#xff0c;然后介绍两种实现…

[pdf、epub]300道《软件方法》强化自测题业务建模需求分析共257页(202505更新)

DDD领域驱动设计批评文集 做强化自测题获得“软件方法建模师”称号 《软件方法》各章合集 在本账号CSDN资源下载&#xff0c;或者访问链接&#xff1a; http://www.umlchina.com/url/quizad.html 如果需要提取码&#xff1a;umlc 文件夹中的“300道软件方法强化自测题2025…

Vue3入门指南:从零到精通的快速上手

齐爷学vue3 一、Vue3入门 vite&#xff1a;前端构架工具&#xff0c;构建速度快于webpack。轻量快速、对TS&#xff0c;JSX&#xff0c;CSS开箱即用、按需编译。 创建Vue3工程 1.在想要创建Vue3的位置打开cmd&#xff0c;执行如下命令。 npm create vuelatest 2.功能只选择…

吴恩达MCP课程(5):mcp_chatbot_prompt_resource.py

前提条件&#xff1a; 1、吴恩达MCP课程&#xff08;5&#xff09;&#xff1a;research_server_prompt_resource.py 2、server_config_prompt_resource.json文件 {"mcpServers": {"filesystem": {"command": "npx","args"…

设计模式——抽象工厂设计模式(创建型)

摘要 抽象工厂设计模式是一种创建型设计模式&#xff0c;旨在提供一个接口&#xff0c;用于创建一系列相关或依赖的对象&#xff0c;无需指定具体类。它通过抽象工厂、具体工厂、抽象产品和具体产品等组件构建&#xff0c;相比工厂方法模式&#xff0c;能创建一个产品族。该模…

基于LocalAI与cpolar技术协同的本地化AI模型部署与远程访问方案解析

文章目录 前言1. Docker部署2. 简单使用演示3. 安装cpolar内网穿透4. 配置公网地址5. 配置固定公网地址前言 各位极客朋友们!今天要向大家推荐一套创新性的本地部署方案——LocalAI技术架构。这款开源工具包能够将普通配置的笔记本电脑转化为具备强大算力的AI工作站,轻松实现…

霍尔效应传感器的革新突破:铟化铟晶体与结构演进驱动汽车点火系统升级

一、半导体材料革新&#xff1a;铟化铟晶体的电压放大机制 铟化铟&#xff08;InSb&#xff09;晶体因其独特的能带结构&#xff0c;成为提升霍尔电压的关键材料。相较于传统硅基材料&#xff0c;其载流子迁移率高出3-5倍&#xff0c;在相同磁场强度下可显著放大霍尔电压。其作…

无法运用pytorch环境、改环境路径、隔离环境

一.未建虚拟环境时 1.创建新项目后&#xff0c;直接运行是这样的。 2.设置中Virtualenv找不到pytorch环境&#xff1f;因为此时没有创建新虚拟环境。 3.选择conda环境&#xff08;全局环境&#xff09;时&#xff0c;是可以下载环境的。 运行结果如下&#xff1a; 是全局环境…

从0开始学vue:pnpm怎么安装

一、什么是 pnpm&#xff1f; pnpm&#xff08;Performant npm&#xff09;是新一代 JavaScript 包管理器&#xff0c;优势包括&#xff1a; 节省磁盘空间&#xff1a;通过硬链接和符号链接实现高效存储安装速度更快&#xff1a;比 npm/yarn 快 2-3 倍内置工作区支持&#xf…

Python 网络编程 -- WebSocket编程

作者主要是为了用python构建实时网络通信程序。 概念性的东西越简单越好理解,因此,下面我从晚上摘抄的概念 我的理解。 什么是网络通信? 更确切地说&#xff0c;网络通信是两台计算机上的两个进程之间的通信。比如&#xff0c;浏览器进程和新浪服务器上的某个Web服务进程在通…

边缘计算应用实践心得

当数据中心的光纤开始承载不了爆炸式增长的物联网数据流时&#xff0c;边缘计算就像毛细血管般渗透进现代数字肌理的末梢。这种将算力下沉到数据源头的技术范式&#xff0c;本质上是对传统云计算中心化架构的叛逆与补充——在智能制造车间里&#xff0c;实时质检算法直接在工业…

EXCEL如何快速批量给两字姓名中间加空格

EXCEL如何快速批量给姓名中间加空格 优点&#xff1a;不会导致排版混乱 缺点&#xff1a;无法输出在原有单元格上&#xff0c;若需要保留原始数据&#xff0c;可将公式结果复制后“选择性粘贴为值” 使用场景&#xff1a;在EXCEL中想要快速批量给两字姓名中间加入空格使姓名对…

Jenkins | Linux环境部署Jenkins与部署java项目

1. 部署jenkins 1.1 下载war包 依赖环境 jdk 11 下载地址: https://www.jenkins.io/ 依赖环境 1.2 启动服务 启动命令 需要注意使用jdk11以上的版本 直接启动 # httpPort 指定端口 #-Xms2048m -Xmx4096m 指定java 堆内存初始大小 与最大大小 /usr/java/jdk17/bin/java…

react私有样式处理

react私有样式处理 Nav.jsx Menu.jsx vue中通过scoped来实现样式私有化。加上scoped&#xff0c;就属于当前组件的私有样式。 给视图中的元素都加了一个属性data-v-xxx&#xff0c;然后给这些样式都加上属性选择器。&#xff08;deep就是不加属性也不加属性选择器&#xff09; …

UDP/TCP协议全解

目录 一. UDP协议 1.UDP协议概念 2.UDP数据报格式 3.UDP协议差错控制 二. TCP协议 1.TCP协议概念 2.三次握手与四次挥手 3.TCP报文段格式&#xff08;重点&#xff09; 4.流量控制 5.拥塞控制 一. UDP协议 1.UDP协议概念 当应用层的进程1要向进程2传输报文&#xff…

Duix.HeyGem:以“离线+开源”重构数字人创作生态

在AI技术快速演进的今天,虚拟数字人正从高成本、高门槛的专业领域走向大众化应用。Duix.HeyGem 数字人项目正是这一趋势下的杰出代表。该项目由一支拥有七年AI研发经验的团队打造,通过放弃传统3D建模路径,转向真人视频驱动的AI训练模型,成功实现了低成本、高质量、本地化的…

ubuntu22.04安装megaton

前置 sudo apt-get install git cmake ninja-build generate-ninja安装devkitPro https://blog.csdn.net/qq_39942341/article/details/148388639?spm1001.2014.3001.5502 安装cargo https://blog.csdn.net/qq_39942341/article/details/148387783?spm1001.2014.3001.5501 …

Windows应用-GUID工具

下载本应用 我们在DirectShow和媒体基础程序的调试中&#xff0c;将会遇到大量的GUID&#xff0c;调试窗口大部分情况下只给出GUID字符串&#xff0c;此GUID代表什么&#xff0c;我们无从得知。这时&#xff0c;就需要此“GUID工具”&#xff0c;将GUID字符串翻译为GUID定义&am…