一、K8S声明式的管理方式:
1、适合对资源的修改操作
2、声明式管理依赖于yaml文件,所有的内容都在yaml文件中声明
3、编辑好的yml文件还是要靠陈述式命令发布到K8S集群中
二、K8S中支持三种声明式的资源管理方式:
1、deployment格式:用于配置和管理资源对象
apiversion:定义api版本
kind:定义资源的类型deployment\job\ingress\service\deamonset
metadata:定义创建资源的元数据信息、资源的名称--pod的名称、命名空间的名称、pod标签
name:nginx1
namespaces:命名空间可写可不写一般是注释掉的
labels:定义标签
app:nginx1
spec:配置deployment资源对象需要的参数属性,副本数,匹配的标签以及容器的重启策略
replicas:3定义该资源pod数量也就是副本数
selector:定义标签的选择器
matchLabels:定义匹配的标签,这里得和全局保持一致
app:nginx1
template:定义业务模板,上面定义了三个副本,所有pod的属性都会和template的设置保持一致
metedata:元数据
lables:指定标签,也要和全局保持一致
app:nginx1
以上为pod的内容,以下为pod内容器内容
spec:定义pod内容器
containers:定义镜像
- name: nginx
image:nginx:1.22
ports:暴漏端口
- containerPort: 8080
如果nginx端口是默认的80,ports可以不加,因为写了也无法改变容器的端口,容器的端口是由dockerfile决定的;如果默认端口不是80就要ports做为声明,声明非默认端口。
pod和容器是分开的也是合并的,镜像定义容器,pod不能改变镜像。
kubectl create deployment nginx1 --image=nginx:1.22 --replicas=3 -n xy102
data:image/s3,"s3://crabby-images/ba239/ba23991ffdae2a773c3004affbf6a99ffd91fbca" alt=""
data:image/s3,"s3://crabby-images/92b6c/92b6ced06b3dbeb974be3848878c5e1299b5fe35" alt=""
配置修改过后apply -f就进行更改了
删除yaml文件就是相当于删除了所有资源对象
data:image/s3,"s3://crabby-images/c3f87/c3f872a46f69f7ca6c25f4bb53446657a4801431" alt=""
2.services类型书写
kubectl expose deployment nginx1 --port=80 --target-port=80 --name=nginx11 -n xy102
data:image/s3,"s3://crabby-images/07dd5/07dd55899e9bc570316f07c545ffc1aac5a6c52e" alt=""
data:image/s3,"s3://crabby-images/c3597/c359768354a1b784f1e1d7a778be57e54d38c142" alt=""
data:image/s3,"s3://crabby-images/46fcd/46fcd81ed1ae01101151780d5a5e2ec838567459" alt=""
3.pod模式:
data:image/s3,"s3://crabby-images/15f6d/15f6d12e72f40ecf251afe07aa77653b9d33df6c" alt=""
data:image/s3,"s3://crabby-images/20b59/20b59bbfd3b927fb0bb98e50ee8273c201d90406" alt=""
data:image/s3,"s3://crabby-images/662cb/662cbfa2a4858d68fe6b7668ed9fda56eb16be3d" alt=""
三、容器的重启策略和传参
1.restartPolicy:
Always:只要启动失败就会一直重启容器
Never:从不重启
OnFailure:只有容器异常退出才会重启,返回码非零时才会对容器进行重启
Always:
data:image/s3,"s3://crabby-images/d54d7/d54d76fd24e7430a348064f20d905c109fc4db9c" alt=""
data:image/s3,"s3://crabby-images/200d0/200d099f5a708fb713998086f414426e2848ac6c" alt=""
data:image/s3,"s3://crabby-images/9dfd9/9dfd9ac7ec76f049bf2984478f3f3af18ee2fe7c" alt=""
data:image/s3,"s3://crabby-images/91a55/91a554a4d24124b5e1a39fcb5bf97661040ccf25" alt=""
Never
data:image/s3,"s3://crabby-images/bed2f/bed2f57490276f7a261f470d0594f1d9f4af76f3" alt=""
data:image/s3,"s3://crabby-images/1e511/1e5110226de846aba4bc9228344ae76feb5f64ed" alt=""
Onfailure:
data:image/s3,"s3://crabby-images/4951d/4951dbaba7100e952aa8180c51d414332a2b79af" alt=""
data:image/s3,"s3://crabby-images/d3167/d3167d5bfdb523155abea671f379626d6019e939" alt=""
2.pod内的传参:
command和args(属于容器内容):在yaml文件中二者不需要传参的情况下只能有一个,args可以给command传参。
command和args与docker中CMD和ENTRYPOINT意义相同
调用bin/bash
data:image/s3,"s3://crabby-images/23959/239599d8689f9714fd9a32b41a26d377cfb783a8" alt=""
两种写法
data:image/s3,"s3://crabby-images/98345/9834504e2e51c1a4852a2321ae0ca144c0d2ec46" alt=""
data:image/s3,"s3://crabby-images/8292f/8292f1aa6e12be8b4987e3f42d25ccdcdb61a15f" alt=""
data:image/s3,"s3://crabby-images/f4fd1/f4fd19083b4ddade4932632fa5d6f8bbc1b73d22" alt=""
data:image/s3,"s3://crabby-images/8f83a/8f83a58ebab65bfedc4bf032938993e8244643e6" alt=""
执行多个命令
-c:输出目录的格式 /bin/bash
data:image/s3,"s3://crabby-images/21daa/21daa8eef6ade5c07bf534498d7de81aa9221b82" alt=""
传参:
data:image/s3,"s3://crabby-images/fdf2a/fdf2a0761d28913f9684f8ea377312dbcb4d7a65" alt=""
data:image/s3,"s3://crabby-images/222c6/222c6b2428f2d5703040a79b3a99e5479eebecd2" alt=""
不论是command还是args都会覆盖容器的标准输出
data:image/s3,"s3://crabby-images/3cddc/3cddc7850387098f55e67c7fda524d50dd5e4d27" alt=""
四、如何制作yaml文件模板
data:image/s3,"s3://crabby-images/94145/9414533cdf3494d8f19b020b7f5171ceb1562204" alt=""