当前位置: 首页 > news >正文

k8s中,服务的自动注册、自动感知、负载均衡,三个功能的含义及测试验证

自动感知,指的是客户端只用访问服务的ip,而不用关心pod在哪个节点,以及pod的ip是多少。

服务可以自动感知pod的位置及ip,核心是通过selector标签选择器找到pod

自动注册,指的是服务创建之后,会自动在k8s的kube-dns服务注册,实现域名和ip的映射,kube-dns是一个系统服务,在部署k8s的时候就有这个服务了,这个服务在kube-system系统名称空间下。其他创建的服务,来找这个dns服务,自动注册。服务域名的格式是<服务名称>.<名称空间>.svc.cluster.local

负载均衡,指的是,当一个服务后端有多个pod的时候,访问服务的请求,会自动在后端pod之间实现负载均衡,不用配置。

服务为什么实现这些功能

底层lvs技术--负载均衡比如NATDR

包括iptables技术--数据转发比如SNATDNAT

两者都可以实现路由负载均衡功能

ipbables还可以实现,修改数据包源目IP标记

四表五链实现很多各种复杂三四层路由

不需要管理员管理

都是kube-proxy配置管理

相当于员工负责管理公司防火墙负载均衡这个员工就叫kubeproxy

所以kubeproxy管理lvs负载均衡iptables防火墙域名注册

k8s底层就是一个负载均衡集群

kubeproxy自我修复机制

即使kube-proxypod全部删掉集群自动重建kube-proxypod

而且配置时候基于每一台主机一台主机上面都有kubeproxymaster主机

集群坏了kubeproxy替你维护集群kubeproxy坏了集群又会重建kubeproxy

关于k8sdns服务实现实验

kube-dns服务kube-system系统名称空间

服务自动注册测试:

服务没有创建时候

服务的域名没有被dns解析为ip

服务创建之后

服务域名dns解析10.245.23.28

这就验证k8sdns服务

对于其他服务自动注册,自动解析功能

~]# kubectl get service
NAME         TYPE        CLUSTER-IP   EXTERNAL-IP   PORT(S)   AGE
kubernetes   ClusterIP   10.245.0.1   <none>        443/TCP   2d22h
~]# kubectl get service -n kube-system 
NAME             TYPE        CLUSTER-IP       EXTERNAL-IP   PORT(S)                  AGE
kube-dns         ClusterIP   10.245.0.10      <none>        53/UDP,53/TCP,9153/TCP   2d22h
metrics-server   ClusterIP   10.245.105.229   <none>        443/TCP                  2d
~]# host 
-bash: host: command not found
~]# nslookup
-bash: nslookup: command not found
~]# yum -y install  bind-utils
~]# host  websvc.default.svc.cluster.local 10.245.0.10
# host是DNS命令行工具, websve.de...是域名,10.245.0.10是DNS服务器
Using domain server:
Name: 10.245.0.10
Address: 10.245.0.10#53
Aliases: Host websvc.default.svc.cluster.local not found: 3(NXDOMAIN)
~]# kubectl apply -f  websvc.yaml 
service/websvc created
~]# host  websvc.default.svc.cluster.local 10.245.0.10
Using domain server:
Name: 10.245.0.10
Address: 10.245.0.10#53
Aliases: websvc.default.svc.cluster.local has address 10.245.23.28
~]# cat websvc.yaml 
---
kind: Service
apiVersion: v1
metadata:
  name: websvc
spec:
  type: ClusterIP
  selector:
    app: web
  ports:
  - protocol: TCP
    port: 80
    targetPort: 80
~]# kubectl get service
NAME         TYPE        CLUSTER-IP     EXTERNAL-IP   PORT(S)   AGE
kubernetes   ClusterIP   10.245.0.1     <none>        443/TCP   2d23h
websvc       ClusterIP   10.245.23.28   <none>        80/TCP    18m
]# curl  10.245.23.28
curl: (7) Failed to connect to 10.245.23.28 port 80: Connection refused
#    这里为什么报错因为服务本身不对外提供应用只是一个代理转发没有pod时候自然访问不到
~]# kubectl replace --force -f  web1.yaml
pod "web1" deleted
pod/web1 replaced
~]# curl  10.245.23.28
Welcome to The Apache.
]# cat web1.yaml 
---
kind: Pod
apiVersion: v1
metadata:
  name: web1
  labels:
    app: web
spec:
  containers:
  - name: apache
    image: myos:httpd# 创建pod之后可以访问这时候不知道podip但是不用知道podip因为访问服务服务自动请求转发podpod在哪podip多少无所谓因为服务自动感知pod位置ip
~]# curl 10.245.23.28
Welcome to The Apache.
~]# kubectl get pods web1 -o wide
NAME   READY   STATUS    RESTARTS   AGE   IP              NODE        NOMINATED NODE   READINESS GATES
web1   1/1     Running   0          18s   10.244.21.135   node-0001   <none>           <none>
~]# kubectl replace --force -f web1.yaml 
pod "web1" deleted
pod/web1 replaced
~]# curl 10.245.23.28
Welcome to The Apache.
~]# kubectl get pods web1 -o wide
NAME   READY   STATUS    RESTARTS   AGE   IP               NODE        NOMINATED NODE   READINESS GATES
web1   1/1     Running   0          7s    10.244.240.141   node-0004   <none>           <none>
#  比如pod重建之后node001跑到node004,ip也从21.135变成了240.141,访问服务依然访问apache服务这就验证服务对于pod自动感知功能自动感知什么实现标签因为服务制定了selector标签pod资源文件中规定这个标签所以服务可以自动感知pod
~]# kubectl get pods --show-labels 
NAME   READY   STATUS    RESTARTS   AGE     LABELS
web1   1/1     Running   0          4m56s   app=web
~]# cat websvc.yaml 
---
kind: Service
apiVersion: v1
metadata:
  name: websvc
