kubevirt eip方案

kube-eip出现背景

kubevirt中虚机是跑在virt-launcher的pod中的qemu进程。默认通过pod ip访问虚机,所以当虚机发生重启,迁移后pod ip将会发生变化。
但是对于虚机而言,使用固定ip,并且ip可以被云外网络访问是很普遍的需求。而kubevirt虚机使用pod ip访问,首先pod ip属于k8s内部网络无法被云外访问,并且当pod发生重启后pod ip将会变化,所以现有网络无法满足需求。并且对于某些嵌入式系统,无法支持多网卡。

kubevirt默认网络

kubevirt默认网络

virt-launcher的pod中虚机的tap设备接在linux bridge上,通过nat将pod veth设备的ip和虚机tap设备的ip做转换,以此通过访问pod ip来访问虚机。

kube-eip实现的eip方案

architecture.png

在vmi所在宿主机上通过在iptables的nat表新增KUBE-EIP-PREROUTING和KUBE-EIP-POSTRONGTING链来对进出虚机的流量做劫持。对于云外访问的流量,根据iptables规则做nat转换,从而实现通过eip来访问虚机。
新增k8s_internal_net的ipset集合用于区分云内外的流量。并新增kube-eip-eip,kube-eip-vmi两个ipset集合来匹配已经做了eip绑定的流量。并配合策略路由实现虚机访问云外流量通过eip走public network出去。
如果public network对接了交换机,可以通过bgp来同步eip路由给外部。

kube-eip的实现

kube-eip提供以下三个组件

  • eipbinding-operator: k8s的operator用于监听eipbinding和kubevirt vmi的crd资源变化来通知agent更新eip规则
  • eip-agent: 以daemonset的形式运行与每个k8s节点,接收operator的grpc请求来下发或者清理eip转换规则
  • eipctl: 命令行工具用于绑定或者解绑eip

kube-eip部署及使用

# 克隆kube-eip项目
git clone https://github.com/lucheng0127/kube-eip.git

# 部署operator和agent
IMG=quay.io/shawnlu0127/eipbinding_operator:20231130 make deploy
make deploy-agent

# 清理
make undeploy
make undeploy-agent

目前稳定版operator和agent镜像

  • quay.io/shawnlu0127/eipbinding_operator:20231130
  • quay.io/shawnlu0127/eip_agent:20231204

绑定eip给kubevirt虚机

apiVersion: extension.lucheng0127/v1
kind: EipBinding
metadata:
  labels:
    app.kubernetes.io/name: eipbinding
    app.kubernetes.io/instance: cirros
    app.kubernetes.io/part-of: kube-eip
    app.kubernetes.io/managed-by: kustomize
    app.kubernetes.io/created-by: kube-eip
  name: cirros
spec:
  eipAddr: 192.168.18.15
  vmiName: cirros

定义eipbinding的crd的yaml, vmiName为kubevirt vmi的名字,eipAddr为eip的ip地址,后创建eipbinding的crd即可。解绑删除eipbinding的crd即可。

root@shawn-server:~# kubectl get eipbinding cirros -o yaml
apiVersion: extension.lucheng0127/v1
kind: EipBinding
metadata:
  annotations:
    kubectl.kubernetes.io/last-applied-configuration: |
      {"apiVersion":"extension.lucheng0127/v1","kind":"EipBinding","metadata":{"annotations":{},"labels":{"app.kubernetes.io/created-by":"kube-eip","app.kubernetes.io/instance":"cirros","app.kubernetes.io/managed-by":"kustomize","app.kubernetes.io/name":"eipbinding","app.kubernetes.io/part-of":"kube-eip"},"name":"cirros","namespace":"default"},"spec":{"eipAddr":"192.168.18.15","vmiName":"cirros"}}
  creationTimestamp: "2023-12-04T07:24:21Z"
  finalizers:
  - extension.lucheng0127/finlizer
  generation: 4
  labels:
    app.kubernetes.io/created-by: kube-eip
    app.kubernetes.io/instance: cirros
    app.kubernetes.io/managed-by: kustomize
    app.kubernetes.io/name: eipbinding
    app.kubernetes.io/part-of: kube-eip
  name: cirros
  namespace: default
  resourceVersion: "10121351"
  uid: 3e980554-7fd1-4d94-9b57-d2179211c372
spec:
  currentHyper: 172.17.15.125
  currentIPAddr: 10.244.3.88
  eipAddr: 192.168.18.15
  lastHyper: 172.17.15.133
  lastIPAddr: 10.244.0.91
  phase: Ready
  vmiName: cirros

kube-eip github项目链接

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,874评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,102评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,676评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,911评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,937评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,935评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,860评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,660评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,113评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,363评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,506评论 1 346
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,238评论 5 341
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,861评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,486评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,674评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,513评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,426评论 2 352

推荐阅读更多精彩内容