博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
CoreOS集成Kubernetes核心组件Kubelet
阅读量:6440 次
发布时间:2019-06-23

本文共 3065 字,大约阅读时间需要 10 分钟。

本文讲的是CoreOS集成Kubernetes核心组件Kubelet,
【编者的话】本文为CoreOS官方博客发布的新闻和说明,介绍了CoreOS中对Kubernetes的核心组件kubelet的集成和支持。通过在CoreOS中安装和使用Kubelet,演示了Kubelet的使用技巧,以及如何在Kubernetes中更好的管理和监控容器资源 。

这周我们在CoreOS Linux的
中集成了kubelet——Kubernetes的一个核心内嵌组件。
负责维护pod(应用实例)集合。Pod集合由本地系统的一个或多个容器构成。在Kubernetes集群中,kubelet作为本地代理,通过访问Kubernetes的API服务器,监控PodSpecs的状态。Kubelet也负责注册节点到Kubernetes,发送事件和pod状态,汇报资源利用率。


Kubelet在Kubernetes集群中扮演着非常重要的角色,但它也可以在单机(standalone)模式下工作。这篇文章接下来将会重点介绍运行在单机模式下的Kubelet,比如运行单节点的Kubernetes集群,借助 
 内建工具监控容器资源利用率。


首先我们要安 kubelet并运行起来。请在CoreOS Linux 773.1.0或更新版本中使用本指南。

用systemd配置Kubelet

CoreOS Linux默认集成了kubelet,并做了安全优化和易用性优化。但我们将会放宽安全限制以支持高级容器。这需要在单节点Kubernetes 上跑代理组件,该组件需要iptables的操作权限,以方便配置 Kubernetes的服务发现模型。

创建 kubelet systemd(系统管理守护进程) 单元

sudo vim /etc/systemd/system/kubelet.service

[Unit]Description=Kubernetes KubeletDocumentation=https://github.com/kubernetes/kubernetes[Service]ExecStartPre=/usr/bin/mkdir -p /etc/kubernetes/manifestsExecStart=/usr/bin/kubelet \--api-servers=http://127.0.0.1:8080 \--allow-privileged=true \--config=/etc/kubernetes/manifests \--v=2Restart=on-failureRestartSec=5[Install]WantedBy=multi-user.target

启动kubelet服务

配置好systemd单元文件后,使用
systemctl
命令启动Kubelet:

sudo systemctl daemon-reloadsudo systemctl start kubelet

为确保kubelet能开机自启动,需要激活服务:

sudo systemctl enable kubelet

这时kubelet服务应该已经跑起来了。你可以用
systemctl
状态命令确认:

sudo systemctl status kubelet

启动一个单节点Kubernetes集群

Kubelet提供了一个非常方便的接口来管理容器。Kubelet有一个清单(manifest)字典,每20秒会默认监控一次以更新pod的manifest文件。在这之前, 需要通过Kubelet Systemd单元中的
--config
标志配置文件目录 /etc/kubernetes/manifests。


Pod manifest文件用JSON或YAML文件格式化并描述文件卷集合和一个或多个容器。我们可以使用一个在manifest目录的pod manifest,部署一个单节点Kubernetes集群。

下载 Kubernetes pod manifest

wget https://raw.githubusercontent.com/coreos/pods/master/kubernetes.yaml

在互联网下载pod manifest会有存在安全风险,所以请在使用它们之前检查所有pod manifest的内容。

cat kubernetes.yaml

此时我们只需要拷贝
kubernetes.yaml
这个pod manifest到kubelet的manifest目录以启动单节点集群。

sudo cp kubernetes.yaml /etc/kubernetes/manifests/

复制完成后,你可以使用标准Docker命令行工具看到Docker镜像和容器启动:

sudo docker images sudo docker ps

几分钟后,Kubernetes集群就可以运行起来了。接下来你可以下载官方的Kubernetes客户端工具。

下载 Kubernetes 客户端

kubectl
是官方的命令行工具,用于和Kubernetes集群交互。每个Kubernetes的发行版都包含一个新的kublet版本。下载并更改它为可执行程序:

wget https://storage.googleapis.com/kubernetes-release/release/v1.0.3/bin/linux/amd64/kubectlchmod +x kubectl

Kubectl可用于获取运行的集群信息。

./kubectl cluster-info

Kubernetes master运行在

kubectl
也可用于启动pods。

./kubectl run nginx --image=nginx

get pods
命令查看运行的 pods:

./kubectl get pods

更多Kubernetes细节请翻阅 

用cAdvisor监控容器

Kubelet内置打包了
,它用于收集、合计、处理并导出给定系统的运行中容器的信息。cAdvisor 包含内置web接口,可通过4194端口访问。


[ cadvisor web 界面 ]


通过cAdvisor web UI,可很方便查看系统资源利用状况和处理列表。


[ 系统利用状况图 ]


cAdvisor也可用于监控特殊容器,例如在Kubernetes pod里运行的 kube-apiserver:


[ 用 cadvisor查看容器信息 ]


想了解更多cAdvisor信息请翻阅

CoreOS和Kubernetes的更多信息

CoreOS Linux镜像中集成kubelet表明我们对(支持)Kubernetes的承诺和要为我们用户带来最好的开源容器技术的(决心)。原生支持了 Kubernetes kubelet ,我们希望提升Kubernetes的部署效率,并提供健壮的接口以管理和监控CoreOS系统上的容器。


如果你对Kubernetes有兴趣,请务必出席在你的城市即将开展的
。如果你想要私人的在线培训,请


原文链接:(翻译:沈冠璞)
原文发布时间为:2015-08-19
本文作者:沈冠璞 
本文来自云栖社区合作伙伴DockerOne,了解相关信息可以关注DockerOne。
原文标题:CoreOS集成Kubernetes核心组件Kubelet

转载地址:http://fbuwo.baihongyu.com/

你可能感兴趣的文章
java知识大全积累篇
查看>>
善于总结所做所学的内容
查看>>
Lua-简洁、轻量、可扩展的脚本语言
查看>>
org.hibernate.MappingException: entity class not found hbm可以解析,但是实体类不能解析...
查看>>
Android -- Drag&&Drop
查看>>
Extjs4:改变Grid单元格背景色(转载)
查看>>
中医无绝症[转载]
查看>>
ZendStudio10.6.1如何安装最新的集成svn小工具?
查看>>
PHP中$_SERVER的详细参数与说明
查看>>
jquery easyui datagrid mvc server端分页排序筛选的实现
查看>>
去了大公司就一定能学到很牛的技术么?
查看>>
methanol 模块化的可定制的网页爬虫软件,主要的优点是速度快。
查看>>
IOS开发之表视图(UITableView)
查看>>
Notepad++去除代码行号的几种方法
查看>>
polay定理总结
查看>>
CodeForces 396C 树状数组 + DFS
查看>>
[sharepoint]rest api文档库文件上传,下载,拷贝,剪切,删除文件,创建文件夹,修改文件夹属性,删除文件夹,获取文档列表...
查看>>
远程桌面退出全屏/不能全屏/全屏切换的技巧
查看>>
【Java】Float计算不准确
查看>>
mybatis在xml文件中处理大于号小于号的方法
查看>>