前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >「走进k8s」Kubernetes1.15.1必备知识静态pod(17)

「走进k8s」Kubernetes1.15.1必备知识静态pod(17)

作者头像
IT架构圈
发布2019-08-19 15:25:31
1.9K0
发布2019-08-19 15:25:31
举报
文章被收录于专栏:IT架构圈IT架构圈

上次说了yaml的使用,也创建了2个pod,从这次开始深入的学习pod,除了之前创建的busybox的pod,在k8s里面还有个特殊的pod,静态pod,这次就说说这个静态pod。

(一)静态pod

静态pod是由kubelet进行管理的仅存在与特定node上的pod,他们不能通过api server进行管理,无法与rc,deployment,ds进行关联,并且kubelet无法对他们进行健康检查。静态pod总是由kubelet创建的,并且总在kubelet所在的node上运行。静态 pod 始终绑定在某一个kubelet,并且始终运行在同一个节点上。kubelet会自动为每一个静态 pod 在 Kubernetes 的 apiserver 上创建一个镜像 Pod(Mirror Pod),因此我们可以在 apiserver 中查询到该 pod(就相当于创建了一个副本),但是不能通过 apiserver 进行控制(例如不能删除)。创建静态pod有两种方式:配置文件方式和HTTP方式。

  • ① 配置文件方式

配置文件就是放在特定目录下的标准的 JSON 或 YAML 格式的 pod 定义文件。用kubelet --pod-manifest-path=来启动kubelet进程,kubelet 定期的去扫描这个目录,根据这个目录下出现或消失的 YAML/JSON 文件来创建或删除静态 pod。 查找原有的配置文件路径,尽量不要用kubelet --pod-manifest-path=指定的目录,会很乱

代码语言:javascript
复制
systemctl status kubelet
# 发现在这个文件夹下:/usr/lib/systemd/system/kubelet.service.d
cd /usr/lib/systemd/system/kubelet.service.d
ls
cat /usr/lib/systemd/system/kubelet.service.d/10-kubeadm.conf
cd /etc/kubernetes/manifests/ 
ls

etcd,kube-apiserver,kube-controller-manager,kebe-scheduler 这些都是在kubelet启动的时候自动启动的。

代码语言:javascript
复制
kubectl get pods -n kube-system
# 里面有几个都是在开机的时候自动跟这kubelet启动的。

在manifests目录下,新建立一个yaml 因为直接放到manifests目录下,就不需要使用命令manifest-path=

代码语言:javascript
复制
---
apiVersion: v1
kind: Pod
metadata:
  name: first-pod
  labels:
    app: bash
    tir: backend
spec:
  containers:
  - name: bash-container
    image: docker.io/busybox
    command: ['sh', '-c', 'echo Hello Kubernetes! && sleep 3600']
  • ② 查看静态pod

查看pod,自动同步副本可以在apiserver中查询到

代码语言:javascript
复制
kuectl get pods
# first-pod-k8s-master 就是静态pod

在dashboard查看

  • ③ 删除静态pod

删除后,自动又重新启动了。

代码语言:javascript
复制
kuectl delete pod first-pod-k8s-master
kuectl get pods

在dashboard删除

如何删除,只要在文件夹下把这个文件给移除掉就可以了 ,命令上边是3个,移除后pod变成了2个。

代码语言:javascript
复制
mv static-pod.yaml /tmp/
  • ④ 通过 HTTP 创建静态 Pods

通过设置kubelet的启动参数“--manifest-url”,kubelet将会定期从该URL地址下载pod的定义文件,并以.yaml或.json文件的格式进行解析,然后创建pod。其实现方式与配置文件方式是一致的。

PS:静态pod主要可以把主要的组件进行容器化,etcd,kube-apiserver,kube-controller-manager,kebe-scheduler 不受apiserver的控制,假如可以控制自己生自己自己养自己绝对是不可能的。通过这篇文章可以尝试创建下静态的pod。

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2019-08-14,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 编程坑太多 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • (一)静态pod
相关产品与服务
容器服务
腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档