5条建议,让应用软件服务发挥云计算平台的优势

简介: 传统的企业应用软件开发者,在软件开发的哪些方面应该做出调整,以利用云计算的优势,开发出可快速扩展、可自动维护的互联网级的应用服务?

传统的企业软件,往往部署在企业内网,以服务单个企业或集团为主,具有可以估算的系统吞吐量和访问量。基于估计的性能要求,采购相应规模的服务器,然后部署应用程序。这种背景下开发的应用软件,往往对于扩容能力要求不高,适应不了通过互联网对外服务的场景。通过互联网对外服务时,客户会越来越多,而访问量可能有明显的波动性。为了满足高峰时期的访问量而部署的计算能力,在平常时期是很大的浪费。不论是企业自己的互联网业务(B2C, B2B),还是应用软件开发商以软件即服务(SaaS)的形式提供的企业应用,都需要反思软件是否能适应这种更加动态的场景。

云计算给这种场景提供了更好的计算平台,容器云技术更使得我们可以接近实时地获取与释放计算资源;此外,云计算平台还提供了很多的支持性服务,能极大地简化基础服务的部署与维护。那么,我们如何设计应用软件服务,以发挥云平台的这些优势呢?

国外知名的云平台服务商Heroku提供了一份开发指南 the-twelve-factor-app, 从12个方面提供了建议。本文基于我对上述开发指南的理解,整理成5条建议。

把大型应用划分为服务和程序库

把大型应用按功能分解为多个服务。对于服务共用的代码,则按功能封装为程序库。这种化整为零的策略能降低大型应用开发与支持的复杂度。按服务和程序库来建立敏捷团队,进行设计、开发与交付。

每一个服务或程序库都有自己独立的代码库,而不是把大型应用的所有代码都放在单一的代码库中。这样能更好地发挥代码库的修订历史管理能力,让不同的服务和程序库以不同的节奏进行开发和发布,而不至于在代码修订上互相干扰。

通常,服务或程序库会依赖其他的服务和程序库,应该通过依赖管理工具,详细而准确地描述依赖关系,避免依赖库的版本引起的问题。

敏捷方法能尽早交付最有价值的服务,然后持续地交付改进和新功能。这种增量的交付方法意味着时常会发布新代码。为了避免新代码中的缺陷对生产环境稳定性影响的风险,应该建立多个执行环境。比如,开发人员的开发和测试环境,集成测试环境,准生产环境(或预备生产环境)和(正式)生产环境。

不同执行环境中,服务器的IP地址、名字是不同的;数据库、消息服务器等的方法URL和账号也是不同的。这些环境上的差异,应该通过配置项体现出来,而不是使用条件语句写入到代码中。配置项可以用系统环境变量来表示,也可以用配置文件来保存。如果使用配置文件,要特别注意,服务的代码库中只能保存示例配置文件,不能保存任何具体执行环境的配置信息,以免造成信息泄露,影响系统安全。

遵循“构建、发布版本、运行”三阶段的流程,将服务发布到这些执行环境中去。“构建”是基于代码库的某一次提交来将服务的代码文件(包括依赖库)打包;“发布版本”是将代码文件包和相应执行环境的配置打包;“运行”是在某执行环境启动服务进程。不应该在运行环境中手动修改代码或配置,以免丢失。构建包和发布版本包都应该使用版本号进行标记,并使用配置管理工具自动管理。

为了避免基础软件环境,比如操作系统、开发语言版本、数据库版本等不一致造成的问题,应该尽量让开发、测试与生产等环境保持一致。由于现在大多数服务是使用Java, PHP, Python, Ruby, Nodejs等语言开发的,程序代码是通过语言虚拟机或解释器运行的,为了提高开发者工作效率,可以允许使用不同的操作系统环境。

使服务能快速启动和优雅地关闭

云平台环境中,为了响应快速波动的应用访问,我们可以通过调用云平台API,自动地管理服务执行环境的创建与销毁。

一旦执行环境准备好,服务的启动应该尽量地快。传统的以应用服务器容器为中心的架构中(比如 Java EE),需要先启动应用服务器和一些列的自带服务,再启动应用服务。整个过程太长,太慢,对于依赖较多的服务,时间是分钟级别的。在以服务为中心的架构中,理想的服务进程的启动是秒级的。

当应用的访问波峰过后,多余出来的处理能力应该优雅地关闭:不再接收新的请求,等已入列的请求完成后,停止服务进程,然后回收服务器,退还给云平台。

由于运行服务的容器(或虚拟机)数量多,且会动态地创建与释放,因此服务的运行日志不应该保存在本地磁盘,而是应该以时间序列事件流的形式发送给专门的日志处理器。运维支持人员通过日志处理平台来查看、处理、分析日志数据。

把平台支持服务看成低耦合的、可分离的资源

应用服务会依赖很多的平台服务、支持性质的服务,比如数据库、队列、缓存等。这些服务,有可能是应用开发者公司自己部署管理的,也可能是云平台提供的,还可能是第三方的服务。应用服务应该把这些支持性质的服务看成以URL访问的资源。当应用服务管理员切换资源提供者时,只需要更新配置项中URL值,应用服务代码不需要修改。这种低耦合的设计,有助于灵活选择支持服务提供者,使得应用服务商可以根据业务需要进行切换。

这要求应用服务代码使用行业标准代码库来访问这些资源,避免在代码中直接使用服务提供商的私有代码。

