文档章节

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

难易
 难易
发布于 2015/02/02 09:10
字数 876
阅读 545
收藏 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

© 著作权归作者所有

共有 人打赏支持
难易

难易

粉丝 263
博文 44
码字总数 100878
作品 2
杭州
程序员
私信 提问
加载中

评论(1)

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

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

lateron
2014/08/23
7.7K
8
Deis 1.6.1 发布,开源 PaaS 系统

Deis 1.6.1 发布,修复了一些 Bug。 Fixes 修复: client: pin cryptography library at 0.8.2 store: fix shared etcd key defaults router: check if there is certificates to generate c......

oschina
2015/05/15
973
1
Deis 0.1.0 发布,开源 PaaS 系统

开源 PaaS 系统 Deis 0.1.0 发布了,该版本包含一些重要的新特性和一些向后兼容的改动。目前 Deis 已经为你的开发和测试环境做好了准备,在下个月我们希望 Deis 就可以用于生产系统。 Deis 是...

oschina
2013/10/03
1K
0
Deis v1.10.1 发布,开源 PaaS 系统

Deis v1.10.1 发布,此版本修复了组件没有完全停止的问题;改进了数据库启动,避免一些启动问题;调整 deisctl 输出流。 v1.10.0 -> v1.10.1 主要是 bug 修复: deisctl: default stdout an...

oschina
2015/09/22
897
1
Deis v1.5.1 发布,开源 PaaS 系统

Deis v1.5.1 发布,此版本修复了应用构建失败后仍然接收 的问题,还有 Deis routers 启用 时重定向失效的问题。 v1.5.0 -> v1.5.1 修复 builder: exit 1 when gitreceive captures a build r...

oschina
2015/04/13
879
0

没有更多内容

加载失败,请刷新页面

加载更多

Ubuntu16.04下安装docker

[TOC] 本文开发环境为Ubuntu 16.04 LTS 64位系统,通过apt的docker官方源安装最新的Docker CE(Community Edition),即Docker社区版,是开发人员和小型团队的理想选择。 1. 开始安装 1.1 由于...

豫华商
31分钟前
3
0
使用XShell工具密钥认证登录Linux系统

如果你是一名Linux运维,那么Linux服务器的系统安全问题,可能是你要考虑的,而系统登录方式有两种,密码和密钥。哪一种更加安全呢? 无疑是后者! 这里我为大家分享用Xshell利器使用密钥的方...

dragon_tech
43分钟前
1
0
day178-2018-12-15-英语流利阅读-待学习

“真蛛奶茶”了解一下?蜘蛛也会产奶了 Lala 2018-12-15 1.今日导读 “蛋白质含量是牛奶的 4 倍,并有着更低的脂肪和含糖量”,听起来诱人又美味的并不是羊奶或豆奶,而是你可能打死都想不到...

飞鱼说编程
48分钟前
9
0
npm WARN optional SKIPPING OPTIONAL DEPENDENCY: fsevents

场景重现 npm install --verbose 安装依赖的时,出现如下警告 强迫症患者表示不能接受 npm WARN optional SKIPPING OPTIONAL DEPENDENCY: fsevents@1.2.4 (node_modules\fsevents):npm WARN......

taadis
52分钟前
2
0
OSChina 周六乱弹 —— 你一口我一口多咬一口是小狗

Osc乱弹歌单(2018)请戳(这里) 【今日歌曲】 @达尔文 :分享Roy Orbison的单曲《She's a Mystery to Me》 《She's a Mystery to Me》- Roy Orbison 手机党少年们想听歌,请使劲儿戳(这里...

小小编辑
今天
363
6

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部