k8s使用

https://blog.csdn.net/weixin_29115985/article/details/78932991

一. k8s基本操作命令:

创建:kubectl create -f xxx.yaml

查询:kubectl get pod yourPodName

kubectl describe pod yourPodName

删除:kubectl delete pod yourPodName

更新:kubectl replace /path/to/yourNewYaml.yaml

二. yaml文件的写法及遇到的问题

  1. 创建 pod 资源对象的yaml文件:(简洁版)

apiVersion: v1
kind: Pod
metadata:
name: pod-redis
labels:
name: redis
spec:
restartPolicy: Always #表明该容器一直运行,默认k8s的策略,在此容器退出后,会立即创建一个相同的容器
nodeSelector:
zone: node1 #节点选择,先给主机打标签kubectl label nodes kube-node1 zone=node1
containers:

  • name: pod-redis
    image: docker.io/redis
    imagePullPolicy: Never #三个选择Always、Never、IfNotPresent,每次启动时检查和更新(registery)images的策略
    ports:
    • containerPort: 6379 #容器开发对外的端口
      hostPort: 8080 #映射到主机的端口/对外映射的端口(一般可以不写)
      编辑好以上yaml文件后,执行以下命令:

kubectl create -f pod-redis.yaml
kubectl get pod

  1. 创建 rc 资源对象的yaml文件:(简洁版)

apiVersion: v1 #指定api版本,此值必须在kubectl apiversion中,可通过命令kubectl api-versions 查看
kind: ReplicationController #指定创建资源的角色/类型
metadata: #资源的元数据/属性
name: rc-nginx-3 #资源的名字,在同一个namespace中必须唯一
spec:
replicas: 3 #副本数量3
template: #这里Pod的定义
metadata:
labels: #Pod的label,可以看到这个label与spec.selector相同
app: nginx-3
spec: #specification of the resource content 指定该资源的内容
restartPolicy: Always #表明该容器一直运行,默认k8s策略,在此容器退出后,会立即创建一个相同的容器
containers:
- name: nginx-3 #容器的名字
image: docker.io/nginx #容器使用的镜像地址
ports:
- containerPort: 80 #容器开发对外的端口
编辑好以上yaml文件后,执行以下命令:

kubectl create -f rc-nginx.yaml
kubectl get rc
kubectl get pod -o wide

  1. pod创建后,容器无法启动报错:

刚创建好pod后,出现了pod卡在ContainerCreating的状态,即容器无法启动问题,用命令 kubectl describe pod xxx 查看发现报错:details: (open /etc/docker/certs.d/registry.access.redhat.com/redhat-ca.crt: no such file or directory)

解决方法:

yum install rhsm -y

  1. 通过修改replicas的数量来控制pod的启动数量:

kubectl scale rc rc-nginx-3 --replicas=1
注:如加入了特定的namespace,需要在rc后加上:kubectl scale rc --namespace=kube-system rc-nginx-3 --replicas=1

  1. 创建 service 资源对象的yaml文件:(简洁版)

apiVersion: v1
kind: Service
metadata:
name: kube-system
labels:
name: kube-system
spec:
ports:

  • port: 8081
    targetPort: 80
    protocol: TCP
    selector:
    name: nginx-3
    这种新建的方法个人感觉不太常用,因为一般情况下,为了让客户端应用能够访问到 Pod 的实例,可以直接通过kubectl expose命令来创建Service的:
    kubectl expose rc rc-nginx-3
    查看新创建的Service可以看到系统为它分配了一个虚拟的IP地址(clusterIP),而Service所需的端口号则从Pod中的containerPort复制而来。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值