spec:
  type: ClusterIP
  selector:
    app: web
  ports:
  - protocol: TCP
    port: 80
    targetPort: 80
~]# kubectl label pods web1 app-
pod/web1 unlabeled
~]# curl 10.245.23.28
curl: (7) Failed to connect to 10.245.23.28 port 80: Connection refused
# 把pod的标签删除之后服务不可用因为服务不能通过标签找到pod
~]# kubectl label pods web1 app=web
pod/web1 labeled
~]# curl 10.245.23.28
Welcome to The Apache.
# pod设置标签之后服务可以访问所以证明服务标签pod

# 测试服务自动负载均衡功能
~]# sed  's,web1,web2,'  web1.yaml    | kubectl  apply -f  -
pod/web2 created
~]# sed  's,web1,web3,'  web1.yaml    | kubectl  apply -f  -
pod/web3 created
~]# kubectl get pods 
NAME   READY   STATUS    RESTARTS   AGE
web1   1/1     Running   0          11m
web2   1/1     Running   0          19s
web3   1/1     Running   0          7s
~]# curl 10.245.23.28/info.php
<pre>
Array
([REMOTE_ADDR] => 10.244.219.64[REQUEST_METHOD] => GET[HTTP_USER_AGENT] => curl/7.61.1[REQUEST_URI] => /info.php
)
php_host:       web2
1229
~]# curl 10.245.23.28/info.php
<pre>
Array
([REMOTE_ADDR] => 10.244.219.64[REQUEST_METHOD] => GET[HTTP_USER_AGENT] => curl/7.61.1[REQUEST_URI] => /info.php
)
php_host:       web1
1229
~]# curl 10.245.23.28/info.php
<pre>
Array
([REMOTE_ADDR] => 10.244.219.64[REQUEST_METHOD] => GET[HTTP_USER_AGENT] => curl/7.61.1[REQUEST_URI] => /info.php
)
php_host:       web3
1229
# 因为info.php文件主机名打印出来所以访问三次可以看到分别访问pod  web1web2web3证明服务自动实现负载均衡

hostDNS命令工具

nslookup也是DNS命令行工具

一个是交互式

一个交互式

相关文章:

  • 使用Python和Proxy302代理IP高效采集Bing图片
  • 软考-高级系统分析师知识点合集记录
  • 实验OSPF路由协议(课内实验)
  • 用python裁切PDF文件中的图片
  • 力扣(leetcode)每日一题 1014 最佳观光组合
  • React第十章(useState)
  • windows上安装mingw教程及mingw64国内下载地址汇总
  • 【JavaEE】http/https 超级详解
  • 六,MyBatis-Plus 扩展功能(逻辑删除,通用枚举,字段类型处理,自动填充功能,防全表更新与删除插件,MybatisX快速开发插件)
  • css的盒模型
  • 数据集-目标检测系列-豹子 猎豹 检测数据集 leopard>> DataBall
  • Spring Boot框架下的足球青训俱乐部后台开发
  • 数据分析-28-交互式数据分析EDA工具和低代码数据科学工具
  • C++ STL(1)迭代器
  • 速刷DuckDB官网24小时-掌握核心功法
  • 自己简单写的 事件订阅机制
  • ABAP的include关键字,Java的import, C的include和C4C ABSL 的import比较
  • axios请求、和返回数据拦截,统一请求报错提示_012
  • Java超时控制的实现
  • k8s如何管理Pod
  • Map集合、散列表、红黑树介绍
  • Puppeteer:浏览器控制器
  • Sequelize 中文文档 v4 - Getting started - 入门
  • Service Worker
  • Spring Cloud(3) - 服务治理: Spring Cloud Eureka
  • 大主子表关联的性能优化方法
  • 工程优化暨babel升级小记
  • 规范化安全开发 KOA 手脚架
  • 欢迎参加第二届中国游戏开发者大会
  • 基于OpenResty的Lua Web框架lor0.0.2预览版发布
  • 聊聊flink的TableFactory
  • 通过获取异步加载JS文件进度实现一个canvas环形loading图
  • 追踪解析 FutureTask 源码
  • 测评:对于写作的人来说,Markdown是你最好的朋友 ...
  • ​Distil-Whisper:比Whisper快6倍,体积小50%的语音识别模型
  • (1) caustics\
  • (160)时序收敛--->(10)时序收敛十
  • (html转换)StringEscapeUtils类的转义与反转义方法
  • (PADS学习)第二章:原理图绘制 第一部分
  • (ZT)一个美国文科博士的YardLife
  • (二十四)Flask之flask-session组件
  • (附源码)spring boot基于小程序酒店疫情系统 毕业设计 091931
  • (附源码)springboot美食分享系统 毕业设计 612231
  • (黑客游戏)HackTheGame1.21 过关攻略
  • (一)utf8mb4_general_ci 和 utf8mb4_unicode_ci 适用排序和比较规则场景
  • (转)3D模板阴影原理
  • **CI中自动类加载的用法总结
  • ... fatal error LINK1120:1个无法解析的外部命令 的解决办法
  • .NET Compact Framework 3.5 支持 WCF 的子集
  • .net mvc部分视图
  • .NET 使用 JustAssembly 比较两个不同版本程序集的 API 变化
  • .net6解除文件上传限制。Multipart body length limit 16384 exceeded
  • .NET连接MongoDB数据库实例教程
  • .NET下ASPX编程的几个小问题
  • .net中生成excel后调整宽度