文档章节

为什么需要PaaS?对Deis,Heroku,Flynn的一些观察

难易
 难易
发布于 2015/02/02 09:10
字数 876
阅读 1.3K
收藏 5

一句话,现在的应用程序从源代码到运行阶段太复杂,没有标准的,通用的方式。 整个过程及产出如下:

  1. 开发阶段:源代码
  2. 构建阶段:发布包/可执行程序
  3. 部署阶段:可运行的镜像(发布包+配置)
  4. 运行阶段:进程、集群、日志、监控信息、网络

不论是Deis,Heroku,Flynn或者其他PaaS的目标,都是为了让2-4这3个阶段尽可能的简单。看了他们所设计的产品,简单到了什么程度?通过一个客户端命令行工具,实现了:

开发到构建:

用户通过git提交源代码,由PaaS自动构建镜像,并提供版本的管理——用户可以创建新版本(提交新代码或修改部署配置)、回滚老版本等。

部署到运行:

自动选择运行机器,为每个进程副本部署启动单独的容器,解决请求路由和负载均衡,并提供进程的管理——用户可以做扩缩容、查看日志、监控状态等、回滚历史的发布

#为什么是这些功能?为什么这些功能不能分别由各种工具实现?

在我看来,代码从发布到运行由两根轴组成。

##纵轴: 源代码——发布包——可运行的镜像——进程

这里的关系是一步接一步,顺序往下,不论你用什么工具什么平台,这4步都是流水式的向下。

##横轴: 负载均衡、集群部署扩容缩容、健康检查、日志

线上的应用,有以下几种情况

  1. 发布新功能:全量更新和部署
  2. 性能压力:通过健康检查或手工触发,进行扩容和缩容
  3. 保证业务连续性:在上面的更新中,通过负载均衡,把新请求导入到更新后的容器上,等待旧的处理完后进行更新

所以,上面这4项是一环扣一环,横向的互相关联,如果不在一个工具内同时提供这4项功能,就需要人工去填平这里面的信息交互,手动的整合这4个工具,从而带来复杂性。

#约束及实现

##纵向编译:buildpack

buildpack填平的是从源代码到发布包的坑,就是一组编译脚本。

PaaS平台自己提供一些编译脚本,但也允许用户按照规范自己写编译脚本。

(脚本需要自己下载合适版本的编译器!)

如果使用Docker,用户提供的就是一个DockerFile或者Dockerimage地址,拿了直接就能跑起来的东西。

##纵向运行:Procfile

buildpack让PaaS知道怎么编译程序,Procfile让PaaS知道怎么运行程序。

一个典型的Procfile就是像这样

 cat ./Procfile
 web: bundle exec rails server -p $PORT

后面可以通过命令行来动态扩容程序

 deis ps:scale web=4

##纵向配置:环境变量 运行的发布包在不同的环境下有不一样的配置,Deis的方式是通过环境变量。客户端的命令行工具上设置环境变量后,就直接发送给所有容器,重设这些环境变量,然后重启。

##横向负载均衡:nginx ##横向日志:集中化的syslog获得日志 ##横向部署:go写的小程序,用于部署Docker的Container

© 著作权归作者所有

难易

难易

粉丝 281
博文 45
码字总数 103644
作品 2
杭州
程序员
私信 提问
加载中

评论(1)

兵戈天下
兵戈天下
简单纠个错:“横向负载均衡:ngix”此应为nginx
十大基于 Docker 的开发工具

随着Docker的发展,Docker的生态圈也越来越成熟,GitHub上出现了很多与Docker相关的开源项目。CenturyLink在其博客上总结了基于Docker的10个开发工具,主要集中在PaaS平台、集群管理、持续集...

lateron
2014/08/23
8.1K
8
Deis v1.13.3 发布,开源 PaaS 系统

Deis v1.13.3 发布了,主要更新如下。 Features: contrib: Add script to restart all apps. client: Sort listings router: Add server_tokens option Fixes: logspout: Ignore events wit......

局长
2016/08/23
837
1
PaaS 系统 DEIS 分支 - DRYCC

DRYCC是受欢迎的PaaS服务DEIS的一个社区分支。 自从微软收购了DEIS团队,它已经停止更新,所以我们决定努力建立一个全新的开放的开发者社区,我们邀请所有人加入我们,帮助建立下一代PaaS云服...

匿名
2019/05/16
590
0
Deis v1.13.4 发布,开源 PaaS 系统

开源 PaaS 系统 Deis v1.13.4 发布了。该版本是 v1 系列的最终维护版。 注意,对 Deis v1 LTS 的支持将于 2017 年 2 月 13 日结束。请参阅 Deis Workflow 以获取下一代 PaaS。主要更新如下:...

局长
2017/01/20
1.1K
0
DRYCC Workflow v1.3.0 版本发布

DRYCC是受欢迎的PaaS服务DEIS的一个社区分支。 自从微软收购了DEIS团队,它已经停止更新,所以我们决定努力建立一个全新的开放的开发者社区,我们邀请所有人加入我们,帮助建立下一代PaaS云服...

段洪义
2019/07/02
966
0

没有更多内容

加载失败,请刷新页面

加载更多

直接显示StackOverflow的答题日期, 增加评论区回复的时间显示 ,修改时间显示到小时分。

// ==UserScript==// @name 直接显示StackOverflow的答题日期, 增加评论区回复的时间显示 ,修改时间显示到小时分。// @namespace http://tampermonkey.net/// @version ...

FalconChen
今天
36
0
Shader笔记_005 纹理

纹理最初的目的就是使用一张图片来控制模型的外观,通过纹理映射技术 我们可以把一张图粘贴在物体表面,逐纹素的控制模型的颜色。 通常美术建模的时候也会在软件里利用纹理展开技术把纹理展开成...

STONE-CITY
今天
12
0
iOS MVVM 与RAC结合使用

MVVM配合 RAC 更能发挥的淋漓尽致。 我们把 MVVM 第一篇的例子 KVO 的事件 替换成 配合RAC 框架使用, OC的话直接导入 : pod 'ReactiveObjC' Swift 直接用 RXSwift就可以。 把 ViewModel里加...

T型人才追梦者
今天
22
1
OSChina 周一乱弹 —— 影响心情的三座大山

Osc乱弹歌单(2020)请戳(这里) 【今日歌曲】 @薛定谔的兄弟 :分享洛神有语创建的歌单「我喜欢的音乐」: 《浮生(inst.)》- 忘乡 / 墨凡悦 手机党少年们想听歌,请使劲儿戳(这里) @凝小紫...

小小编辑
今天
57
0
Unity中头发渲染

头发与普通PBR 材质最大的区别是 头发是各项异性的高光, 参考实现主要为下面文章 http://web.engr.oregonstate.edu/~mjb/cs519/Projects/Papers/HairRendering.pdf 头发包含 2个高光,以及高...

liyong2
今天
20
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部