k8s--services(微服务)
创始人
2024-05-31 22:42:29
0

文章目录

  • 前言
  • 一、k8s网络通信
  • 二、services
    • 1.简介
    • 2.默认
    • 3.IPVS模式的service
    • 4.clusterip
    • 5.headless
    • 6.从外部访问service的三种方式
      • (1)nodeport
      • (2)loadbalancer
    • 7.metallb

前言


一、k8s网络通信

k8s通过CNI接口接入其他插件来实现网络通讯。目前比较流行的插件有flannel,calico等。CNI插件存放位置:# cat  /etc/cni/net.d/10-flannel.conflist 插件使用的解决方案如下:虚拟网桥,虚拟网卡,多个容器共用一个虚拟网卡进行通信。多路复用:MacVLAN,多个容器共用一个物理网卡进行通信。硬件交换:SR-LOV,一个物理网卡可以虚拟出多个接口,这个性能最好。容器间通信:同一个pod内的多个容器间的通信,通过lo即可实现;pod之间的通信:同一节点的pod之间通过cni网桥转发数据包。(brctl show可以查看)不同节点的pod之间的通信需要网络插件支持。pod和service通信: 通过iptables或ipvs实现通信,ipvs取代不了iptables,因为ipvs只能做负载均衡,而做不了nat转换。pod和外网通信:iptables的MASQUERADE。Service与集群外部客户端的通信;(ingress、nodeport、loadbalancer)

二、services

1.简介

Service可以看作是一组提供相同服务的Pod对外的访问接口。借助Service,应用可以方便地实现服务发现和负载均衡。
service默认只支持4层负载均衡能力,没有7层功能。(可以通过Ingress实现)

service的类型:(前三种是集群外部访问内部资源)ClusterIP:默认值,k8s系统给service自动分配的虚拟IP,只能在集群内部访问。NodePort:将Service通过指定的Node上的端口暴露给外部,访问任意一个NodeIP:nodePort都将路由到ClusterIP。LoadBalancer:在 NodePort 的基础上,借助 cloud provider 创建一个外部的负载均衡器,并将请求转发到 :NodePort,此模式只能在云服务器上使用。ExternalName:将服务通过 DNS CNAME 记录方式转发到指定的域名(通过 spec.externlName 设定)。[集群内部访问外部,通过内部调用外部资源]

2.默认

创建测试示例
[root@k8s2 service]# vim myapp.yml
apiVersion: apps/v1
kind: Deployment
metadata:labels:app: myappname: myapp
spec:replicas: 6selector:matchLabels:app: myapptemplate:metadata:labels:app: myappspec:containers:- image: myapp:v1name: myapp---apiVersion: v1
kind: Service
metadata:labels:app: myappname: myapp
spec:ports:- port: 80protocol: TCPtargetPort: 80selector:app: myapptype: ClusterIP[root@k8s2 service]# kubectl apply -f myapp.yml[root@k8s2 service]# kubectl get svc
NAME         TYPE        CLUSTER-IP      EXTERNAL-IP   PORT(S)   AGE
kubernetes   ClusterIP   10.96.0.1               443/TCP   4d1h
myapp        ClusterIP   10.107.249.53           80/TCP    7s

默认使用iptables调度
在这里插入图片描述

3.IPVS模式的service

Service 是由 kube-proxy 组件,加上 iptables 来共同实现的
kube-proxy 通过 iptables 处理 Service 的过程,需要在宿主机上设置相当多的 iptables 规则,如果宿主机有大量的Pod,不断刷新iptables规则,会消耗大量的CPU资源。
IPVS模式的service,可以使K8s集群支持更多量级的Pod。

查看没有设置ipvs模式时候的ipvs
[root@server2 ~]# lsmod | grep ip    ##可以查看对应的ipvs是没有使用的,还是使用的iptables
ip6_udp_tunnel         12755  1 vxlan
ip_vs_sh               12688  0 
ip_vs_wrr              12697  0 
ip_vs_rr               12600  0 
ip_vs                 145497  6 ip_vs_rr,ip_vs_sh,ip_vs_wrr

部署ipvs模式

[root@server2 ~]# yum install -y ipvsadm    ##安装ipvsadm[root@server2 ~]# kubectl get pod -n kube-system | grep kube-proxy       ##部署之前查看一下
[root@server2 ~]#  kubectl -n kube-system edit  cm kube-proxy     
...
mode: "ipvs"																		   ##进入修改mode为ipvs重启pod:
[root@server2 ~]#  kubectl -n kube-system get pod|grep kube-proxy | awk '{system("kubectl -n kube-system delete pod "$1"")}'                                                           ##更新kube-proxy pod
[root@server2 ~]# kubectl get pod -n kube-system | grep kube-proxy  ##部署之后查看是否发生变化
[root@server2 ~]# ipvasdm -ln#IPVS模式下,kube-proxy会在service创建后,在宿主机上添加一个虚拟网卡:kube-ipvs0,并分配service IP

