前言
1.1:概述
k8s支持使用YAML和JSON格式的文件来创建资源对象,相比较而言:
-
json格式的文件用于接口之间消息的传递,更适合二次开发
-
yaml格式的文件只是一种简洁的非标记性语言,更适合运维
YAML的文件格式和注意事项
1、不支持制表符tab键缩进,需要使用空格缩进,使用缩进表示层级关系
2、通常开头缩进2个空格,缩进的空格数不重要,只要相同层级的元素左对齐即可
3、字符后缩进一个空格,如冒号、逗号、横杆
4、用#号注释
5、如果包含特殊字符用单引号引起来
6、布尔值必须用引号括起来7、—表示yaml文件格式的分割
1.2:使用YAML文件创建资源对象
1、查看资源版本标签
[root@master ~]# kubectl api-versions
admissionregistration.k8s.io/v1beta1
apiextensions.k8s.io/v1beta1
apiregistration.k8s.io/v1
apiregistration.k8s.io/v1beta1
apps/v1
apps/v1beta1
apps/v1beta2
authentication.k8s.io/v1
authentication.k8s.io/v1beta1
authorization.k8s.io/v1
authorization.k8s.io/v1beta1
autoscaling/v1
autoscaling/v2beta1
autoscaling/v2beta2
batch/v1
batch/v1beta1
certificates.k8s.io/v1beta1
coordination.k8s.io/v1beta1
events.k8s.io/v1beta1
extensions/v1beta1
networking.k8s.io/v1
policy/v1beta1
rbac.authorization.k8s.io/v1
rbac.authorization.k8s.io/v1beta1
scheduling.k8s.io/v1beta1
storage.k8s.io/v1
storage.k8s.io/v1beta1
v1
例如:写一个yuml文件
2、创建目录,编辑测试文件
[root@master ~]# mkdir test
[root@master ~]# cd test/
[root@master test]# vim nginx-test.yaml
apiVersion: apps/v1 '//指定api版本标签'
kind: Deployment '//定义资源的类型/角色,deployment为控制器'
metadata: '//定义资源的元数据'
name: nginx-test '//定义资源的名称,在同一个namespace中必须唯一'
labels: '//定义资源的标签'
app: nginx
spec: '//定义容器模板
replicas: 3 '//定义副本数量'
selector: '//选择器'
matchLabels: '//匹配标签'
app: nginx '//匹配模板名称'
template: '//模板'
metadata:
labels:
app: nginx
spec:
containers: '//定义容器信息'
- name: nginx '//-:表示参数,容器名,与标签名要相同'
image: nginx:1.15.4 '//容器使用的镜像以及版本'
ports:
- containerPort: 80 '//定义容器的对外端口'
3、创建资源对象
[root@master test]# kubectl create -f nginx-test.yaml
deployment.apps/nginx-test created
[root@master test]# kubectl get pod '//创建成功'
NAME READY STATUS RESTARTS AGE
nginx-dbddb74b8-5s6h7 1/1 Running 1 9d
nginx-test-d55b94fd-9zmdj 1/1 Running 0 55s
nginx-test-d55b94fd-b8lkl 1/1 Running 0 55s
nginx-test-d55b94fd-w4c5k 1/1 Running 0 55s
4、创建service服务对外提供访问并测试
[root@master test]# vim nginx-service-test.yaml
apiVersion: v1
kind: Service
metadata:
name: nginx-service
labels:
app: nginx
spec:
type: NodePort
ports:
- port: 80
targetPort: 80
selector:
app: nginx
[root@master test]# kubectl create -f nginx-service-test.yaml
service/nginx-service created
[root@master test]# kubectl get svc
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
kubernetes ClusterIP 10.0.0.1 <none> 443/TCP 2d5h
nginx-service NodePort 10.0.0.226 <none> 80:47710/TCP 5s
1.3:使用命令快速生成YAML或者JSON文件
1、测试创建资源对象的命令正确性,并不真正执行创建
[root@master test]# kubectl run nginx-test01 --image=nginx --port=80 --replicas=2 --dry-run
kubectl run -- generator=deployment/apps.v1beta1 is DEPRECATED and will be removed in a future version. Use kubectl create instead.
deployment.apps/nginx-test01 created (dry run)
'//以上提示说明命令是正确的'
2、自动生成yaml格式的文件不保存
[root@master test]# kubectl run nginx-test01 --image=nginx --port=80 --replicas=2 --dry-run -o yaml '//此命令直接生成yaml文件内容展示出来,并不会保存'
[root@master test]# kubectl run nginx-test01 --image=nginx --port=80 --replicas=2 --dry-run -o json '//也可以生成json格式'
3、自动生成yaml格式的文件并保存
[root@master test]# kubectl run nginx-test01 --image=nginx --port=80 --replicas=2 --dry-run -o yaml > nginx-test01.yaml
kubectl run --generator=deployment/apps.v1beta1 is DEPRECATED and will be removed in a future version. Use kubectl create instead.
[root@master test]# ls
nginx-service-test.yaml nginx-test01.yaml nginx-test.yaml '//成功生成,可以在此基础上修修改改了'
4、将现有的资源生成模板并导出
[root@master test]# kubectl get pod
NAME READY STATUS RESTARTS AGE
nginx-dbddb74b8-5s6h7 1/1 Running 1 9d '//用此nginx来生成模板并导出'
nginx-test-d55b94fd-9zmdj 1/1 Running 0 11m
nginx-test-d55b94fd-b8lkl 1/1 Running 0 11m
nginx-test-d55b94fd-w4c5k 1/1 Running 0 11m
[root@master test]# kubectl get deployment/nginx --export -o yaml > nginx-test02.yaml
[root@master test]# ls
nginx-service-test.yaml nginx-test01.yaml nginx-test02.yaml nginx-test.yaml
5、查看yaml文件某一字段的帮助信息
[root@master test]# kubectl explain pods.spec.containers