首页 > 其他分享 >办公网段与Kubernetes Pod及Svc网络互通方案

办公网段与Kubernetes Pod及Svc网络互通方案

时间:2023-05-08 13:15:11浏览次数:54  
标签:master1 Kubernetes Svc 办公网 172.17 Pod k8s root

一、背景

      在Kubernetes的网络模型中,基于官方支持的CNI插件Flannel、Calico等,可以轻松实现Pod之间的网络互通,当我们将Spring Cloud的微服务部署到Kubernetes中后,无需任何改动微服务的Pod即可通过Eureka注册后进行访问。除此之外还可以通过Ingress controller 基于80/http和443/https端口将用户的请求流量引入到集群服务中。

但在实际开发过程中,我们出现了如下需求:

  1. 办公网络和Kubernetes Pod网络不通,开发在电脑完成某个微服务模块开发后,希望在本地电脑能注册到Kubernetes中开发环境的注册中心(Nacos)进行调试,而不需要在本地起一堆的依赖服务。
  2. 办公网络和Kubernetes Svc网络不通,部分服务需要通过Service的NodePort代理访问,应用数量变多后导致维护量工作巨大。

二、环境介绍

Kubernetes网络环境说明
网段名称 IP地址范围 子网掩码
办公网段 172.16.0.0/18 255.255.192.0
Pod地址池 172.17.32.0/19 255.255.224.0
Svc地址池 172.17.16.0/20 255.255.240.0

三、网络互通配置

选择一个节点用来做路由转发,在本案例中我们使用了Master1来进行配置。

注:建议在集群中新加一台配置不高的Node节点,打上污点不允许调度Pod占用资源,让其专门做路由转发使用。

  # 开启转发
  [root@k8s-master1 ~]# vim /etc/sysctl.d/k8s.conf
  net.ipv4.ip_forward = 1
  [root@k8s-master1 ~]# sysctl -p
   
  # 在k8s-master1上设置snat
  [root@k8s-master1 ~]# iptables -t nat -A POSTROUTING -s 172.16.0.0/18 -d 172.17.32.0/19 -j MASQUERADE
  [root@k8s-master1 ~]# iptables -t nat -A POSTROUTING -s 172.16.0.0/18 -d 172.17.16.0/20 -j MASQUERADE
   
  # (可选)查看设置的snat
  [root@k8s-master1 ~]# iptables -t nat -L -n --line-numbers | grep -A 10 "Chain POSTROUTING"
  Chain POSTROUTING (policy ACCEPT)
  num target prot opt source destination
  1 ......
  2 ......
  3 MASQUERADE all -- 192.168.0.0/20 0.0.0.0/0
  4 MASQUERADE all -- 172.16.0.0/18 172.17.32.0/19
  5 MASQUERADE all -- 172.16.0.0/18 172.17.16.0/20
   
  # (可选)如配置失误可删除已设置的snat条目
  [root@k8s-master1 ~]# iptables -t nat -D POSTROUTING 4

在办公室的出口路由上,设置静态路由,将Kubernetes的Pod和Service网段,路由到Master1节点上(具体可查看拓扑图)。 

  # 在路由器上需要做的配置:
  ip route 172.17.32.0 255.255.224.0 172.17.14.11
  ip route 172.17.16.0 255.255.240.0 172.17.14.11

配置完成后验证是否能从办公电脑访问:

  # 查询集群某个Pod地址
  [root@k8s-master1 ~]# kubectl get pod -o wide -n ingress-nginx
  NAME READY STATUS RESTARTS AGE IP NODE NOMINATED NODE READINESS GATES
  ingress-nginx-controller-688d67dc6d-68f85 1/1 Running 0 65d 172.17.54.238 k8s-node03 <none> <none>
  # 查询集群某个Svc地址
  [root@k8s-master1 ~]# kubectl get svc -n ingress-nginx
  NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
  ingress-nginx-controller NodePort 172.17.24.229 <none> 80:80/TCP,443:443/TCP 465d
   
  # 在办公电脑ping测试连通性
  $ ping 172.17.54.238
  PING 172.17.54.238 (172.17.54.238): 56 data bytes
  64 bytes from 172.17.54.238: icmp_seq=0 ttl=61 time=1.036 ms
  64 bytes from 172.17.54.238: icmp_seq=1 ttl=61 time=1.200 ms
  ......
  # 在办公电脑测试Svc连通性
  $ curl -I 172.17.24.229:80/healthz
  HTTP/1.1 200 OK
  Date: Mon, 14 Mar 2022 03:02:30 GMT
  Content-Type: text/html
  Content-Length: 0
  Connection: keep-alive

 四、DNS解析配置

      以上步骤完成后,我们就可以之间在本地电脑访问Pod和Svc的服务了,但是由于Pod IP根据部署频率会经常变化,Service IP也不是那么容易记忆。所以我们希望通过内网DNS在访问*.cluster.local时自动去解析相应的IP。

