概述
结合大家CICD的应用场景,本篇Blog旨在介绍如何通过Rancher的webhook微服务来实现Service/Host的弹性伸缩。
流程介绍
webhook介绍
Rancher webhook的服务流程大致如下:
-
Webhook Driver(WD)初始化。
-
Router Handler(RH)初始化。
-
接收请求URL和Method,匹配调用RH.Execute或其他方法,RH.Execute解析请求数据得到WD_Id,进而执行WD.Execute,最后返回并response。
![图片1.png wKioL1ndd16jVI9EAACIqVM_u9U844.png]()
环境准备
Platform
![图片2.png wKioL1ndd36w0-7xAAHmAIsmKp8867.png]()
Docker
Rancher
![图片3.png wKioL1ndd5mCxmB5AAEqla1xTJw710.png]()
实践步骤
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'
![图片4.png wKioL1ndd7zBZgDqAADEe3AIHdY194.png]()
创建webhook
![图片5.png wKiom1nd5tuhsio2AAEDL9OwhJQ891.png]()
Trigger webhook
![图片6.png wKioL1ndd-jBP2dCAADACu7qgpo392.png]()
![图片7.png wKiom1nd5vexSQEoAAK3jFvSdSI086.png]()
![图片8.png wKioL1ndd-rAdChCAAC9jJVNgmQ657.png]()
Host Scale
创建example host
![图片9.png wKioL1ndeAXy4efdAAKNp3wa8pE775.png]()
![图片10.png wKiom1nd5xTQpijqAADlLM3HWWU890.png]()
创建webhook
图11
Trigger webhook
![图片12.png wKiom1nd5yzBuT49AAEp4fuo764247.png]()
![图片13.png wKioL1ndeB_BjvXCAAK2-EUgNiY833.png]()
![图片14.png wKiom1nd5y6xoG7RAAFNhgc_hjM727.png]()
原文来源:Rancher Labs
本文转自 RancherLabs 51CTO博客,原文链接:http://blog.51cto.com/12462495/1971363