Flynn它是一个开源PaaS台,无论要部署的应用程序,你可以建立自己的主动性Docker容器集群的实现,能特性与组件设计大量參考了传统的PaaS平台Heroku。本文旨在从使用动机、基本对象、层次架构、功能组件、基本工作流这几个方面对Flynn做整体的介绍。

为什么须要Flynn

为了便于理解Flynn的作用与功能,让我们先来看看应用程序从开发到构建再到部署再到执行分别须要经历的几个实体状态:

更详细一点。以一个Java程序为例来描写叙述:

  • 源码:包含*.java、log4j.properties、pom.xml等文件。

  • 公布包:源码被编译打包后生成一个JAR包,这个就是公布包。

  • 部署配置:比方每一个进程的启动命令、环境变量、系统属性等。

    通常。这些配置会写在一个启动脚本里面。

  • 进程:执行Java程序的实体。一个Java程序能够起多个进程,每一个进程启动不同的主类(实现了main()方法的类,一个JAR包能够包括多个主类)。

引入Docker后,公布包变成封装了JAR包与JDK环境的镜像,进程变成在相互隔离的容器里执行。可是,从源码到镜像、从镜像到执行容器这两步转换过程须要用户人工的操作。

尤其是后者的转换,涉及到集群资源调度、自己主动部署、配置管理、容器管控等一系列的复杂流程。

更进一步。在执行阶段还涉及扩缩容、日志查看、错误处理、执行监控等运维需求,假设所有人工操作将耗费巨大的工作量。

这时候类似Flynn这种PaaS出场了,基于Docker之上进一步封装了整个构建、部署、执行工作流,使得用户仅仅需简单地提交代码就可以完毕开发到执行的高速转换:

  • 开发到构建:用户通过git提交源码,由Flynn自己主动构建镜像,并提供版本号的管理——用户能够创建新版本号(提交新代码或改动部署配置)、回滚老版本号等。

  • 部署到执行:Flynn自己主动选择执行机器,为每一个进程副本部署启动单独的容器,并提供进程的管理——用户能够做扩缩容、查看日志、监控状态等。

Flynn的基本对象

以下我们来看看公布包、部署配置、进程这三个实体在Flynn中是怎样抽象的。例如以下图所看到的是其基本对象的关系描写叙述:

  • App:表示一个应用,全部其它对象都是环绕App而展开。

  • Artifact:表示应用的公布包,实际上相应一个Docker镜像。

  • Process:表示应用的进程。通过一个镜像能够启动多个不同的进程,每一个进程执行在自己单独的容器里。

  • Release:是应用公布态的抽象表示。

    它在Artifact的基础上添加了一些不可变(immutable)的静态配置,比方每一个进程的启动命令行、环境变量、绑定port、等。要改动这些配置,须要生成一个新Release。

    Release这样的不可变性是为了方便做Rollback。即应用随时能够回退到之前的Release。

  • Formation: 是应用执行态的抽象表示。它在Release的基础上添加了可变(mutable)的动态配置。即每一个进程的副本(replica)个数。

  • Job: 是进程副本的抽象表示,每一个Job相应一个执行容器。因此,在后文中能够看到。Job是资源调度的基本单元。

Flynn的层次架构

例如以下图所看到的。Flynn的架构自下而上分为两个层级——Layer 0和Layer 1。简单地理解,能够觉得Layer 1负责接受用户请求,封装成应用的执行指令。再由Layer 0解决在哪里执行以什么方式执行的问题。详细一点讲,Layer 0面向的对象是Formation,负责将底层的集群资源封装成可执行Formation的一台主机;Layer 1面向的对象是App。负责将App从源码构建成Artifact。进而封装成Formation提交给Layer
0去运行。

这样的分工明白的层次划分,使整个系统很灵活。相互松耦合。便于随意组件的替换(比方。甚至能够把Layer 0替换成不用容器去运行Formation)。

Flynn的功能组件

以下总结一下组成两个层级的各个组件及其功能(全部组件自身都能够执行在容器里):

Layer 0

  • Scheduler: 资源调度器,定期从Layer 1获取Formation的更新。再依据每一个Formation的部署配置生成一个个的Job,最后从集群中选择合适的机器去执行这些Job。

  • Host Service: 执行在集群每台机器上的agent,负责管控执行在本机的容器,并收集执行状态信息。

  • Host Leader:一个特殊的Host Service,做为"cluster leader",负责维护整个集群的状态信息(比方有哪些机器、每台机器上执行的Job等)。并提供给Scheduler用于资源调度。

  • Discoverd:基于etcd的服务发现模块,提供容器间的发现机制。实际上。Flynn自身的组件间通讯也是通过Discoverd来相互发现的。

