kt-connect使用-k8s流量代理

news2025/7/18 3:57:48

1.下载kt安装包

地址: https://github.com/alibaba/kt-connect/releases

2.下载k8s集群的config文件

cd  /root/.kube
下载服务器的`config`文件

3.安装config文件

  1. 切换到用户目录C:\Users\yangx
  2. 创建.kube文件夹mkdir .kube
  3. 目录结构为C:\Users\yangx\.kube
  4. 把下载config文件移动到C:\Users\yangx\.kube

4. 启动代理

  1. 解压压缩包
  2. 在当前目录执行 .\ktctl.exe connect
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-qIT6bHZH-1668588594407)(C:\Users\yangx\AppData\Roaming\Typora\typora-user-images\image-20221116162427943.png)]

这样代理就成功了

5. 怎么代理流量

5.1.将集群流量转发到本地

KtConnect提供了两种能够让集群流量重定向到本地服务的命令,在使用场景上稍有不同。

  • Exchange:将集群指定服务的所有流量转向本地
  • Mesh:将集群指定服务的部分流量(按Header或Label规则)转向本地

Exchange命令

将集群里访问指定服务的所有请求拦截并转发到本地的指定端口。通常用于调试在测试环境里,调试位于业务调用链中间环节的特定服务。

┌──────────┐     ┌─ ── ── ──     ┌──────────┐
│ ServiceA ├─┬─►x│ ServiceB │ ┌─►│ ServiceC │
└──────────┘ │    ── ── ── ─┘ │  └──────────┘
         exchange             │
             │   ┌──────────┐ │
             └──►│ ServiceB'├─┘ (本地服务实例)
                 └──────────┘

使用ktctl exchange命令将先前部署到集群中的tomcat服务流量全部转到本地8080端口:

$ ktctl exchange tomcat -n dev --expose 8080 
  • tomcat:这里指的是k8s的service的名称

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-RO03OqXk-1668588594408)(C:\Users\yangx\AppData\Roaming\Typora\typora-user-images\image-20221116162912619.png)]

  • -n dev:是指命名空间 dev

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-TduSFooe-1668588594408)(C:\Users\yangx\AppData\Roaming\Typora\typora-user-images\image-20221116163026898.png)]
    当出现如下图,则表示成功

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-HXV86BhB-1668588594408)(C:\Users\yangx\AppData\Roaming\Typora\typora-user-images\image-20221116163108615.png)]

Mesh命令

将集群里访问指定服务的部分请求拦截并转发到本地的指定端口。通常用于团队协作时,需要定向调试调用链中间位置的服务,又不希望影响其他开发者正常使用测试环境的场景。

┌──────────┐     ┌──────────┐    ┌──────────┐
│ ServiceA ├─┬──►│ ServiceB │─┬─►│ ServiceC │
└──────────┘ │   └──────────┘ │  └──────────┘
            mesh              │
             │   ┌──────────┐ │
             └──►│ ServiceB'├─┘ (本地服务实例)
                 └──────────┘

Mesh命令有两种运行模式,默认的auto模式不需要额外的服务网格组件,能够直接实现HTTP请求的自动按需路由。

ktctl mesh tomcat --expose 8080
00:00AM INF KtConnect start at <PID>
... ...
--------------------------------------------------------------
 Now you can access your service by header 'VERSION: feo3x'
--------------------------------------------------------------

若请求包含Mesh命令输出的Header,则流量将自动被本地的服务实例接收。

$ curl -H 'VERSION: feo3x' http://tomcat:8080

总结

ktctl exchangektctl mesh命令的最大区别在于,前者会将原应用实例流量全部替换为由本地服务接收,而后者仅将包含指定Header的流量导流到本地,同时保证测试环境正常链路始终可用。

5.2.将本地服务提供给其他开发者

除了已经部署到集群的服务,在开发过程中,也可以利用KtConnect将本地服务快速"放"到集群,变成一个临时的服务,供其他开发者或集群中的其他服务使用。

  • Preview:将本地服务注册为集群里的Service
  • Forward:将集群服务映射到本地,结合Preview命令可实现开发者之间跨主机使用Localhost地址互访

Preview命令

将本地运行的服务实例注册到集群上。主要用于将本地开发中的服务提供给其他开发者进行联调和预览。

使用ktctl preview命令将运行在本地8080端口的服务注册到测试集群,命名为tomcat-v2

$ ktctl preview tomcat-v2 --expose 8080
00:00AM INF KtConnect start at <PID>
... ...
---------------------------------------------------------------
 Now you can access your local service in cluster by name 'tomcat-v2'
---------------------------------------------------------------
  • tomcat-v2 是一个service

现在集群里的服务就可以通过tomcat-v2名称来访问本地注册的服务实例了,其他开发者也可以在执行ktctl connect后,直接通过tomcat-v2服务名称来预览该服务的实时情况:

