K8S控制平面组件API Server----高可用及apima
2023-06-16 本文已影响0人
青衣敖王侯
1.启动API Server示例
data:image/s3,"s3://crabby-images/4982e/4982e7f3ca5134865f52b3e427eadce018c54a5b" alt=""
2.构建高可用的多副本API Server
data:image/s3,"s3://crabby-images/2231c/2231c3b77c5bff62cf1e282490d82015d17d80f6" alt=""
2.1 预留充足的CPU、内存资源
data:image/s3,"s3://crabby-images/90918/90918e4cd00023d27ffb86b4e7e2e2e38d3c8464" alt=""
2.2 善用速率限制
data:image/s3,"s3://crabby-images/d6335/d63354a9fffd72c0156c21af95b535af98534eee" alt=""
data:image/s3,"s3://crabby-images/3c4f8/3c4f8fd55edebdf75e88a8cf1c645ce8e276802a" alt=""
2.3 设置合适的缓存大小
data:image/s3,"s3://crabby-images/b39bb/b39bbff887a99c7d98bfd64b9c1bdf626b757a99" alt=""
data:image/s3,"s3://crabby-images/84778/847780bfbdd4626ef55cecc07013e76a26bb7bd0" alt=""
2.4客户端尽量使用长链接
我们要优先用侦听,少用轮询,因为后台是一个分布式存储,其支持能力较弱。所以用户不要一直来轮询,导致etcd和API Server的压力过大
data:image/s3,"s3://crabby-images/bc252/bc252c46d8bcdd124512ff15b61b7c73dcf326e3" alt=""
2.5如何访问API Server
data:image/s3,"s3://crabby-images/901ca/901cafc1dbdd9705b9773dcd726cc096a004fdea" alt=""
同一个API Server有不同的访问入口,外部是从负载均衡过来的,比如F5,一个是从集群内部 KubeProxy来的。所有控制面的组件是希望用同一个访问入口,要么全用负载均衡上的VIP,要么全部用Kube-proxy提供的service-cluster IP.
3.搭建多租户的K8S集群
data:image/s3,"s3://crabby-images/c6888/c6888ca661acb244c321ec4761b351d5ac9d356f" alt=""
3.1认证
data:image/s3,"s3://crabby-images/90272/9027219dba5ac3535fdd47ebb0c3d56bc23d4b57" alt=""
3.2授权
data:image/s3,"s3://crabby-images/11ea5/11ea5b218d94fbb40e2a907fc1b76b96baecbe05" alt=""
4.ApiMachinery
4.1 GKV回顾
data:image/s3,"s3://crabby-images/eacc0/eacc0efa40a41e2df9597712e4a6301269ef03da" alt=""
K8S里面的对象有很多重要的属性,第一个就是TypeMeta,它定义了对象是什么。TypeMeta分为三类:
Group:根据对象所适应的业务场景来进行分类
Kind:这个对象真正的类型是什么,比如Pod,ConfigMap,Secret,Service,这些属于K8S的core Group.
Version:任何社区的代码都是从V1, alpha1开始的。External是针对外部客户端的请求来说的,Internal是针对集群内部来说的。外部所有的请求发到K8S的时候,K8S会在存入etcd之前,转成Internal Version.
4.1.1 如何定义Group
data:image/s3,"s3://crabby-images/ad090/ad0902aa021fc54ebf3c423979dc634a8557437c" alt=""
4.1.2 定义对象类型 types.go
data:image/s3,"s3://crabby-images/83984/839841728d0ad072bcf628e6b02dd105808b96cc" alt=""
List就是类似Pod这样的