DINP 正在参加 2020 年度 OSC 中国开源项目评选,请投票支持!
DINP 在 2020 年度 OSC 中国开源项目评选 中已获得 {{ projectVoteCount }} 票,请投票支持!
投票让它出道
已投票
DINP 获得 2020 年度 OSC 中国开源项目评选「最佳人气项目」 !
DINP 获得 2020 年度 OSC 中国开源项目评选「最佳人气项目」「最积极运营项目」 !
DINP 获得 2020 年度 OSC 中国开源项目评选「最积极运营项目」 !

软件简介

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的架构

 

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

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

展开阅读全文

代码

的 Gitee 指数为
超过 的项目

评论 (12)

加载中
写了一篇非常详细的搭建过程图。https://github.com/chinesejie/gogogo
2017/07/12 11:10
回复
举报
这个不错 DINP
2015/02/09 20:37
回复
举报
架构最简单的 PaaS 平台 DINP 发布,来自小米 DINP
2015/02/09 21:24
回复
举报
不错的项目,顶一个,Dashboard 部分用 JFinal 开发的,有需要的朋友可以参考一下 DINP
2015/02/09 21:38
回复
举报
试试看 DINP
2015/02/10 07:12
回复
举报
夜莺监控软件作者
2015/03/29 10:50
回复
举报
打算深入DINP DINP
2015/04/04 08:46
回复
举报
这个paas的设计理念适合我的想法,不要接管mysql这些东西,可以在阿里云上搭建吗? #DINP#
2015/04/13 08:51
回复
举报
这个安装好简单,可以参考一下。https://csphere.cn/docs/1-installation.html #DINP#
2015/04/17 16:24
回复
举报
看起来不错,就是要再装一个UIC太蛋疼 #DINP#
2015/06/11 10:39
回复
举报
更多评论
暂无内容
发表了博客
2015/02/16 07:28

OSChina 技术周刊第二十二期 —— DUBBO 配置规则详解

每周技术抢先看,总有你想要的! 移动开发 【翻译】为你的 Android 应用增加本地搜索功能 前端开发 【软件】AngularJS 的剪贴板扩展 ngClip 【软件】国际化和本地化 JavaScript 库 Globalize 【资讯】为网站开发准备的 30 个惊艳的 jQuery 插件 服务端开发/管理 【翻译】一年之后重新审视 Docker —— 根本性缺陷和炒作 【翻译】单线程 1KB 的 Redis 写操作有 84% 都是耗费在内核上 【翻译】使用 HAProxy 基于 HTTP 头实现的速率...

0
5
发表于云计算专区
2020/01/06 19:03

【有福利】滴滴云技术沙龙免费报名开始啦!(北京区)

滴滴云技术沙龙,由滴滴和其他知名互联网公司的专家以独立演讲、Q&A、开放讨论等方式,每期围绕一个主题,与领域内的中高端技术人员进行自由、深度的交流和学习。 中国及全球云计算市场仍处于快速发展期。基于滴滴出行丰富的业务技术和经验积累,在实战中打磨出来的滴滴云已经在为行业用户、中小企业和开发者提供可靠的云计算服务。通过创新的架构、不断的技术迭代演进,以及稳定的产品性能、可靠的服务品质、极具竞争力的价格优...

0
0
发表于云计算专区
2016/07/18 15:04

小米开源监控系统OpenFalcon应对高并发7种手段

小米开源监控系统OpenFalcon应对高并发7种手段 原创 2016-04-01 秦晓辉 高可用架构 编者按:本文是秦晓辉在 3 月 27 日数人云“百万并发”活动的演讲,授权「高可用架构」首发。转载请注明来自高可用架构公众号「ArchNotes」。 秦晓辉,小米运维研发技术负责人,互联网公司监控解决方案 OpenFalcon 主程,国内第一套开源 PaaS 平台 DINP 主程,企业级业务监控 Minos 作者,Gopher,现负责小米运维平台的搭建。关注运维自动化、P...

0
6
没有更多内容
加载失败,请刷新页面
点击加载更多
加载中
下一页
发表了问答
2015/08/06 11:14

关于dinp的部署问题

@UlricQin 你好,我在搭建dinp时碰见个问题 麻烦咨询一下您. 由于参考的是这个帖:http://leo108.com/pid-2109.asp #DINP# 里面的步骤应该也差不太多. 但是由于在内网测试,上述流程始终使用的本机的内网ip. 在最后部署时发现router会将dns分配的域名重定向到一个外网ip上.所以我想问下怎么通过dinp-router查看部署应用分配的路由信息阿? 我访问8082时会提示用户名和密码,从git上查到后登录进去是404阿,还是说这个router的路由表信...

4
0
发表了问答
2016/02/01 14:39

​请问您的builder工程现在还能正常编译吗?

@UlricQin 你好,想跟你请教个问题: 我在尝试使用您开发的dinp,在进行到builder这个工程时,无法完成编译. 首先是 root@42517b72251a:/go/src/github.com/dinp/builder# go get ./... # github.com/dinp/builder/g g/g.go:133: undefined: orm.DR_MySQL 我把这句注释掉后又会报一个 root@42517b72251a:/go/src/github.com/dinp/builder# go get ./... # github.com/dinp/builder/models models/user.go:49: cannot use int64(360...

2
0
发表了问答
2015/06/03 17:42

build问题-go import cycle not allowed

@UlricQin 你好,想跟你请教个问题: [root@saint4 builder]# go get ./... package github.com/dinp/builder imports runtime: C source files not allowed when not using cgo: atomic_amd64x.c defs.c float.c heapdump.c lfstack.c malloc.c mcache.c mcentral.c mem_linux.c mfixalloc.c mgc0.c mheap.c msize.c os_linux.c panic.c parfor.c proc.c runtime.c signal.c signal_amd64x.c signal_unix.c stack.c string.c s...

3
0
发表了问答
2015/03/30 13:41

DINP ​配置文档

@UlricQin 你好 请问 有DINP 配置文档吗?

2
1
发表了问答
2015/02/27 14:25

关于pull image的问题

@UlricQin 你好,想跟你请教个问题:server在pull image时报错,如下: 2015/02/27 14:21:32 compare.go:252: create container. app:app, ip:10.1.1.250 2015/02/27 14:21:32 compare.go:299: [ERROR] pull image 127.0.0.1:5000/dsds/n24:0.1 fail: API error (500): Invalid Registry endpoint: Get http://127.0.0.1:5000/v1/_ping: dial tcp 127.0.0.1:5000: connection refused $ curl http://127.0.0.1:5000/v1/_ping的结...

2
0
没有更多内容
加载失败,请刷新页面
点击加载更多
加载中
下一页
12 评论
336 收藏
分享
OSCHINA
登录后可查看更多优质内容
返回顶部
顶部