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

为什么需要PaaS?一句话,现在的应用程序从源代码到运行阶段太复杂,没有标准的,通用的方式。

整个过程及产出如下:

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

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

开发到构建:

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

部署到运行:

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

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

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

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

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

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

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

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

所以,上面这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的方式是通过环境变量。客户端的命令行工具上设置环境变量后,就直接发送给所有容器,重设这些环境变量,然后重启。

原文发布于微信公众号 - 云计算D1net(D1Net02)

原文发表时间:2015-02-09

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏Golang语言社区

NSQ:分布式的实时消息平台--简介

源码下载地址: https://github.com/bitly/nsq NSQ是一个基于Go语言的分布式实时消息平台,它基于MIT开源协议发布,代码托管在Gi...

5376
来自专栏JAVA高级架构

一个分布式服务器集群架构方案

6122
来自专栏大白虾谈架构

Windows10 Oracle ODBC安装配置

1864
来自专栏申龙斌的程序人生

零基础学编程040:在Windows上安装Python库的正确姿势

Python的优势不仅仅在于优雅的语言、简洁的语法,强大的第三方库是其能够用于各个领域的最重要杀手锏之一,如在数据科学领域的numpy、scipy、pandas...

3027
来自专栏程序人生 阅读快乐

自建DNS服务器

不晓得为撒,用网上的一些公共DNS服务的时候,总是莫名其妙的有些网站无法解析,有时候114能解析,阿里DNS不行或者腾讯DNS不行,导致总是来回切换DNS,很是...

1.2K2
来自专栏腾讯移动品质中心TMQ的专栏

常用流量测试方法及一些思考

App性能测试中流量测试是其中重要的一项,网络场景(wifi、非wifi)、用户使用场景(页面加载流量、场景使用流量、待机流量),这些都是需要考虑的测试点。

5345
来自专栏R语言___生物信息

Anaconda安装使用

Anaconda是一个用于科学计算的Python发行版,支持 Linux, Mac, Windows系统,提供了包管理与环境管理的功能,可以很方便地解决多版本p...

6007
来自专栏CSDN技术头条

运用Kubernetes进行分布式负载测试

本文为CSDN原创编译文章,禁止转载。 负载测试是开发后台基础架构的重要一环,它不但能够演示系统在真实需求面前的性能表现,还可以通过模拟用户与设备行为,在应用程...

2246
来自专栏美团技术团队

【美团技术博客】Docker系列之二:基于容器的自动构建

自动构建系统是从美团的自动部署系统发展出来的一个新功能。每当开发人员提交代码到仓库后,系统会自动根据开发人员定制的构建配置,启动新的Docker容器,在其中对源...

40310
来自专栏Golang语言社区

NSQ:分布式的实时消息平台--简介

源码下载地址: https://github.com/bitly/nsq NSQ是一个基于Go语言的分布式实时消息平台,它基于MIT开源协议发布,代码托管在Gi...

4096

扫码关注云+社区

领取腾讯云代金券