本文主要是介绍如何从零手撕一个PaaS平台?,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
PaaS 平台重构原因及架构
一、背景
目前在用的PaaS平台是之前购买的一个商业产品,但没有源码,运维期也早就结束了,所以在后期使用过程中会遇到一些各种各样的问题,对于使用、运维都造成一定的困扰。
老PaaS的架构及基本功能如下:
二、重构
为什么选择重构PaaS平台而不是全部迁移kubernates集群?
kubernates集群的确提供了很多优秀的特性,比如:RC、滚动更新或回滚、资源监控和日志记录、负载均衡等等。
但在目前我们这边的环境来看,迁移kubernates集群有如下几个问题:
- 无法无感知迁移,即迁移到kubernates集群的过程中及迁移到kubernates集群后,不增加用户的使用、学习成本,但应用引入kubernates集群之后,很难保证这一点。因为我们这边的用户大多是我们公司的供应商,供应商其实不太关心,你平台所提供的各种新特性、功能,更不想因为这些新特性、功能增加他们的使用、学习成本。
- 我们这边很多项目本身是有硬负载的,比如F5,所以kubernates提供的负载均衡功能,也就显的不那么重要。
- 日志部分,我们已经打通各个平台的日志、监控,不再需其他的组件。具体参见:《基于日志的收集、检索、监控、告警平台》
- 滚动更新或回滚,老PaaS平台木有,重构后新版中准备加入(二期)。
- RC类似功能,目前不打算支持。
1、架构及用到组件梳理
2、新PaaS功能点梳理
三、迁移
通过无缝迁移,在用户无感知的情况下实现迁移。
为什么要做到无感知迁移?
老PaaS中目前的项目数量是:193个,应用数量是:673个
总实例数:1485,其中生产环境的实例数:894
如果这些项目、应用,因为你的重构都需要改动的话,那么推广难度是很大的,所以需要尽量做到,对于用户来说无感知迁移。
以下迁移部分,都需要在新PaaS上线前完成并在上线一段时间准实时同步过来。
PaaS平台日志的收集可以参考:《ELK+Prometheus 构建实时日志 检索 监控 告警平台》
类似产品:https://www.terminus.io/product_paas
个人微信公众号:
作者:jiankunking 出处:http://blog.csdn.net/jiankunking
这篇关于如何从零手撕一个PaaS平台?的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!