$ curl http://tomcat-v2:8080
kt-connect local v2

Forward命令

将任意IP或集群中的服务映射到本地的指定端口。用于在测试时,使用localhost地址便捷的访问集群中的特定IP或服务,典型场景是是访问其他开发者通过Preview命令注册的本地服务。

         ┌─────────────────────────────┐
      forward           |           preview
┌────────┴───────┐      |      ┌───────▼──────┐
│ localhost:8080 │      |      │ local tomcat │
└────────────────┘      |      └──────────────┘
      开发者 B           |           开发者 A

例如当一个开发者A运行了前述的Preview命令后,另一个开发者B可以使用ktctl forward命令将它映射到自己本地的6060端口。

$ ktctl forward tomcat-v2 6060:8080
00:00AM INF KtConnect start at <PID>
... ...
---------------------------------------------------------------
 Now you can access port 8080 of service 'tomcat-v2' via 'localhost:6060'
---------------------------------------------------------------

现在开发者B就可以使用localhost:6060地址访问到开发者A本地运行的Tomcat服务了。

当映射的流量源是集群中的服务名时,其效果与kubectl port-forward命令相似,只是额外增加了断网自动重连的能力。

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

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

相关文章

XSS进阶三

目录实验目的预备知识实验环境实验步骤一实例七、和实例六好像木有区别实验步骤二实例八、有时候你要跳出你的思维实验步骤三实例九、将xss进行到底实验目的 1.深入理解xss工作原理。 2.怎么去绕过规则实现xss。 3.培养学生的独立思考能力。 预备知识 XSS基础、XSS进阶一。 …

字节跳动测试岗面试记:二面被按地上血虐,所幸Offer已到手...

在互联网做了几年之后&#xff0c;去大厂“镀镀金”是大部分人的首选。大厂不仅待遇高、福利好&#xff0c;更重要的是&#xff0c;它是对你专业能力的背书&#xff0c;大厂工作背景多少会给你的简历增加几分竞争力。 但说实话&#xff0c;想进大厂还真没那么容易。最近面试字…

[力扣] 剑指 Offer 第二天 - 从尾到头打印链表

[力扣] 剑指 Offer 第二天 - 从尾到头打印链表题目来源题目描述题目分析解题思路递归反转数组&#xff08;切片&#xff09;代码实现递归执行结果复杂度分析反转切片执行结果复杂度分析总结耐心和持久胜过激烈和狂热。 题目来源 来源&#xff1a;力扣&#xff08;LeetCode&…

【微服务】如何利用Nacos Config实现服务配置?

微服务--Nacos Config1、前言2、Nacos Config2.1 简介2.2 常见的服务配置中心3、Nacos Config入门4、Nacos Config深入4.1 配置动态刷新4.2 配置共享4.2.1 同一个微服务不同环境之间共享配置4.2.2 不同微服务之间共享配置5、Nacos的几个概念6、总结1、前言 在前期的文章中&…

纯代谢冲上Nature不是幻想,蛋氨酸饮食可影响小鼠癌症预后,同样可影响人体代谢

百趣代谢组学文献分享一篇题名 "Dietary methionine influences therapy in mouse cancer models and alters human metabolism"&#xff0c;发表在Nature。文章是做的纯代谢研究&#xff08;饮食影响癌症和代谢&#xff09;。纯代谢冲上Nature&#xff0c;这篇文章是…

C++:重定义:符号重定义:变量重定义(三):解决变量重定义(声明extern外部变量)

在上一篇文章中&#xff0c;我们知道&#xff1a;可以通过声明 const/ static 变量来隔离变量在源文件的可见性&#xff0c;来解决变量重复定义的问题&#xff0c; C&#xff1a;重定义&#xff1a;符号重定义&#xff1a;变量重定义&#xff08;二&#xff09;&#xff1a;解…

链表题目 : 链表的中间结点 与 链表中倒数第k个结点(leetcode 和 牛客)

坚持看完&#xff0c;结尾有思维导图总结 快慢指针在链表中的运用链表的中间结点步骤例子分析奇数情况偶数情况程序链表中倒数第k个结点步骤解析程序链表的中间结点 leetcode 链接 步骤 设置两个指针来遍历链表&#xff0c;一个叫 fast 每次跳过两个元素&#xff0c;一个叫 …

浅谈网络损伤仪HoloWAN的使用场景

目录一、HoloWAN 应用于卫星通讯领域1.1 卫星通讯领域的背景和挑战1.2 使用HoloWAN实现卫星⽹络仿真二、HoloWAN 应用于网络游戏2.1 网络游戏的背景和挑战2.2 使用HoloWAN模拟真实的网络环境三、HoloWAN 应用于数据中心迁移3.1 数据迁移的背景和挑战3.2 使用HoloWAN进行在线性能…