Layer 1

  • CLI:提供给用户使用的命令行工具。

  • Controller:为Flynn系统的入口,封装了核心对象(比方app/artifact/release/job)的增删改查操作,以RESTFul接口方式提供给外部客户和内部组件调用。

    它维护的REST对象将持久化到postgre数据库。

    Layer 0的Scheduler就是通过Controller的接口来获取Formation更新的。

  • GitReceiver:接受用户git push源码的SSHserver。接受到git push后将触发Receiver。

  • Receiver:基于buildpack机制。利用SlugBuilder从源码包构建slug包。

    buildpack和slug都是从Heroku借鉴过来的概念。简单地理解。buildpack是一组用于构建源码的脚本,buildpack能够多种多样,每一个buildpack可构建某种类型的源码,这样的类型能够是不同的语言(比方Java、PHP)、不同的构建方式(比方maven、gradle);而slug则是buildpack构建生成的部署包。包括了编译输出文件、依赖库文件等执行环境。

  • BlobStore: HTTP文件server,用于上传/下载slug包。

  • SlugBuilder:接受源码包,基于某种buildpack构建生成slug包。选择哪一种buildpack能够显式地指定,也能够由SlugBuilder依据源文件自己主动匹配。

  • SlugRunner:执行slug包,会从BlobStore下载应用的slug包。

Flynn的工作流

以下通过一个样例来展示Flynn各个组件的工作流。使用Flynn来构建部署应用最主要的流程是以下三步:



用户创建app

flynn create myapp



用户提交app代码

git push flynn master



用户扩容app的进程

flynn scale web=2

对照Kubernetes

Kubernetes是Google开源的Docker容器集群管理系统,为容器化的应用提供资源调度、部署执行、服务发现、扩容缩容等整一套功能,更具体地介绍请參考作者的还有一篇文章《Kubernetes初探:原理及实践应用》

在应用的抽象上,Flynn与Kubernetes有本质的差别:Flynn的应用管理单元是App,仅仅相应一个Docker镜像,但能够由这个镜像来启动多个进程,而且每一个进程能够单独扩缩容;而Kubernetes的应用管理单元是Pod,可相应多个不同的Docker镜像,而且Pod内的各个容器保证会执行在同样的机器上,整个Pod作为扩缩容的基本单位。

另外一个根本的差别是Kubernetes不提供镜像构建与版本号管理的功能。因此,Kubernetes仅仅能看成是面向容器而不是面向应用的系统。

当然,我们能够在Kubernetes之上扩充这些功能。

对照Deis

与Flynn类似,Deis也是受到Heroku的启示,基于Docker之上构建的PaaS平台。因此,从功能特性到应用抽象,两者是大同小异。

至于两者的差异,了解不是非常多,这里提三点:第一,Deis是用Python开发的,而Flynn是Go;第二。Deis依赖于CoreOS。而Flynn由于全部组件都可执行在容器里,没有OS的依赖;第三。Deis在构建阶段,除了buildpack方式构建外。还支持Dockerfile直接以两种方式镜像上传。较Flynn更灵活。

版权声明:本文博主原创文章,博客,未经同意不得转载。

