更多云场景实践研究案例,点击这里:【云场景实践研究合集】联合不是简单的加法,而是无限的生态,谁会是下一个独角兽
作为在线教育平台,学霸君选择阿里云的容器方案来实现运维的自动化 。本文站在运维的角度,介绍了学霸君如何落地实施基于微服务和容器的云上系统 。
“当时我们对比了多家服务提供商,包括阿里云、AWS和第三方的Pass平台。相比之下,阿里云拥有一定的优势,所以我们最终选择了阿里云的容器方案。”
——俞杰
学霸君运维负责人
采用的阿里云产品
- 阿里云容器服务
- 阿里云容器镜像服务
- 阿里云日志服务 LOG
为什么使用阿里云
希望借助第三方服务和架构体系完成自动化运维系统的构建,降低维护成本,加快部署和交付速度
关于 学霸君
学霸君(隶属于上海谦问万答吧云计算科技有限公司)成立于2012年,是国内领先的中小学智能化在线教育公司。公司集合来自谷歌、中科院、腾讯等人工智能领域专家,技术水平位于行业领先地位。学霸君从成立到现在不到4年的时间,在这期间推出了拍照答疑和实时答疑,这些都是在整个在线教育领域的重磅产品。
学霸君发展中遇到的障碍
在快速发展的过程中,公司业务往往会急速扩张并且业务架构也会逐渐复杂化,此时运维就是一个比较头疼的事情。在早期,为了业务能尽快上线,运维会有很多的退让,因为此时的最高优先级是让业务能够尽快上线,不太会关注标准化和安全性。这就导致后期业务规模越来越大的时候,维护的难度将会呈现指数级递增。这时就不得不考虑运维自动化了,但是传统方式中想要实现运维自动化就需要一个团队来开发一个平台或者系统,而在这方面花费的人力和物力对于中小企业或者处于发展阶段的创业公司而言都是比较大的开销。所以学霸君希望能借助第三方服务和架构体系完成自动化运维系统的构建。
为什么选择阿里云?
学霸君决定向微服务转型的时候选择在新项目上实施微服务架构。
如图所示的是当时的项目的架构图,这样一个简单的应用其实涉及到了9个服务模块,而且这还只是项目初期。项目涉及到了许多的开发语言和框架,这样对于开发人员而言非常方便,可以选择自己熟悉的语言,但是对于维护人员而言简直是噩梦,因为需要维护的东西实在太多。
这样的架构如何在生产环境下真正地运行呢?这也是整个微服务架构和容器化需要考虑的问题,无论是自己进行开发还是使用开源软件进行二次开发都需要考虑。
学霸君上云方案及成效
下图是基于docker的微服务架构技术栈。最上层是应用层;下一层是接入层,涉及到负载均衡的高可用和稳定性;再下层的服务层就是微服务的双方如何去注册和发现对方,以及如何进行通信以及部署上线的灰度发布;再下一层更多的是容器级别的内容,容器集群的正常运转是业务正常运行的保证,这一层面同时涉及到代码库以及容器镜像的管理;最后一个层面涉及的就是阿里云提供的云服务以及一些私有云等。
虽然目前有很多的开源软件可以使用,但是基于开源软件进行二次开发还是比较困难的。在对比了多家服务提供商后,包括阿里云、AWS和第三方的Pass平台,发现阿里云拥有一定的优势,所以学霸君最终选择了阿里云的容器方案。
如果容器方案中支持良好的持续集成和交付将大大缩短应用上线的时间。同时我们对接了自己的源代码管理系统,对于代码的管控更加安全,代码可以直接拉到阿里云上构建的Jenkins的系统,然后利用通用型的构建方式将代码构建成镜像,直接推倒阿里云的镜像仓库。这样对于镜像的管理都是由阿里云提供的,开发者不需要关心太多的细节。而且对于同样一份镜像和同样一个服务,可以在三个环境下运行,而且不会存在差异。
学霸君基于阿里日志服务构建的日志系统
下图是阿里云提供的日志系统框架。该日志系统可以对接后端,支持大规模的数据处理和分析。
关于学霸君的更多实践详情:学霸君基于Docker的微服务架构设计
原文发布日期:2016-11-02
云栖社区场景研究小组成员:李杉杉,仲浩。