切换ipvs模式后,kube-proxy会在宿主机上添加一个虚拟网卡:kube-ipvs0,并分配service IP
在这里插入图片描述
测试:轮循机制
在这里插入图片描述

4.clusterip

clusterip模式只能在集群内访问

[root@k8s2 service]# vim myapp.yml
---
apiVersion: v1
kind: Service
metadata:labels:app: myappname: myapp
spec:ports:- port: 80protocol: TCPtargetPort: 80selector:app: myapptype: ClusterIP                                                     ##模式

service创建后集群DNS提供解析
在这里插入图片描述
通过dig进行测试在这里插入图片描述

5.headless

Headless Service不需要分配一个VIP,而是直接以DNS记录的方式解析出被代理Pod的IP地址。
域名格式:(servicename).(servicename).(servicename).(namespace).svc.cluster.local

[root@k8s2 service]# vim myapp.yml...
---
apiVersion: v1
kind: Service
metadata:labels:app: myappname: myapp
spec:ports:- port: 80protocol: TCPtargetPort: 80selector:app: myapp type: ClusterIP                                               ##clusterIP: None												##[root@k8s2 service]# kubectl delete svc myapp
[root@k8s2 service]# kubectl apply -f myapp.yml

headless模式不分配vip
在这里插入图片描述
headless通过svc名称访问,由集群内dns提供解析
在这里插入图片描述
集群内直接使用service名称访问
在这里插入图片描述

6.从外部访问service的三种方式

(1)nodeport

[root@k8s2 service]# vim myapp.yml
---
apiVersion: v1
kind: Service
metadata:labels:app: myappname: myapp
spec:ports:- port: 80protocol: TCPtargetPort: 80selector:app: myapptype: NodePort[root@k8s2 service]# kubectl apply -f myapp.yml[root@k8s2 service]# kubectl get svc
NAME         TYPE        CLUSTER-IP      EXTERNAL-IP   PORT(S)        AGE
kubernetes   ClusterIP   10.96.0.1               443/TCP        4d1h
myapp        NodePort    10.107.249.53           80:32199/TCP   12m

nodeport在集群节点上绑定端口,一个端口对应一个服务
[root@k8s1 harbor]# curl 192.168.56.12:32199
Hello MyApp | Version: v1 | Pod Name

(2)loadbalancer

[root@k8s2 service]# vim myapp.yml
---
apiVersion: v1
kind: Service
metadata:labels:app: myappname: myapp
spec:ports:- port: 80protocol: TCPtargetPort: 80selector:app: myapptype: LoadBalancer           ##[root@k8s2 service]# kubectl apply -f myapp.yml
默认无法分配外部访问IP
[root@k8s2 service]# kubectl get svc
NAME         TYPE           CLUSTER-IP      EXTERNAL-IP   PORT(S)        AGE
kubernetes   ClusterIP      10.96.0.1               443/TCP        4d1h
myapp        LoadBalancer   10.107.23.134        80:32537/TCP   4sLoadBalancer模式适用云平台,裸金属环境需要安装metallb提供支持

7.metallb

官网:https://metallb.universe.tf/installation/
在这里插入图片描述

[root@k8s2 service]# kubectl edit configmap -n kube-system kube-proxy
apiVersion: kubeproxy.config.k8s.io/v1alpha1
kind: KubeProxyConfiguration
mode: "ipvs"                                        ##
ipvs:                                                    ##strictARP: true                               ##[root@k8s2 service]# kubectl -n kube-system get pod|grep kube-proxy | awk '{system("kubectl -n kube-system delete pod "$1"")}'下载部署文件
[root@k8s2 metallb]# wget https://raw.githubusercontent.com/metallb/metallb/v0.13.9/config/manifests/metallb-native.yaml修改文件中镜像地址,与harbor仓库路径保持一致
[root@k8s2 metallb]# vim metallb-native.yaml
...
image: metallb/speaker:v0.13.9
image: metallb/controller:v0.13.9
上传镜像到harbor
[root@k8s1 ~]# docker pull quay.io/metallb/controller:v0.13.9
[root@k8s1 ~]# docker pull quay.io/metallb/speaker:v0.13.9[root@k8s1 ~]# docker tag quay.io/metallb/controller:v0.13.9 reg.westos.org/metallb/controller:v0.13.9
[root@k8s1 ~]# docker tag quay.io/metallb/speaker:v0.13.9 reg.westos.org/metallb/speaker:v0.13.9[root@k8s1 ~]# docker push reg.westos.org/metallb/controller:v0.13.9
[root@k8s1 ~]# docker push reg.westos.org/metallb/speaker:v0.13.9

在这里插入图片描述

