“服务上云”一直是一个进行时,在2010年-2017年期间,发力点重心都在「自有物理建设」到「IaaS基础设施即服务」,各个云厂商都在此基础上推出网络产品、数据库产品、存储产品,提供「PaaS」层面的产品来促进上云的过程,我们称为“服务上云1.0”。
“服务上云1.0”本质上就是将自建的物理服务设施迁移到云厂商提供的服务设施,并配备了一大批专业的工具。但在这一过程中,内在的关于开发者所选的服务技术架构,却很少干预触及;目前大部分流通的都是传统服务架构模式。
传统服务架构模式是什么?有什么特点?以下我列举几个大家对照感受一下
- 使用本地文件系统来持久化存储,数据文件和应用的文件混合在一起。
- 在同一个服务器上运行很多服务,比如 Mysql、Redis 、Nginx 以及一大堆定时任务。
- 使用大杂烩式的脚本和手工流程进行安装和升级。
- 配置是存储在文件里的,通常散落在多个位置,并与应用的文件混在一起。
- 进程间的通信是借助本地文件系统进行的(比如在磁盘上放一个文件,另一个进程来读取),而不是TCP/IP。
- 按照单个服务器上只运行一个应用的实例的方式来设计的。
这些特点会在执行维护的过程中暴露出很多问题,比如:
- 自动化部署很困难,虽然可以通过各种工具来实现,但仍有很大的水分空间存在。
- 如果需要运行应用的多个不同的实例,很难让多个实例在同一个服务器上同时存在。
- 如果服务器停机,由于需要手工流程所以需要较长的时间来恢复。
- 部署新版本的过程基本是手动的,或者大部分是手动的,难以回滚。
- 很有可能测试环境与生产环境有较大差异,导致一些生产环境问题不能在测试期间发现。
- 很难通过增加新的实例来进行横向扩展。
这些问题会随着业务的发展日益突出,最终极大的消耗人力成本,也累积了很多风险因素,即使服务设施上云,有强大的环境,内部系统的维护问题始终阻碍和影响高质量的服务。
容器技术,规避了传统服务架构模式所带来的问题,作为一种新的架构模式开始在近几年兴起。
容器服务,就是通过标准化方式,将业务代码和其所依赖的环境资源一起打包成为镜像,然后在服务器中启动一个实例运行这个镜像,就可以提供服务了。
比如你去网吧工作,使用网吧的纯净系统,需要安装自己所需要的办公软件才能够开始正式工作,这里就类比你在传统模式下需要根据服务设施的不同来进行针对性运维,才能够把自己的业务项目运行起来。
容器服务在上述例子中就是,你带了一块硬盘(或者一个U盘),将你的办公系统存储在其中,到网吧里直接插入你的硬盘,就可以立刻使用熟悉的系统了。
为了更好的说明容器服务,我们准备了一段30分钟左右直播回放,帮助大家从实践中感受一下容器服务的使用过程,点击文末阅读原文即可浏览。
通过30分钟的使用演示,比较全面的展示了容器技术的使用开发过程,从中间可以总结出容器技术的特点:
- 部署容易,可以使用新的容器镜像直接替换整个老版本。
- 自动化部署也相对容易,可以完全由 CI 来驱动。
- 部署失败时的回滚只要切换到之前的镜像就行,非常方便。
- 应用升级不需要去考虑复杂的升级配置流程,不必执行繁琐的步骤。
- 相同的容器镜像可以在不同的环境中充分测试,再直接部署到生产环境,确保测试环境与生产环境完全一致。
- 系统更容易从宕机中恢复,因为可以迅速在新硬件资源上启动装有这个应用镜像的新容器,并附加到同一数据源上。
- 开发人员能在本地以容器的形式,在更逼真的环境里测试新功能。
- 硬件资源的利用更高效,在单一主机上可以运行多个容器应用。
- 容器化是支持零停机升级、金丝雀部署、高可用和横向扩展的坚实基础。
在回放中总是讲到Docker,容器技术和Docker到底是什么关系?Docker是构建容器的技术工具,是目前流行的。就好比安卓和IOS(Docker)是手机终端操作系统(容器技术)中比较流行的,因为流行,所以各个厂商都会适配,使得技术方案可以畅行无阻没有门槛。
当我们构建的服务越来越多,同一个服务因为并发可能包含多个容器实例,那么如何有效的管理协调多个容器的位置资源?如何处理容器与容器之间的通信?这就需要容器编排技术。
Kubernetes是目前最流通的容器编排技术,提供API来控制容器的执行方式和位置,操作执行Docker容器和调节工作负载,解决在调整跨多部伺服器部署多个容器规模时的一些复杂作业。
Kubernetes是目前最流通的容器编排技术,提供API来控制容器的执行方式和位置,操作执行Docker容器和调节工作负载,解决在调整跨多部伺服器部署多个容器规模时的一些复杂作业。
我们来看一下标准的容器服务需要的配置,其适用于对容器编排非常熟悉的团队使用,可以灵活配置,按照自己的需求来调整
熟练掌握Kubernetes并且独立维护起来成本也是很高的,需要比较好的专业背景才能够做的出色,对于快速发展的企业和业务团队,上来就打这么大的积累是比较难顶的。当我们对容器服务不太了解,我们如何使用容器服务呢?
微信云托管,通过简化繁杂的配置流程,提供易配置高可用的容器服务;并整合与业务相关的套件,包含可自动扩缩容的数据库,对象存储等,同时也提供很多微信在服务技术的一些积累,打造安全的有生态特色的一站式后端服务平台。
也就是说,你即使没有微信相关应用服务,也可以使用微信云托管来为自己的业务提供服务,其在防刷攻击,安全链路方面都有很强的优势特点。
那么如何迁移项目到云托管?我们总结了一份迁移指南,建议大家结合直播回放视频一起学习使用。
如果你所在的企业希望得到专业的支持,并想要又一些优惠策略,可以报名云托管企业激励计划,团队将有专人跟进帮助。
点击获取:「完整直播回放」和「配套源码」
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。