内容简介:使用 helm 命令更新一个 release:如果需要回滚:
使用 Helm
可以很方便的部署 Kubernetes 应用,但是如果对于线上的应用部署或者更新后出现了问题,要及时回滚到之前的版本该如何去做呢?当然我们可以手动通过 kubectl rollout
去进行控制,但是难免需要手动去操作。今天给大家介绍一个 Helm 的插件 Helm monitro,通过监听 Prometheus 或 ElasticSearch 监控或者日志数据,在发生故障时自动回滚 release。
Helm 命令
使用 helm 命令更新一个 release:
$ helm upgrade my-release company-repo/common-chart
如果需要回滚:
$ helm rollback my-release
安装 Helm 插件:
$ helm plugin install https://github.com/repo/name
然后可以使用下面命令查看插件使用方法:
$ helm foo --help
Helm 插件文件结构如下:
Helm monitor
通过 Helm monitor 插件监控一个 release 示意图如下:
安装 Helm monitor 插件:
$ helm plugin install https://github.com/ContainerSolutions/helm-monitor
查看使用方法:
$ helm monitor --help This command monitor a release by querying Prometheus or Elasticsearch at a given interval and take care of rolling back to the previous version if the query return a non-empty result. Usage: monitor [command] Available Commands: elasticsearch query an elasticsearch server help Help about any command prometheus query a prometheus server
如果在过去5分钟内的5xx错误率超过0,则启动回滚:
$ helm monitor prometheus \ --prometheus=http://prometheus \ my-release \ 'rate(http_requests_total{code=~"^5.*$"}[5m]) > 0'
需要通过 --prometheus
参数指定 prometheus server 的地址,默认连接地址 http://localhost:9090
。
使用 ElasticSearch, Lucene Query,在发现了 500 状态码后触发回滚操作:
$ helm monitor elasticsearch \ --elasticsearch=http://elasticsearch:9200 \ my-release \ 'status:500 AND kubernetes.labels.app:app AND version:2.0.0'
同样需要通过 --elasticsearch
参数指定 Elasticsearch 集群的地址,默认连接地址: http://localhost:9200
。
当然也可以使用一个查询的 DSL
文件进行监控:
$ helm monitor elasticsearch my-release ./elasticsearch-query.json
除了使用 Prometheus 和 Elasticsearch 进行监控触发回滚之外,也可以使用 Sentry
:
$ helm monitor sentry my-app \ --api-key <SENTRY_API_KEY> \ --organization sentry \ --project my-project \ --sentry http://sentry:9000 \ --tag release=2.0.0 \ --regexp 'Error with database connection.*'
Demo
Helm monitor 插件地址: https://github.com/ContainerSolutions/helm-monitor
推荐
最后打个广告,给大家推荐一个本人精心打造的一个精品课程,现在限时优惠中: 从 Docker 到 Kubernetes 进阶
扫描下面的二维码(或微信搜索 k8s技术圈
)关注我们的微信公众帐号,在微信公众帐号中回复 加群 即可加入到我们的 kubernetes 讨论群里面共同学习。
以上所述就是小编给大家介绍的《Helm monitor 插件(附视频)》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- iOS--React Native视频播放器插件
- 手把手教你写 Pornhub 视频下载 Chrome 插件
- GuiLite 3.5 发布:视频,视频,视频
- AVFoundation 视频常用套路: 视频合成与导出,拍视频手电筒,拍照闪光灯
- AVFoundation 视频常用套路: 视频合成与导出,拍视频手电筒,拍照闪光灯
- .NET 处理视频-MediaInfo 获取视频信息
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
从Paxos到Zookeeper
倪超 / 电子工业出版社 / 2015-2-1 / 75.00元
《Paxos到Zookeeper:分布式一致性原理与实践》从分布式一致性的理论出发,向读者简要介绍几种典型的分布式一致性协议,以及解决分布式一致性问题的思路,其中重点讲解了Paxos和ZAB协议。同时,本书深入介绍了分布式一致性问题的工业解决方案——ZooKeeper,并着重向读者展示这一分布式协调框架的使用方法、内部实现及运维技巧,旨在帮助读者全面了解ZooKeeper,并更好地使用和运维Zoo......一起来看看 《从Paxos到Zookeeper》 这本书的介绍吧!