Flynn初步:基于Docker的PaaS台的更多相关文章

  1. 026.[转] 基于Docker及Kubernetes技术构建容器云平台 (PaaS)

    [编者的话] 目前很多的容器云平台通过Docker及Kubernetes等技术提供应用运行平台,从而实现运维自动化,快速部署应用.弹性伸缩和动态调整应用环境资源,提高研发运营效率. 本文简要介绍了与容 ...

  2. 基于Docker&Kubernetes构建PaaS平台基础知识梳理

    点击上方"开源Linux",选择"设为星标" 回复"学习"获取独家整理的学习资料! 基于Docker&Kubernetes构建Paa ...

  3. 一台虚拟机,基于docker搭建大数据HDP集群

    前言 好多人问我,这种基于大数据平台的xxxx的毕业设计要怎么做.这个可以参考之前写得关于我大数据毕业设计的文章.这篇文章是将对之前的毕设进行优化. 个人觉得可以分为两个部分.第一个部分就是基础的平台 ...

  4. 基于 Docker 的微服务架构实践

    本文来自作者 未闻 在 GitChat 分享的{基于 Docker 的微服务架构实践} 前言 基于 Docker 的容器技术是在2015年的时候开始接触的,两年多的时间,作为一名 Docker 的 D ...

  5. 十大基于Docker的开发工具

    http://www.infoq.com/cn/news/2014/08/top-10-open-source-docker FlynnFlynn是一个使用Go语言编写的开源PaaS平台,Flynn使 ...

  6. 前端程序员初步认识 docker

    初步认识 docker 为什么要学习 docker 有同学说他开发工作中有两大神器,一个是 vim 编辑器,另一个就是 Docker. 什么是 docker Docker 是一个开源的应用容器引擎. ...

  7. 容器化 — 基于Docker技术容器云

    导读:本文介绍了基于Docker技术的企业级应用容器平台,从云的定义.云服务分类,到用友云PaaS基础平台.平台总体架构.架构预览.部署架构.平台核心价值和核心竞争力,阐述PaaS基础平台成为广大传统 ...

  8. 基于Docker一键部署大规模Hadoop集群及设计思路

    一.背景: 随着互联网的发展.互联网用户的增加,互联网中的数据也急剧膨胀.每天产生的数据量数以万计,本地文件系统和单机CPU已无法满足存储和计算要求.Hadoop分布式文件系统(HDFS)是海量数据存 ...

  9. docker是PaaS,与openstack是IaaS的关系

    个人理解Docker的每一个虚机其实是宿主操作系统中的一个进程.主要是一种虚拟化技术.OpenStack主要解决的是基础架构云的云服务问题.OpenStack是在虚拟化技术之上的一层,主要解决系统部署 ...

随机推荐

  1. Nginx使用ngx_zeromq模块返回502错误的解决方法

    /*********************************************************************  * Author  : Samson  * Date   ...

  2. mindmanager2012打开文件出现runtime error r6025 解决方式

    关于mindmanager 2012启动无法执行,提示c++错误 ---------------------------Microsoft Visual C++ Runtime Library---- ...

  3. Android它Service

    服务是一段代码的后台执行. 无法处理,也不是螺纹,但它是在进程和线程的执行. Android该服务与Activity不同,不能与用户交互,无法启动自己. 媒体播放服务.当用户退出媒体选择用户界面,不过 ...

  4. php判断页面是电脑登录还是手机登录

    首先说最根本的解决方法: 手机访问时,会附带发送user-agent信息,这个信息里面会有手机号码信息,那么如果能取得手机号码,则可以肯定是通过手机wap访问的.但是目前 中国移动已经屏蔽了user- ...

  5. Java Executor 框架

    Java Executor 框架 Executor框架是指java5中引入的一系列并发库中与executor相关的功能类,包括Executor.Executors. ExecutorService.C ...

  6. EJB体系结构

    为了适应企业的快速发展.缩短企业信息系统的设计和开发周期.降低构建信息系统的成本,Sun公司制订了Java2 SDK Enterprise Edition(J2EE)规范,定义基于组件的方式设计.开发 ...

  7. 并查集专辑 (poj1182食物链,hdu3038, poj1733, poj1984, zoj3261)

    并查集专题训练地址,注册登录了才能看到题目 并查集是一个树形的数据结构,  可以用来处理集合的问题, 也可以用来维护动态连通性,或者元素之间关系的传递(关系必须具有传递性才能有并查集来维护,因为并查集 ...

  8. Windows Phone开发(23):启动器与选择器之CameraCaptureTask和PhotoChooserTask

    原文:Windows Phone开发(23):启动器与选择器之CameraCaptureTask和PhotoChooserTask 这两个组件都属于选择器,而且它们也有很多相似的地方,最明显的上一点, ...

  9. C# Windows Phone 8 WP8 , 文字超连结到网页 免打程式码,Xaml就搞定 ! !

    原文:C# Windows Phone 8 WP8 , 文字超连结到网页 免打程式码,Xaml就搞定 ! ! 一般我们在开发Windows Phone 8 APP ,有时会需要超连结连到其他的网页,但 ...

  10. POJ 2417 Discrete Logging 离散对数

    链接:http://poj.org/problem?id=2417 题意: 思路:求离散对数,Baby Step Giant Step算法基本应用. 下面转载自:AekdyCoin [普通Baby S ...