Linux:kubernetes(k8s)pod的基础操作(6)-CSDN博客https://blog.csdn.net/w14768855/article/details/136462030?spm=1001.2014.3001.5501
👆这一章里有我编写nginx-demo的一个文件
apiVersion: v1 # api文档版本
kind: Pod # 资源对象类型
metadata: # pod相关的元数据,用于描述pod的数据name: nginx-demo # pod名称labels: # pod的标签type: app #这个是随便写的 自定义的标签version: 1.0.0 #这个是随便写的test: 1.0.0 #都标签随便写的namespace: 'default' #命名空间的配置
spec: #期望pod按照这里面的描述进行创建containers: #对于pod容器的描述- name: nginx #容器的名称image: nginx:1.7.9 # 指定容器的镜像imagePullPolicy: IfNotPresent #镜像拉取策略command: # 指定容器启动时执行的命令- nginx- -g- 'daemon off;'workingDir: /usr/local/nginx/html # 定义容器启动后的工作目录ports:- name: http # 端口名称containerPort: 80 # 描述容器内容要暴露的端口protocol: TCP # 端口是用什么协议通信env: # 环境变量- name: JVM_OPTS # 环境变量的名称value: '-Xms128m -Xmx128m' # 环境变量的值resources:requests: # 最少需要多少资源cpu: 100m #限制cpu最少使用 1000m=1核心 100m就是0.1个核心memory: 128Mi #限制内存最少使用129兆limits: #最多可以用多少 cpu: 200m # 限制最多可以使用多少memory: 256MirestartPolicy: OnFailure #重启策略,只有失败的情况才会重启
新加探针 :错误的路径
现在我要在这个demo文件中做出修改添加探针的一个检测
修改为
apiVersion: v1 # api文档版本
kind: Pod # 资源对象类型
metadata: # pod相关的元数据,用于描述pod的数据name: nginx-demo # pod名称labels: # pod的标签type: app #这个是随便写的 自定义的标签version: 1.0.0 #这个是随便写的test: 1.0.0 #都标签随便写的namespace: 'default' #命名空间的配置
spec: #期望pod按照这里面的描述进行创建containers: #对于pod容器的描述- name: nginx #容器的名称image: nginx:1.7.9 # 指定容器的镜像imagePullPolicy: IfNotPresent #镜像拉取策略startupProbe: #应用容器探针httpGet: # 探测方式path: /api/path #http 请求路径port: 80 # 请求端口failureThreshold: 3 # 失败多少次,才算真正失败periodSeconds: 10 # 间隔时间successThreshold: 1 # 多少次检测成功算成功timeoutSeconds: 5 # 请求超时时间command: # 指定容器启动时执行的命令- nginx - -g- 'daemon off;'workingDir: /usr/local/nginx/html # 定义容器启动后的工作目录ports: - name: http # 端口名称containerPort: 80 # 描述容器内容要暴露的端口protocol: TCP # 端口是用什么协议通信env: # 环境变量- name: JVM_OPTS # 环境变量的名称value: '-Xms128m -Xmx128m' # 环境变量的值resources: requests: # 最少需要多少资源cpu: 100m #限制cpu最少使用 1000m=1核心 100m就是0.1个核心memory: 128Mi #限制内存最少使用129兆limits: #最多可以用多少 cpu: 200m # 限制最多可以使用多少memory: 256MirestartPolicy: OnFailure #重启策略,只有失败的情况才会重启
在里面加了探针这一块,我的/api/path目录并不存在,等会启动的时候肯定会失败
现在去查看一下pod
kubectl get pod
可以看到是创建中,现在去看一下他的创建过程
可以看到是失败的
探针目标:正确的路径
apiVersion: v1 # api文档版本
kind: Pod # 资源对象类型
metadata: # pod相关的元数据,用于描述pod的数据name: nginx-po # pod名称labels: # pod的标签type: app #这个是随便写的 自定义的标签version: 1.0.0 #这个是随便写的test: 1.0.0 #都标签随便写的namespace: 'default' #命名空间的配置
spec: #期望pod按照这里面的描述进行创建containers: #对于pod容器的描述- name: nginx #容器的名称image: nginx:1.7.9 # 指定容器的镜像imagePullPolicy: IfNotPresent #镜像拉取策略startupProbe: #应用容器探针httpGet: # 探测方式path: /index.html #http 请求路径port: 80 # 请求端口failureThreshold: 3 # 失败多少次,才算真正失败periodSeconds: 10 # 间隔时间successThreshold: 1 # 多少次检测成功算成功timeoutSeconds: 5 # 请求超时时间command: # 指定容器启动时执行的命令- nginx - -g- 'daemon off;'workingDir: /usr/local/nginx/html # 定义容器启动后的工作目录ports: - name: http # 端口名称containerPort: 80 # 描述容器内容要暴露的端口protocol: TCP # 端口是用什么协议通信env: # 环境变量- name: JVM_OPTS # 环境变量的名称value: '-Xms128m -Xmx128m' # 环境变量的值resources: requests: # 最少需要多少资源cpu: 100m #限制cpu最少使用 1000m=1核心 100m就是0.1个核心memory: 128Mi #限制内存最少使用129兆limits: #最多可以用多少 cpu: 200m # 限制最多可以使用多少memory: 256MirestartPolicy: OnFailure #重启策略,只有失败的情况才会重启
这次我们监控的目录肯定是存在的了
通过该命令
kubectl describe po nginx-po
可以看到一下创建成功了
探针目标:tcp
apiVersion: v1 # api文档版本
kind: Pod # 资源对象类型
metadata: # pod相关的元数据,用于描述pod的数据name: nginx-po # pod名称labels: # pod的标签type: app #这个是随便写的 自定义的标签version: 1.0.0 #这个是随便写的test: 1.0.0 #都标签随便写的namespace: 'default' #命名空间的配置
spec: #期望pod按照这里面的描述进行创建containers: #对于pod容器的描述- name: nginx #容器的名称image: nginx:1.7.9 # 指定容器的镜像imagePullPolicy: IfNotPresent #镜像拉取策略startupProbe: #应用容器探针# httpGet: # 探测方式# path: /index.html #http 请求路径tcpSocket :port: 80 # 请求端口failureThreshold: 3 # 失败多少次,才算真正失败periodSeconds: 10 # 间隔时间successThreshold: 1 # 多少次检测成功算成功timeoutSeconds: 5 # 请求超时时间command: # 指定容器启动时执行的命令- nginx - -g- 'daemon off;'workingDir: /usr/local/nginx/html # 定义容器启动后的工作目录ports: - name: http # 端口名称containerPort: 80 # 描述容器内容要暴露的端口protocol: TCP # 端口是用什么协议通信env: # 环境变量- name: JVM_OPTS # 环境变量的名称value: '-Xms128m -Xmx128m' # 环境变量的值resources: requests: # 最少需要多少资源cpu: 100m #限制cpu最少使用 1000m=1核心 100m就是0.1个核心memory: 128Mi #限制内存最少使用129兆limits: #最多可以用多少 cpu: 200m # 限制最多可以使用多少memory: 256MirestartPolicy: OnFailure #重启策略,只有失败的情况才会重启
现在是使用tcp进行一个监控了
探针目标:目录内容
apiVersion: v1 # api文档版本
kind: Pod # 资源对象类型
metadata: # pod相关的元数据,用于描述pod的数据name: nginx-po # pod名称labels: # pod的标签type: app #这个是随便写的 自定义的标签version: 1.0.0 #这个是随便写的test: 1.0.0 #都标签随便写的namespace: 'default' #命名空间的配置
spec: #期望pod按照这里面的描述进行创建containers: #对于pod容器的描述- name: nginx #容器的名称image: nginx:1.7.9 # 指定容器的镜像imagePullPolicy: IfNotPresent #镜像拉取策略startupProbe: #应用容器探针# httpGet: # 探测方式# path: /index.html #http 请求路径# tcpSocket :# port: 80 # 请求端口exec:command:- sh- -c- " echo 'success' > /inited"failureThreshold: 3 # 失败多少次,才算真正失败periodSeconds: 10 # 间隔时间successThreshold: 1 # 多少次检测成功算成功timeoutSeconds: 5 # 请求超时时间command: # 指定容器启动时执行的命令- nginx - -g- 'daemon off;'workingDir: /usr/local/nginx/html # 定义容器启动后的工作目录ports: - name: http # 端口名称containerPort: 80 # 描述容器内容要暴露的端口protocol: TCP # 端口是用什么协议通信env: # 环境变量- name: JVM_OPTS # 环境变量的名称value: '-Xms128m -Xmx128m' # 环境变量的值resources: requests: # 最少需要多少资源cpu: 100m #限制cpu最少使用 1000m=1核心 100m就是0.1个核心memory: 128Mi #限制内存最少使用129兆limits: #最多可以用多少 cpu: 200m # 限制最多可以使用多少memory: 256MirestartPolicy: OnFailure #重启策略,只有失败的情况才会重启
这个就是会在根目录下创建一个文件并且写入内容
kubectl exec -it nginx-po -c nginx -- cat /inited
将nginx-po修改为你的pod名称就能看到了容器目录内的内容