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

1元 10元 50元





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



  要资料 文章 文库 Lib 视频 Code iProcess 课程 认证 咨询 工具 火云堂 讲座吧   成长之路  
会员   
 
   
 
  
每天15篇文章
不仅获得谋生技能
更可以追随信仰
 
     
   
 订阅
  捐助
如何通过Rancher webhook微服务实现Service/Host的弹性伸缩
 
来源:segmentfault.com 发布于: 2017-10-25
868 次浏览     评价:      
 

概述

结合大家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的服务流程大致如下:

Webhook Driver(WD)初始化。

Router Handler(RH)初始化。

接收请求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

Trigger webhook

   
 订阅
  捐助
相关文章

阻碍使用企业架构的原因及克服方法
世界级企业架构的行业挑战
企业架构和SOA架构的角色将融合
什么最适合您的组织?
相关文档

企业架构与ITIL
企业架构框架
Zachman企业架构框架简介
企业架构让SOA落地
相关课程

企业架构设计
软件架构案例分析和最佳实践
嵌入式软件架构设计—高级实践
企业级SOA架构实践
每天2个文档/视频
扫描微信二维码订阅
订阅技术月刊
获得每月300个技术资源
 
 

关于我们 | 联系我们 | 京ICP备10020922号 京公海网安备110108001071号