客户文章|南方医科大学李克玄团队破解肠道宏病毒与心肌病关系

近日凌恩生物合作客户南方医科大学南方医院麻醉科刘克玄团队在医学期刊《JOURNAL OF MEDICAL VIROLOGY》上发表名为“Gut microbiota dysbiosis is associated with sepsis-induced cardiomyopathy in patients: A case‒control study”研究&#xff0c;该研究利用宏基因组测序…

Imazing2023免费版苹果手机iOS数据管理软件

Imazing是一款很棒的苹果iOS管理工具&#xff0c;并且可以轻松扩大您对移动数据的控制范围&#xff0c;实现以往从未出现的功能&#xff0c;那么为了让大家更好的使用这款软件&#xff0c;因此小编就给大家带来了imazing使用教程&#xff0c;有需要的用户就一起来看看吧。一款安…

Linux安装java的JDK步骤

1.获取安装包&#xff08;服务器不通外网的话&#xff0c;自行在本机下载然后上传&#xff09; wget https://packages.baidu.com/app/jdk-8/jdk-8u121-linux-x64.tar.gz 2.创建安装目录 mkdir -p /usr/java 3.将前面下载的安装包移动到新目录 mv jdk-8u121-linux-x64.tar.g…

使用北鲲云在AWS上运行基因分析HPC任务

背景 近三十年来&#xff0c;生命科学与计算科学飞速发展。生物信息学是一门生命科学与计算科学的前沿交叉学科。生物信息学产生和迅猛发展的主要推动力来自于新一代测序等高通量技术在生命科学领域越来越广泛的应用。 基因组学是这一趋势的一个主要例子&#xff0c;其中高通量…

直播回顾|关联网络如何反团伙欺诈——标准答案版

11月10日下午15:00顶象数据科学家翼龙带来主题为《关联网络技术在业务安全中的应用》的直播。 直播内容包括常见的团伙欺诈场景、关联网络在反团伙欺诈中的作用、关联网络的技术框架&#xff0c;并就关联图谱构建和复杂网络算法展开了具体的讨论&#xff0c;最后以案例的形式形…

ElasticSearch 文档数据导入导出及两个ElasticSearch互相导入操作

文章目录一、前期安装准备二、ElasticSearch文档数据导入和导出三、两个ElasticSearch互相导入操作四、ElasticSearch版本不同是否有问题一、前期安装准备 1.先安装Node.js工具 Node.js官网下载地址&#xff1a;下载地址 双击下载完后的安装包&#xff0c;一直点下一步&#…

【日拱一卒】如何编写测试用例(下)

六、测试用例设计的误区 能发现到目前为止没有发现的缺陷的用例是好的用例&#xff1b; 首先要申明&#xff0c;其实这句话是十分有道理的&#xff0c;但我发现很多人都曲解了这句话的原意&#xff0c;一心要设计出发现“难于发现的缺陷”而陷入盲目的片面中去&#xff0c;忘记…

华为机试 - 城市聚集度

目录 题目描述 输入描述 输出描述 用例 题目解析 算法源码 题目描述 一张地图上有n个城市&#xff0c;城市和城市之间有且只有一条道路相连&#xff1a;要么直接相连&#xff0c;要么通过其它城市中转相连&#xff08;可中转一次或多次&#xff09;。城市与城市之间的道…

11月第2周榜单丨飞瓜数据B站UP主排行榜(哔哩哔哩)发布!

飞瓜轻数发布2022年11月07日-11月13日飞瓜数据UP主排行榜&#xff08;B站平台&#xff09;&#xff0c;通过充电数、涨粉数、成长指数三个维度来体现UP主账号成长的情况&#xff0c;为用户提供B站号综合价值的数据参考&#xff0c;根据UP主成长情况用户能够快速找到运营能力强的…

Java#6(类和对象及封装)

目录 一.类和对象基本介绍 1.类:是对象共同特征的描述; 2.对象:是真实存在的具体东西 如何定义类? 对象的定义和使用? 二.封装 原则:对象代表什么,就得封装什么数据,并提供数据对应的行为 1.实例理解 三.Private(私有权限) 一.类和对象基本介绍 1.类:是对象共同特征…

css :first-child 和 :first-of-type

1 :first-child p:first-child {background-color:yellow; }阅读理解&#xff1a;<p>元素的背景设为黄色 第一个子元素的背景设为黄色 父元素的第一个子元素是<p>时&#xff0c;该子元素背景设为黄色 举个栗子&#xff1a; <!DOCTYPE html> <html>…

关于java String类(源码等)分析

String 类 String声明为final &#xff0c;不可以被继承 String 实现了Serializable接口&#xff0c;表明字符串是可序列化的 String 实现了Compareble接口&#xff0c;表示String 可比较大小 String 内部定义了 final char[] value value用于存储字符串数据&#xff0c;表明…