基于Docker开发的PaaS平台 DINP
之所以用了“又”字,是因为现在的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在公司内部小规模用了几个月,没有出什么问题,大家可以玩一玩了。
原文发布时间:2015-02-10
本文来自云栖合作伙伴“linux中国”
人工智能,丹青圣手,全平台(原生/Docker)构建Stable-Diffusion-Webui的AI绘画库教程(Python3.10/Pytorch1.13.0) 世间无限丹青手,遇上AI画不成。最近一段时间,可能所有人类画师都得发出一句“既生瑜,何生亮”的感叹,因为AI 绘画通用算法Stable Diffusion已然超神,无需美术基础,也不用经年累月的刻苦练习,只需要一台电脑,人人都可以是丹青圣手。
ELK搭建(九):搭建Docker容器指标监控平台 Docker是一款轻量级的应用容器引擎,可以帮助我们快速部署各类软件,自动化构建系列生产环境。因此,我们也需要一个统一的监控页面,来让我们实时了解docker中各个容器的运行情况
使用Docker部署自动化CI/CD平台Drone [Drone](https://drone.io) 是一个现代化的持续集成平台,能够使用强大的云原生管道引擎自动化他们的构建、测试和发布工作流程,让我们不再关注程序如何发布而是如何去实现,去更好的实现。
相关文章
- docker上安装nginx服务
- docker中,将容器中的文件拷贝到宿主机上
- docker 与 docker-compose区别
- 全网最火爆,最详细Docker与自动化测试讲解,看完觉得我又行了
- Docker中mysql修改配置导致无法启动的docker容器
- 2021 最新 IntelliJ IDEA配置 远程Docker容器 编写Dockerfile文件 步骤演示(图文版)
- 基于docker轻松部署selenium grid环境
- 用了这款docker监控平台,再也不用记一大堆命令了,真香
- docker for windows--Windows 10 家庭中文版 21H2 安装Docker Desktop初体验
- docker-compose 搭建 YOURLS 短网址服务
- Docker容器(六)——创建docker私有化仓库
- 《Docker容器:利用Kubernetes、Flannel、Cockpit和Atomic构建和部署》——2.2 容器式Linux系统的Docker配置
- 容器平台选型的十大模式:Docker、DC/OS、K8S谁与当先?
- docker镜像、容器
- Docker中安装Gitea
- docker清理缓存
- MindSpore分布式并行训练 (GPU-Docker)mindspore—1.2.1—gpu—docker版本运行报错,Failed to init nccl communicator for group,init nccl communicator for group nccl_world_group
- 【YApi接口管理平台】在Linux上使用Docker搭建YApi (亲测完美运行)
- Docker问题——ubuntu下彻底删除docker
- Docker启动报错docker: Error response from daemon: Conflict. The container name “/redis6“ is already in u