如何通过Rancher webhook微服务实现Service/Host的弹性伸缩

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何通过Rancher webhook微服务实现Service/Host的弹性伸缩相关的知识,希望对你有一定的参考价值。

概述


结合大家CICD的应用场景,本篇Blog旨在介绍如何通过Rancher的webhook微服务来实现Service/Host的弹性伸缩。


流程介绍


  • Service Scale

    • 创建example服务对象。

    • 创建service scale webhook对象。

    • 第三方触发webhook,完成service弹性伸缩。

  • Host Sacle

    • 通过阿里云machine driver创建实例对象,打上scale-up标签。

    • 创建host scale webhook对象。

    • 第三方触发webhook,完成host弹性伸缩。


webhook介绍


Rancher webhook的服务流程大致如下:


  1. Webhook Driver(WD)初始化。

  2. Router Handler(RH)初始化。

  3. 接收请求URL和Method,匹配调用RH.Execute或其他方法,RH.Execute解析请求数据得到WD_Id,进而执行WD.Execute,最后返回并response。


技术分享


环境准备


Platform


  • Mac,Windows,Linux,Docker Cloud,AWS,Azure均可部署。


技术分享


  • 本次准备的平台是Ubuntu发行版(14.04),为了兼容docker,选择linux发行版的时候内核需控制在3.10以上。


Docker


  • 根据用户选择的平台安装docker引擎,安装指导可参考https://docs.docker.com官方文档,搭配Rancher使用,docker引擎版本最优选择1.12.6或者1.13.1。

  • 本次准备的docker引擎版本是1.12.6。


Rancher


技术分享


实践步骤


Service Scale


创建example service

curl -u "xx:xx" -X POST -H ‘Accept: application/json‘ -H ‘Content-Type: application/json‘ -d ‘{
"description": "example service for scaling",
"name": "webapp",
"system": false,
"dockerCompose": "version: ‘2‘\nservices:\n  NGX:\n    image: nginx:alpine\n    stdin_open: true\n    tty: true\n    cpuset: \"0\"\n    ports:\n    - 8787:80/tcp\n    cpu_shares: 1024\n    labels:\n      io.rancher.container.pull_image: always\n      servicename: nginx",
"rancherCompose": "version: ‘2‘\nservices:\n  NGX:\n    scale: 1\n    start_on_create: true",
"binding": null,
"startOnCreate": true
}‘ ‘http://a.b.c.d:8080/v2-beta/projects/1a5/stacks‘


技术分享


创建webhook


技术分享


Trigger webhook


技术分享

技术分享

技术分享


Host Scale


创建example host


技术分享

技术分享


创建webhook


图11


Trigger webhook


技术分享

技术分享

技术分享


原文来源:Rancher Labs

本文出自 “12452495” 博客,请务必保留此出处http://12462495.blog.51cto.com/12452495/1971363

以上是关于如何通过Rancher webhook微服务实现Service/Host的弹性伸缩的主要内容,如果未能解决你的问题,请参考以下文章

docker微服务部署之:Rancher管理部署微服务

docker微服务部署之:七Rancher进行微服务扩容和缩容

爱油科技基于Docker和Spring Cloud的微服务实践

微服务实践:从单体式架构迁移到微服务架构

如何使用 Spring 为我的微服务实现安全性? [关闭]

如何跨单个项目的不同 Spring Boot 微服务实现 JPA 审计?