是否可以在kubernetes中自动存储包含应用程序服务器(如wildfly / tomcat / jetty /)的docker容器?例如在cpu& ram使用或基于http请求?如果有一个内置功能,我无法找到它,或者是否可以为此编写类似配置脚本的内容?如果是这样,魔法在哪里发生?
答案 0 :(得分:4)
尚未支持对容器进行自动缩放,并且不是Kubernetes近期1.0 roadmap的一部分(意味着核心团队不会很快添加它,但外部贡献肯定是受欢迎的)。
答案 1 :(得分:2)
您可以在kubernetes 1.3之后使用水平pod自动缩放。 kubernetes博客提供了有关功能的详细信息。
http://blog.kubernetes.io/2016/07/autoscaling-in-kubernetes.html
但上面的文章主要关注GKE。所以下面会提供更多信息。
https://kubernetes.io/docs/user-guide/horizontal-pod-autoscaling/
此处描述了如何使用kubectl进行pod自动缩放。
kubectl autoscale (-f FILENAME | TYPE NAME | TYPE/NAME) [--min=MINPODS] --max=MAXPODS [--cpu-percent=CPU] [flags]
实施例
# Auto scale a deployment "foo", with the number of pods between 2 and 10, target CPU utilization specified so a default autoscaling policy will be used:
kubectl autoscale deployment foo --min=2 --max=10
# Auto scale a replication controller "foo", with the number of pods between 1 and 5, target CPU utilization at 80%:
kubectl autoscale rc foo --max=5 --cpu-percent=80
答案 2 :(得分:1)
由于Kubernetes 1.2自动缩放是稳定API的一部分。它基于CPU使用率或基于容器本身提供的指标来完成。
它可以用于这样的部署或复制控制器:
# Auto scale a deployment "foo", with the number of pods between 2 and 10, target CPU utilization specified so a default autoscaling policy will be used:
kubectl autoscale deployment foo --min=2 --max=10
# Auto scale a replication controller "foo", with the number of pods between 1 and 5, target CPU utilization at 80%:
kubectl autoscale rc foo --max=5 --cpu-percent=80
有关详细信息,请参阅Horizontal scaling说明,kubectl autoscale文档和official blog内的官方文档。
答案 3 :(得分:0)
您可以使用Horizontal Pod Autoscaler自动缩放部署。
kubectl autoscale deployment task2deploy1 –cpu-percent=80 –min=2 –max=6
该命令将确保部署的最少2个Pod和最多6个pod,目标CPU利用率设置为80%。 您可以使用以下方式列出自动定标器:
kubectl get hpa
名称参考目标MINPODS MAXPODS REPLICAS
task2deploy1部署/ task2deploy1 / 80%2 6 0
kubectl describe hpa
名称:task2deploy1
有关自动定标器的很多信息将打印在屏幕上。
使用以下命令继续检查广告连播数量的变化:
kubectl describe deployment task2deploy1