基于进程的服务部署

应用的服务应该以一个或多个进程的形式运行,而且任何需要保存的状态应该由后台支持服务负责,应用的服务进程对于请求者而言应该是无状态的。对服务请求者而言,不能假设下一个请求会被调度到和上一个请求同一个服务进程上进行处理。因此,会话状态不能保存到进程本地,而是应该保存到后端的数据库服务中,如 memcached, redis等。会话建立以后,服务请求者每次请求都应该带上会话ID,应用服务根据会话ID从后端支持数据库中获取会话状态。

基于进程的部署使得向外水平扩展变得很容易,只需要新增服务器、部署运行更多进程即可分担请求。对进程的管理,应该像Linux管理启动服务那样简单。

相比于传统的让服务运行于某个应用服务器容器中,网络端口由容器分配的方案,我们更倾向于以应用服务为主体来分配和使用网络端口。在应用启动时调用网络服务库,启动网络服务端口;而不是等应用服务器容器启动以后,加载应用服务模块。这种方式能从逻辑上避免共享应用服务器容器带来的冲突。如果多个服务运行于同一个应用服务器进程中,那么我们就无法以简单的进程管理方式来启动和关闭某个服务。而且,多个服务所需要加载的依赖包,在同一个进程中加载,可能存在版本冲突,使事情变得更复杂。小型化、独立化是更适应自动化服务进程管理的设计思路。

提供管理脚本执行环境

应用服务代码除了提供常规的请求处理功能以外,通常还应该提供管理脚本。这些管理员脚本一般用于执行一次性的任务,如数据库结构更新、异常数据修复,或查看服务内部状态等。

执行这些管理脚本的环境,应该与服务进程的环境相同;应该在“版本发布”后的环境中执行这些一次性任务。

目录
相关文章
|
17天前
|
监控 Cloud Native 持续交付
构建未来:云原生技术驱动的云计算平台
【5月更文挑战第52天】 随着数字化转型的不断深化,企业对于敏捷性、可扩展性和成本效益的需求日益增长。本文探讨了如何通过采纳云原生技术来构建和优化云计算平台,以支持不断变化的业务需求。文章首先概述了云原生技术的核心概念及其优势,随后详细分析了在设计云平台时应考虑的关键要素,并通过案例研究展示了云原生实践在实际中的应用效果。最后,文章提出了面向未来的云平台发展趋势和挑战。
|
2月前
|
存储 运维 持续交付
探索云计算的不同服务模型:IaaS、PaaS、SaaS
【5月更文挑战第23天】本文探讨了云计算的三大服务模型:IaaS、PaaS和SaaS。IaaS提供基础设施租赁,允许用户按需付费,聚焦业务创新而非设备维护。PaaS在IaaS基础上提供开发、测试和部署环境,简化应用管理,支持弹性扩展。SaaS则为用户提供可通过互联网访问的软件应用,实现多租户共享,提升工作灵活性。这三种模型满足了不同用户从基础设施到软件服务的多元化需求。
|
6天前
|
存储 安全 数据库
阿里巴巴的云计算平台有哪些服务?
【7月更文挑战第1天】阿里巴巴的云计算平台有哪些服务?
99 57
|
2月前
|
边缘计算 Cloud Native 安全
未来云计算平台的发展趋势与挑战
随着数字化时代的到来,云计算作为一种关键的信息技术基础设施正在发挥着越来越重要的作用。本文将探讨未来云计算平台的发展趋势与面临的挑战,分析在日益复杂多变的技术环境下,云原生技术的应用将如何推动云计算平台迈向新的高度。
|
6天前
|
存储 弹性计算 安全
云计算服务选型与成本分析
【7月更文挑战第2天】云计算服务选型与成本分析聚焦企业如何在IaaS、PaaS、SaaS间抉择,考虑云提供商的技术实力、服务范围、成本效益和支持。成本分析涉及硬件、软件和服务成本,通过简单回收期、投资回报率和净现值法评估效益。优化资源配置、弹性伸缩和合理计费是成本控制关键,助力企业高效利用云计算。
|
7天前
|
监控 中间件 Go
云计算和云网络的优势和挑战
云计算和云网络是相关但又不同的概念。云计算关注的是应用程序如何运行,而云网络则关注的是应用程序之间的连接如何管理和交付。
12 2
|
13天前
|
存储 安全 定位技术
云计算在远程办公与协作平台中的应用与挑战是一个热门话题。
云计算在远程办公与协作平台中的应用与挑战是一个热门话题。
10 1
|
19天前
|
存储 运维 搜索推荐
云计算平台在在线教育领域的应用探索
云计算平台在在线教育领域的应用探索
28 0
|
19天前
|
云计算 数据中心 Python
云计算在在线教育平台中的资源管理与优化
云计算在在线教育平台中的资源管理与优化
|
2月前
|
安全 Devops 虚拟化
【专栏】虚拟化技术与云计算平台 OpenStack:硬件虚拟化、操作系统级虚拟化和容器化
【4月更文挑战第28天】本文探讨虚拟化技术原理,如硬件虚拟化、操作系统级虚拟化和容器化,以及开源云计算平台OpenStack如何利用这些技术提供优势。OpenStack支持多种虚拟化技术,具备开源灵活性、多租户架构、可扩展性、插件式设计和成本效益。未来,OpenStack将在容器化、DevOps、跨云策略和安全合规性方面发挥更大作用,助力企业数字化转型。