基于Docker开发的PaaS平台 DINP

转载 2016年11月02日 21:52:27

DINP是又一个基于Docker开发的PaaS平台。

DINP 包含如下组件:

  • dinp-server master组件,控制集群中所有计算节点

  • dinp-agent Agent,部署在所有计算节点,收集各个节点运行状态和container列表

  • dinp-builder 编配平台,负责把用户代码打包为Docker image

  • dinp-dash Dashboard,用户操作的入口

  • dinp-router 负责请求的路由等功能

  • dinp-hm Health Monitor,对APP的rs进行7层健康检查

  • dinp-common 公共函数、数据结构

之所以用了“又”字,是因为现在的PaaS平台着实很多,DINP只不过是又造了个轮子,下面给大家说说这个轮子与其他轮子的不同点。

1. DINP只接管web应用

PaaS 平台是个规范性很强的平台,app要用PaaS托管,必须要满足1、2、3...n条规范才可以。web应用通常无状态,逻辑简单,部署方式统一故而可以 使用PaaS托管。但对于一些分布式大型软件、复杂的rpc服务,部署架构复杂,并不适合用PaaS托管。有所为有所不为,DINP只接管web应用。

2. DINP不接管代码的编译环节

像 tsuru之类的PaaS,从代码的push就开始接管了。他们通常要求用户把代码push到指定repo的指定分支,以此触发git receiver,git receiver与后端其他组件协同,拉取用户最新代码,下载dependency,编译,打包等等。但是在国内,因为一些原因,下载 dependency是一个很费劲的过程。如果这个动作放到平台来做,用户每次要上线了都要等待一个漫长的过程是不可接受的。

所以,DINP不接管代码的编译环节,需要用户自己通过科学上网的方式搞定。比如Java,用户把最终的war包扔给DINP即可,而不能是扔一 堆.java源文件和pom.xml;比如Golang,用户把编译好的二进制扔给DINP即可,而不能扔一堆.go源文件;比如Python,用户最好 提前下载好相关lib库,然后加入环境变量,而不是提供一个pip_requirements.txt,当然,对于一些特别容易安装的lib库,用户提供 一个pip_requirements.txt也未尝不可,DINP也支持,但是不推荐。

3. DINP够简单

如果你对 Docker比较熟悉,那DINP对你来说会很简单,我们并没有做太多事情,你理解起来也会相对轻松。PaaS中需要一个通用打包规范,我们使用了 Dockerfile;PaaS中需要一个SCM存放发布包,我们使用了Docker Registry;PaaS中需要一个container来run app,我们使用了Docker。另外PaaS中需要一个七层router,我们使用了CloudFoundry提供的gorouter。DINP的绝大 部分组件都是Golang写的,静态编译的语言部署起来超方便。Dashboard和UIC是用Java写的,基于JFinal框架,很简单的,相信我。

4. DINP的架构

  • 用户把代码打包为.tar.gz,交给Builder打包为一个Docker image
  • 拿到Builder产出的Docker image去Dashboard创建一个App,设置好实例数、内存大小、image地址,O了。Dashboard把用户填写的这些信息写入MySQL
  • Server定期从MySQL同步用户期望的数据,姑且称之为desired state
  • 部署在所有计算节点的Agent与Server之间有心跳通信,收集本机的剩余内存量和container列表,姑且称之为real state
  • Server对比desired state和real state,发现某个App的实例数少了就去调度新的计算节点创建新实例,如果发现某个App实例数多了,就干掉多余的实例
  • Server同时会分析real state,组织出路由信息写入redis
  • Router定期从redis中获取路由信息
  • Router通常部署多个,前面部署LVS,注册一个域名,比如apps.io,把*.apps.io这个泛域名解析到LVS VIP,整个流程就通了

5. 服务接入

如 果你玩过CloudFoundry,会很敏感的发现,DINP没有接管MySQL、Memcache、Redis、MQ等等服务。为什么呢?我们的想法是 这样的:专业的人做专业的事,在公司里,MySQL、Redis之类的服务已经有DBA团队运维管理了很久了。他们是最懂的人,他们已经形成了一整套成熟 的部署规范,运维流程。只要提供一个连接地址,一个账号让PaaS上的App连上去就行了,何必非要把MySQL与DINP做很强的关联整合呢

补充

DINP在公司内部小规模用了几个月,没有出什么问题,大家可以玩一玩了。

基于Docker及Kubernetes技术构建容器云(PaaS)平台概述

本文个人博客地址为:http://www.huweihuang.com/article/kubernetes/paas-based-on-docker&kubernetes/本文个人博...
  • huwh_
  • huwh_
  • 2017-07-23 17:39:38
  • 4529

Docker 与 PAAS

docker 与 PAAS平台
  • raindaywhu
  • raindaywhu
  • 2016-07-28 17:14:39
  • 3574

Flynn初探:基于Docker的PaaS平台

[Flynn](https://flynn.io/)是一个开源的PaaS平台,可自动构建部署任何应用到Docker容器集群上运行,其功能特性与组件设计大量参考了传统的PaaS平台[Heroku](ht...
  • TragicJun
  • TragicJun
  • 2014-11-19 01:04:01
  • 8799

Docker解析及轻量级PaaS平台演练(一)--Docker简介与安装

Container技术:传统的虚拟化技术: 通过对硬件层模拟,从而实现了能够在一套硬件上面运行多个操作系统,因为通过硬件虚拟化,使得操作系统认为在它之下就是硬件层但是实际情况是这样的:虚拟机中的OS...
  • qq1010885678
  • qq1010885678
  • 2015-05-31 19:37:13
  • 3057

收录几个开源的PaaS平台

收录了几个将来可能用得着的PaaS平台,以备将来所用。 1.Flynn  Flynn 是一个开源的PaaS系统,采用Go语言编写, 使用完全组件化模块化的设计,任何一个组件和模块都可以独立的进行替换...
  • u011439718
  • u011439718
  • 2013-07-18 13:54:55
  • 3161

Docker视频教程下载

  • 2017年02月28日 13:48
  • 2KB
  • 下载

docker构建微服务学习视频

  • 2018年03月11日 13:54
  • 98B
  • 下载

Docker实战视频教程下载|Docker视频教程

  • 2017年02月23日 15:01
  • 2KB
  • 下载

Docker构建企业PAAS平台之-Docker入门与企业实践【入门实战篇】

-
  • 2017年01月20日 18:35

沙龙分享 基于Docker的PaaS平台建设实践

本处只作导览,更加完整与详细请参看原创:https://www.a-site.cn/article/499312.html感谢作者分享。================================...
  • ice1224
  • ice1224
  • 2018-02-28 20:15:25
  • 34
收藏助手
不良信息举报
您举报文章:基于Docker开发的PaaS平台 DINP
举报原因:
原因补充:

(最多只允许输入30个字)