我们谈论生活,讨论技术,借由文字,抵达心灵。
同一个 Pod 中的多个容器能够共享 Pod 级别的存储卷 Volume。Volume 可以被定义为各种类型,多个容器各自进行挂载操作,将一个 Volume 挂载为容器内部需要的目录多容器协作实践解析Pod 内包含两个容器:tomcat 和 busybox,在 Pod 级别设置 Volume"apps-logs",用于 tomcat 向其中写日志文件,busybox 读日志文件apiVersion: v1 kind: Pod metadata: name: volume-pod spec: containers: - name: tomcat # 第一个容器(主容器)tomcat image: tomcat # 使用 tomcat 镜像 ports: - containerPort: 8080 # 容器内部端口 volumeMounts: - name: app-logs
vim 编辑器卡住新开一个标签页,再次进入 vim 编辑器,按 R 进入覆盖(Recover)后,进入编辑,完成编辑后 :wq 保存。vim 进程冲突如果编辑器没有卡住,但是提示冲突时,可以选择根据需要,按提示选择需要进行的操作:[O]pen Read-Only, (E)dit anyway, (R)ecover, (Q)uit, (A)bort:继续编辑配置文件,完成编辑后 :wq 保存。删除 swp 文件虽然已经完成了文件编辑并保存,但是在出现冲突时,就已经产生了一个 .swp 的隐藏文件,需要找到他并删除。查看隐藏文件:ls -la会看到与 vim 编辑器卡住 / 进程冲突的同名的 .swp 文件。再执行删除命令:sudo rm .pod-volume-applogs.yaml.swp成功删除后,就可以再次用 vim 打开并编辑文件了。如果还提示有 .swp 文件,可以先确认 vim 进程是否还在运行ps aux | grep vim如果发现有运行的 vim 进程,可以强制结束:killall vim # 或者 pkill vim然后再删除 swp 文件重试。附录:查找 swp
静态 Pod 由 kubelet 管理的仅存在于特定 Node 上的 Pod。他们不能通过 API Server 进行管理,无法与 RC、Deployment 或者 DaemonSet 进行关联,并且 kubelet 无法对他们进行健康检查。静态 Pod 是 由 kubectl 创建,并总在 kubelet 所在的 Node 上运行。创建静态 Pod - 配置文件方式设置 kubelet 的启动参数 --config,指定 kubelet 需要监控的配置文件所在的目录,kubelet 会定期扫描该目录,并根据该目录下的 .yaml 或 .json 文件进行创建操作。假设配置目录为 /etc/kubelet.d,配置启动参数为 --config=/etc/kubelet.d/ ,然后重启 kubelet 服务。--config=/etc/kubelet.d/ 适用于指定 kubelet 配置文件的参数,不是静态 Pod 的配置文件内容。kubelet 会从该目录中读取配置文件来启动和管理 Pod,这个参数通常用于配置 kubelet 的行为,而不是直接管理静态 Pod静态 Pod 实践检
Pod 定义YAML 格式的 Pod 定义文件完整内容如下:apiVersion: v1 # Pod API 版本,v1 是稳定版,String,必选 kind: Pod # 资源类型为 Pod,String,必选 metadata: # 元数据定义,Object,必选 name: string # Pod 的名称,必选,命名规范需要符合 RFC 1035 规范,metadata.name namespace: string # Pod 所属的命名空间,默认值为 default,必选,metadata.namespace labels: # 标签定义 key: value # 标签是 key-value 格式 annotations: # 注解定义 key: value
kubectl 用法概述kubectl 命令行的语法如下:kubectl [command] [TYPE] [NAME] [flags]command:子命令,用于操作 Kubernetes 集群资源对象的命令,如 create、delete、describe、get、apply 等TYPE:资源对象的类型,区分大小写,能以单数。复数或简写形式表示,如,以下三种 TYPE 是等价的:kubectl get pod pod1 kubectl get pods pod1 kubectl get po pod1NAME:资源对象的名称,区分大小写,如果不指定名称,系统则将返回属于 TYPE 的全部对象的列表flags:kubectl 子命令的可选参数,如使用 -s 指定 API Server 的 URL 地址而不用默认值kubectl 可操作的资源对象类型 及其缩写资源对象类型缩写资源对象类型缩写cluster statefulsets componentstatusescspersistentvolumeclaimspvcconfigmapscmpersistentvolumespvdae
糖呀糖 xyz