求知 文章 文库 Lib 视频 iPerson 课程 认证 咨询 工具 讲座 Model Center   Code  
会员   
 


业务架构设计
4月18-19日 在线直播



基于UML和EA进行系统分析设计
4月25-26日 北京+在线



AI 智能化软件测试方法与实践
5月23-24日 上海+在线
 
 
 

Kubernetes教程
Kubernetes概述
Kubernetes设计架构
kubernetes设计理念
创建Kubernetes集群
基于Docker本地运行Kubernetes
使用Vagrant
本地运行Kubrenetes v1.0
Google Computer Engine入门
AWS EC2快速入门
在Azure上使用CoreOS和Weave的 Kubernetes
从零开始k8s
CoreOS部署Kubernetes集群
CloudStack部署Kubernetes集群
vSphere部署Kubernetes集群
Ferdora部署Kubernetes集群
CentOS部署Kubernetes集群
Ubuntu物理节点上部署Kubernets集群
Mesos部署Kubernetes集群
Kubernetes用户指南:应用程序管理
名词解释 Pods
名词解释 Labels
名词解释:Namespace
名词解释 Replication Controller
名词解释:Node
名词解释:ReplicaSets
名词解释 Services
名词解释 Volumes
名词解释:PV/PVC/StorageClass
名称解释:Deployment
名词解释:Secret
名词解释:StatefulSet
名词解释:DaemonSet
名词解释:Service Account
名词解释:CronJob
名词解释:Job
名词解释:Security Context和PSP
名词解释:Resource Quotas
名词解释:Network Policy
名词解释:Ingress
名词解释:ThirdPartyResources
名词解释:ConfigMap
名词解释:PodPreset
配置Kubernetes
管理应用:部署持续运行的应用
Horizontal Pod Autoscaling
管理应用:连接应用
管理应用: 在生产环境中使用Pods和容器
Kubernetes UI
Kube-API Server
授权插件
认证插件
API Server端口配置
Admission Controller
Service Accounts集群管理指南
使用Kubernetes在云上原生部署cassandra
Spark例子
Storm 示例
示例: 分布式任务队列 Celery, RabbitMQ和Flower
Kubernetes在Hazelcast平台上部署原生云应用
Meteor on Kuberenetes
配置文件使用入门
环境向导示例
在Kubernetes上运行你的第一个容器
kubectl
安装和设置kubectl
kubectl annotate
kubectl api-versions
kubectl apply
kubectl attach
kubectl cluster-info
kubectl config
kubectl config set-cluster
kubectl config set-context
kubectl config set-credentials
kubectl config set
kubectl config unset
kubectl config use-context
kubectl config view
kubectl create
kubectl delete
kubectl describe
kubectl edit
kubectl exec
kubectl logs
kubectl version
故障排查
应用程序相关的故障排查
 
 

管理应用:部署持续运行的应用
 
1337 次浏览
63次  

在前面的章节里,我们了解了如何用 kubectl run 快速部署一个简单的复制的应用以及如何用pods(configuring-containers.md)配置并生成单次运行的容器。本文,我们将使用基于配置的方法来部署一个持续运行的复制的应用。

用配置文件生成复制品集合

Kubernetes用 Replication Controllers 创建并管理复制的容器集合(实际上是复制的Pods)。 Replication Controller 简单地确保在任一时间里都有特定数量的pod副本在运行。如果运行的太多,它会杀掉一些;如果运行的太少,它会启动一些。这和谷歌计算引擎的Instance Group Manager以及AWS的Auto-scaling Group(不带扩展策略)类似。在快速开始章节里用 kubctl run 创建的用来跑Nginx的 Replication Controller 可以用下面的YAML描述:

apiVersion: v1
kind: ReplicationController
metadata:
name: my-nginx
spec:
replicas: 2
template:
metadata:
labels:
app: nginx
spec:
containers:
- name: nginx
image: nginx
ports:
- containerPort: 80

和指定一个单独的Pod相比,不同的是设置了这里的kind域为ReplicationController,设定了需要的副本(replicas)数量以及把Pod的定义放到了template域下面。pods的名字不需要显示指定,因为它们是由 replication controller 的名字生成的。要查看支持的域列表,可以看replication controller API object。 和创建pods一样,也可以用 create 命令来创建这个replication controller:

$ kubectl create -f ./nginx-rc.yaml
replicationcontrollers/my-nginx

replication controller 会替换删除的或者因不明原因终止的(比如节点失败)pods,这和直接创建的pods的情况是不一样。基于这样的考量,对于一个需要持续运行的应用,即便你的应用只需要一个单独的pod,我们也推荐使用 replication controller 。对于单独的pod,在配置文件里可以省略 replicas 这个域,因为不设置的时候默认就只有一个副本。

查看replication controller的状态

可以用 get 命令查看你创建的replication controller:

这说明你的controller会确保有两个nginx的副本。和直接创建的pod一样,也可以用 get 命令查看这些副本:

删除replication controllers

如果想要结束你的应用并且删除repication controller。和在快速开始里一样,用下面的命令:

$ kubectl delete rc my-nginx
replicationcontrollers/my-nginx

这个操作默认会把由replication controller管理的pods一起删除。如果pods的数量比较大,这个操作要花一些时间才能完成。如果想要pods继续运行,不被删掉,可以在delete的时候指定参数 –cascade=false 。 如果在删除replication controller之前想要删除pods,pods只是被替换了,因为replication controller会再起新的pods,确保pods的数量。

Labels

Kubernetes使用自定义的键值对(称为Labels)分类资源集合,例如pods和replicationcontroller。在前面的例子里,pod的模板里只设定了一个单独的label,键是 app ,值为 nginx 。所有被创建的pod都带有这个label,可以用带-L参数的命令查看:

pod模板带的label默认会被复制为replication controller的label。Kubernetes中所有的资源都支持labels:

更重要的是,pod模板的label会被用来创建 selector ,这个 selector 会匹配所有带这些labels的pods。用 kubectl get 的go语言模板输出格式就可以看到这个域:

$ kubectl get rc my-nginx -o template --template="{{.spec.selector}}"
map[app:nginx]

如果你想要在pod模板里指定labels,但是又不想要被选中,可以显示指定 selector 来解决,不过需要确保 selector 能够匹配由pod模板创建出来的pod的label,并且不能匹配由其他replication controller创建的pods。对于后者,最直接最保险的方法是给replication controller分配一个独特的label,并且在pod模板和selector里都进行指定。


您可以捐助,支持我们的公益事业。

1元 10元 50元





认证码: 验证码,看不清楚?请点击刷新验证码 必填



1337 次浏览
63次
 捐助