最简单的方式,就是直接将本地dns解析地址设置成CoreDNS的SvcIP上。

  # 获取coredns的IP
  [root@k8s-master1 ~]# kubectl get svc -n kube-system -l k8s-app=kube-dns
  NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
  kube-dns ClusterIP 172.17.16.10 <none> 53/UDP,53/TCP,9153/TCP 465d
   
  # 本地测试是否能正常解析
  $ nslookup -q=A kube-dns.kube-system.svc.cluster.local 172.17.16.10
  Server: 172.17.16.10
  Address: 172.17.16.10#53
   
  Name: kube-dns.kube-system.svc.cluster.local
  Address: 172.17.16.10

      因为我们公司内网已有台单独的DNSmasq用来做解析,所以我们这里直接在DNSmasq服务器的/etc/dnsmasq.conf配置文件中添加server=/cluster.local/172.17.16.10,将内网的*.cluster.local解析请求交给coreDNS(172.17.16.10)去解析。

  [root@centos-172-16-1-10 ~]# vim /etc/dnsmasq.conf
  # 内网的*.cluster.local解析请求,交给coreDNS 172.17.16.10
  server=/cluster.local/172.17.16.10

完成以上步骤后,我们办公网络与Kubernetes网络互通需求就都实现了,同时我们可以直接使用Service的域名规则<svc>.<namespaces>.svc.cluster.local:Port去访问到Kubernetes中的服务。

 

 
 

标签:master1,Kubernetes,Svc,办公网,172.17,Pod,k8s,root
From: https://www.cnblogs.com/gaoyuechen/p/17381399.html

相关文章

  • 关于Kubernetes-v1.23.6-初始化时报错[kubelet-check] It seems like the kubelet isn
    笔者今天在对k8s,v1.23.6版本的的master节点使用如下命令进行初始化时[root@k8s-masterqq-5201351]#kubeadminit\>--apiserver-advertise-address192.18.106.87\>--image-repositoryregistry.aliyuncs.com/google_containers\>--kubernetes-versionv1.23.6\>--......
  • 关于Kubernetes-v1.23.6-初始化时报错[WARNING FileExisting-tc]: tc not found in sy
    今天笔者在部署Kubernetes-v1.23.6版本时,在对master节点使用如下命令进行初始化时,报错:[WARNINGFileExisting-tc]:tcnotfoundinsystempath当然其实也从字符意义上来看,只能算是WARNING提醒,不会影响主要的功能和结果,但既然有这个提醒,就可能就在某些地方是有轻微影响的,为了......
  • kubernetes|EFK日志系统
    前言对于任何基础设施或后端服务系统,日志都是极其重要的,借助日志可以分析程序的运行状态、用户的操作行为等。最早常说的日志监控系统是ELK,即ElasticSearch(负责数据检索)、Logstash(负责数据收集)、Kibana(负责数据展示)三个软件的组合,随着技术的发展,又出现了很多新的名词,比如EFK,......
  • kubernetes域名解析服务CoreDNS
    k8sdns组件历史简介kubernetes的DNS组件历史有三个,分别是skydns、kube-dns和coredns;在k8s1.3版本之前使用的是skydns,之后的版本到1.17及之间的版本都是使用的kube-dns,1.18开始至今主要使用coredns;这些dns组件在k8s当中,主要作用就是解析k8s中servicename所对应的IP地......
  • 使用 External Secrets Operator 管理 Kubernetes 的 Secret
    Kubernetes的Secret机制允许我们将敏感信息存储中央存储库etcd中,这是一种比在Pod定义或容器镜像中存储信息更安全的方式。然而,Kubernetes目前还没有能力管理Secret的生命周期,所以有时候我们需要使用外部系统来管理这些敏感信息。随着我们需要管理的Secret数量的增长,我......
  • 部署Kubernetes遇到的问题与解决方法(初始化等)
    Kubelet和controlplane版本不对应:[ERRORKubeletVersion]:thekubeletversionishigherthanthecontrolplaneversion.Thisisnotasupportedversionskewandmayleadtoamalfunctionalcluster.Kubeletversion:"1.19.4"Controlplaneversion:&qu......
  • Kubernetes资源对象管理
    API对象:也就是K8S的资源对象,是K8S集群中的管理操作单元。K8S集群系统每支持一项新功能,引入一项新技术,一定会新引入对应的API对象,支持对该功能的管理操作。一、Kubernetes资源对象查询1.1查询资源类型#列出当前集群中所有的资源类型kubectlapi-resources   字段说明NAME:资......
  • k8s Kubernetes Dashboard 安装与使用
    https://github.com/kubernetes/dashboardhttps://developer.aliyun.com/article/745086https://github.com/kubernetes/dashboard/blob/master/docs/user/access-control/creating-sample-user.mdhttps://kubernetes.io/zh-cn/docs/tasks/access-application-cluster/web-ui-......
  • DevOps 基于Rancher 2.3 Kubernetes 1.16
    一服务器清单 二初始化服务器:安装Docker Docke-compose以及配置Docker阿里云镜像加速此处略过三 192.168.117.104安装RancherServerdockerrun-d--restart=unless-stopped\-p8080:80-p8443:443\-eCATTLE_SYSTEM_CATALOG=bundled\-eAUDIT_LEVEL=3\ranc......
  • linux-kubernetes(二进制部署)
    参考笔记:https://www.cnblogs.com/yinzhengjie/p/17069566.html一、环境准备准备5台机器,二进制部署K8S高可用集群:主机ipk8s-master0110.0.0.201k8s-master0210.0.0.202k8s-master0310.0.0.203k8s-node0110.0.0.204k8s-node0210.0.0.205二、K8S......