可以通过手工执行kubectl scale
命令实现Pod扩容或缩容,但是这显然不符合Kubernetes的定位目标–自动化、智能化。
Kubernetes期望可以实现通过监测Pod的使用情况,实现pod数量的自动调整,于是就产生了Horizontal Pod Autoscaler(HPA)这种控制器。
HPA可以获取每个Pod利用率,然后和HPA中定义的指标进行对比,同时计算出需要伸缩的具体值,最后实现Pod的数量的调整。
其实HPA与之前的Deployment一样,也属于一种Kubernetes资源对象,它通过追踪分析RC控制的所有目标Pod的负载变化情况,来确定是否需要针对性地调整目标Pod的副本数,这是HPA的实现原理。
【例 】
要求:
使用deployment控制器创建运行nginx的pod,并创建service将该deployment进行暴露,使得外部可以访问,同时为该deployment创建HPA控制器,监测该deployment中pod的资源使用情况,设定HPA触发规则为当资源占用超过设置的阈值便进行自动扩容,资源占用低于阈值自动缩容。最后采用压测工具进行测试,使得pod内的资源占用升高,查看HPA的工作过程。
安装metrice-server
metrics-server是用来收集集群中的资源使用情况
# 安装git
[root@k8s-master ~]# yum install git -y
# 获取metrics-server, 注意使用的版本
[root@k8s-master ~]# git clone -b v0.3.6 https://github.com/kubernetes-incubator/metrics-server
# 下载完成后,此时会在当前目录下生成 metrics-server目录
# 修改deployment, 注意修改的是镜像和初始化参数
[root@k8s-master ~]# cd /root/metrics-server/deploy/1.8+/
[root@k8s-master ~]# vim metrics-server-deployment.yaml
# 按图中添加下面选项:
# hostNetwork: true
# image: registry.cn-hangzhou.aliyuncs.com/google_containers/metrics-server-amd64:v0.3.6
# args:
# - --kubelet-insecure-tls
# - --kubelet-preferred-address-types=InternalIP,Hostname,InternalDNS,ExternalDNS,ExternalIP
---
apiVersion: v1
kind: ServiceAccount
metadata:
name: metrics-server
namespace: kube-system
---
apiVersion: apps/v1
kind: Deployment
metadata:
name: metrics-server
namespace: kube-system
labels:
k8s-app: metrics-server
spec:
selector:
matchLabels:
k8s-app: metrics-server
template:
metadata:
name: metrics-server
labels:
k8s-app: metrics-server
spec:
hostNetwork: true
serviceAccountName: metrics-server
volumes:
# mount in tmp so we can safely use from-scratch images and/or read-only containers
- name: tmp-dir
emptyDir: {
}
containers:
- name: metrics-server
image: registry.cn-hangzhou.aliyuncs.com/google_containers/metrics-server-amd64:v0.3.6
imagePullPolicy: Always
args:
- --kubelet-insecure-tls
- --kubelet-preferred-address-types=InternalIP,Hostname,InternalDNS,ExternalDNS,ExternalIP
volumeMounts:
- name: tmp-dir
mountPath: /tmp
# 保存退出
# 安装metrics-server
[root@k8s-master 1.8+]# kubectl apply -f .
clusterrole.rbac.authorization.k8s.io/system:aggregated-metrics-reader created
clusterrolebinding.rbac.authorization.k8s.io/metrics-server:system:auth-delegator created
rolebinding.rbac.authorization.k8s.io/metrics-server-auth-reader created
apiservice.apiregistration.k8s.io/v1beta1.metrics.k8s.io created
serviceaccount/metrics-server created
deployment.apps/metrics-server created
service/metrics-server created
clusterrole.rbac.authorization.k8s.io/system:metrics-server created
clusterrolebinding.rbac.authorization.k8s.io/system:metrics-server created
# 查看metrics-server的pod运行情况
[root@k8s-master 1.8+]# kubectl get pod -n kube-system | grep metrics-server
metrics-server-6b976979db-9wwb5 1/1 Running 0 66s
# 使用kubectl top node 查看node资源使用情况
[root@k8s-master 1.8+]