部署服务
[root@k8s2 metallb]# kubectl apply -f metallb-native.yaml
[root@k8s2 metallb]# kubectl -n metallb-system get pod
NAME                          READY   STATUS    RESTARTS   AGE
controller-74f844c699-gz9pt   1/1     Running   0          51s
speaker-crr2r                 1/1     Running   0          51s
speaker-kcv84                 1/1     Running   0          51s
speaker-zxc6j                 1/1     Running   0          51s
配置分配地址段
[root@k8s2 metallb]# vim config.yaml
apiVersion: metallb.io/v1beta1
kind: IPAddressPool
metadata:name: first-poolnamespace: metallb-system
spec:addresses:- 192.168.117.100-192.168.117.110		  #修改为自己本地地址段---
apiVersion: metallb.io/v1beta1
kind: L2Advertisement
metadata:name: examplenamespace: metallb-system
spec:ipAddressPools:- first-pool[root@k8s2 metallb]# kubectl apply -f config.yaml[root@k8s2 metallb]# kubectl get svc
NAME         TYPE           CLUSTER-IP      EXTERNAL-IP      PORT(S)        AGE
kubernetes   ClusterIP      10.96.0.1                  443/TCP        4d1h
myapp        LoadBalancer   10.107.23.134   192.168.117.100   80:32537/TCP   19m

在这里插入图片描述


相关内容

热门资讯

被忽略的唠叨初三作文【经典3... 被忽略的唠叨初三作文 篇一初三生活对于我们来说既是充实而又繁忙的。每天都有各种各样的学科需要学习,还...
成长路上的阳光初三作文【最新... 成长路上的阳光初三作文 篇一初中生活是我们人生中最为关键的时期之一,也是我们成长的重要阶段。在这个阶...
十面霾伏初三作文600字【优... 十面霾伏初三作文600字 篇一初三作文:抵御霾雾,守护健康霾雾是近年来频繁出现的天气现象,给人们的生...
你我之间的约定-初三作文(经... 你我之间的约定-初三作文 篇一初三作文《你我之间的约定》约定是一种承诺,是一种默契,是一种信任。而在...
倾吐心声初三作文(精彩3篇) 倾吐心声初三作文 篇一我对学校生活的感受初中三年,是我人生中最快乐、最充实的时光。回想起这段时光,我...
校园里有这么一个有趣的地方初... 校园里有这么一个有趣的地方初三作文 篇一校园里有这么一个有趣的地方在我所读的初中校园里,有一个非常有...
初三感动为话题的作文700字... 初三感动为话题的作文700字 篇一初三,是每个中学生生命中的重要阶段。在这个阶段,我们经历了许多挑战...
怒放青春初三作文(优秀3篇) 怒放青春初三作文 篇一初中三年是我们青春怒放的时刻,充满了激情与活力。这段时间是我们成长的关键阶段,...
古刹袅袅初三作文1000字【... 古刹袅袅初三作文1000字 篇一古刹袅袅初三作文1000字古刹袅袅,岁月流转间,承载着古老而庄严的历...
初三毕业的作文800字(实用... 初三毕业的作文800字 篇一初三毕业,离别之际,心情复杂。回首这三年的初中生涯,我不禁感慨万分。初三...
遇见未来作文800字初三【精... 遇见未来作文800字初三 篇一未来,是一个神秘而又充满想象的词。当我们谈论未来时,脑海中浮现的可能是...
约定,三年后实现-初三作文【... 约定,三年后实现-初三作文 篇一约定,三年后实现我和我的好朋友小明是从小一起长大的,我们的友谊可以说...
初三成长励志作文(精简6篇) 初三成长励志作文 篇一:磨砺初心,迈向成功初三,对于每个初中生来说,是一个关键的阶段。在这一年里,我...
数学与物理(精彩3篇) 数学与物理 篇一数学和物理是两门密不可分的学科,它们之间相辅相成,互相促进着科学的发展。数学为物理提...
我多想轻轻地抱着你初三抒情作... 我多想轻轻地抱着你初三抒情作文 篇一初三,是人生中一个特殊的阶段。在这个阶段里,我们经历了许多变化和...
九年级开学季作文【通用6篇】 九年级开学季作文 篇一我的新学期计划新学期开始了,我对未来的九年级生活充满了期待和憧憬。在这个关键的...
初三下学期新学期新打算作文6... 篇一:初三下学期新学期新打算新的学期开始了,对于我来说,这是一个全新的开始,一个全新的机会去追求我的...
弟弟对不起作文300字【通用... 篇一:弟弟对不起我是一个有一个比我小四岁的弟弟的姐姐。在我和弟弟的相处中,难免会有矛盾和冲突,但最近...
亲情类初三700字作文大全(... 亲情类初三700字作文大全 篇一家,是我最温暖的港湾家,是我最温暖的港湾。在这个喧嚣的世界里,家是我...
感恩的花开在成长的路上初三作... 感恩的花开在成长的路上初三作文 篇一感恩是一种美好的情感,它让我们在成长的路上更加坚定和幸福。每个人...