1.Node
data:image/s3,"s3://crabby-images/c295f/c295f8a9c362cf7c93b78da11e6483034bbe514e" alt=""
其实在我们使用k8s get no -oyaml node1这样的命令时,会看到apiVersion和kind,这两个就是metaData,kind会是node,它的apiVersion是v1,其实这个v1前面应该还有group的信息,但是因为node是core group,所以它的group在K8S里面是空,其他的group一般会有group名字斜杠v1去代表。
CIDR其实是节点的subnet,也就是这个节点上的pod,能用哪个子网去分IP。
2.Namespace
data:image/s3,"s3://crabby-images/d9ddf/d9ddf6b0fb3eab656113aa3b14ace0dff5367224" alt=""
假设集群中有20W个Pod,属于1万个应用,可能每个应用我都创建一个Namespace,也就是创建出了一个个的虚拟目录。那么接下来就可以把这些对象装在这些namespace里面,那么当我去操作这些对象的时候,我能知道我要去看哪个业务的对象或者哪个部门的对象,我就可以去看对应的namespace。
3.Pod
data:image/s3,"s3://crabby-images/1a143/1a143d601986dfef6d0c8200c54f6f689f8f8dd5" alt=""
3.1 如何通过Pod对象定义支撑应用运行
data:image/s3,"s3://crabby-images/2cb16/2cb1625de7f0a20a5ba3f909c224efe6795a1186" alt=""
4.存储卷
data:image/s3,"s3://crabby-images/7abf0/7abf07db61d347943eb0be4b9b4ce19a4e0781de" alt=""
5.Pod网络
data:image/s3,"s3://crabby-images/23b23/23b23539d42c72307fc17de544f8bbda1845f35f" alt=""
当一个Pod里面有多个容器的时候,它们是共享同一个网络namespace的
6.资源限制
data:image/s3,"s3://crabby-images/bad53/bad53d68555948e3153b05c681bfbc3528417021" alt=""
data:image/s3,"s3://crabby-images/716c7/716c7f361aa2dd0d46aaad30d55cf84237df5b9c" alt=""
7.健康检查
data:image/s3,"s3://crabby-images/99fe2/99fe2da668ca9aa4222c1e4869065b036e48a202" alt=""
data:image/s3,"s3://crabby-images/b04fd/b04fdf2b539a288a3aeae84bb922c18fbe085e13" alt=""
8.ConfigMap
data:image/s3,"s3://crabby-images/6ab59/6ab594805718284bb2cf1c1524ab6671502fd64e" alt=""
9.秘钥对象(Secret)
data:image/s3,"s3://crabby-images/1c8df/1c8df05659634e551a1d5b75dcf4288f1edf6343" alt=""
10.用户&服务账户
data:image/s3,"s3://crabby-images/d7d51/d7d512af61ac4f78f2b19cfe0c8a538ee0955057" alt=""
当我们去建立namespace的时候,比如说建立了default namespace,那么在每个namespace里面,它会去创建一个对象,叫做Service Account(比如defulat的service account),k8s会自动为每一个namespace,创建一个service account,这个service account会对应一个Secret,所以也就是在当前的namespace下面,会有一个secret,这个secret会有namespace的名字。
ServiceAccount的作用:K8S在启动Pod的时候,它会默认地为这个pod分配一个service account,并且会把service account对应的secret mount到这个pod里面,在pod里面想要去跟api Server通信的时候,你就可以读取它mount进来的service account所对应secret里面的token和ca,并且以这个token的身份去跟apiServer通信。
11.Service
data:image/s3,"s3://crabby-images/3a9bf/3a9bf74b69e7bebb9dd61686174162e29cd074f5" alt=""
每个集群的节点上面,有一个kube-proxy的对象,这个对象会来watch service的变化,并且去配置负载均衡,当我们每创建一个Service,默认情况下,他就会为这个service创建一个分配一个cluster IP,我们接下来就可以通过cluster IP去访问这个服务了。Service是怎么跟Nginx的pod产生关系的呢,service里面有一个selector,selector中有一个run 等于pod label。
12.Service Spec
data:image/s3,"s3://crabby-images/a793e/a793e0ddcc0ed36618bc8f1c3e883367728b2876" alt=""
13.副本集
data:image/s3,"s3://crabby-images/b4585/b4585e696653c42fc08ff07b602d258de6b90de5" alt=""
14.Deployment
data:image/s3,"s3://crabby-images/efece/efece9259f4a46ac72d9c0e8a8bcb22681eaf7fa" alt=""
Deployment创建的时候,它会继续计算当前的pod模板的hash,并且根据这个hash创建一个replicaSet,并且按照replica的数量去设置这个副本集里面需要多少个副本。如果我们做应用升级,就会导致hash发生变化,deployment controller会根据这个hash值创建新的deployment Set,接下来会逐渐让新的replicaSet慢慢涨副本,老的慢慢降副本,以此完成滚动升级。
Deployment用于控制无状态的应用副本。
15.有状态服务集(Stateful Set)
data:image/s3,"s3://crabby-images/1ed4a/1ed4a7b38bb0c4d468f9e9c4fdfd216527f8d8e8" alt=""
16.StatefulSet和Deployment的区别
data:image/s3,"s3://crabby-images/6dc10/6dc104c93ea930133232d50aa555ce1c267c2f2b" alt=""
17.任务(Job)
data:image/s3,"s3://crabby-images/8249b/8249b07e942e94e2ad7609eb4687b21a476adcee" alt=""
18.后台支撑服务集(Daemon Set)
data:image/s3,"s3://crabby-images/0f056/0f0568cbfaad2b6c19e17db07068496f810a50d9" alt=""
19.存储PV和PVC
data:image/s3,"s3://crabby-images/c9a66/c9a6662377696e92b4b84c296f23964a06de83e5" alt=""
20.CustomResourceDefinition
data:image/s3,"s3://crabby-images/e1949/e19497439130f6ac138cfc5d725613e0150053b9" alt=""
网友评论