挑战有何不同!云环境中开发 vs 云环境中管理

原创
云计算
云计算的优点已经被捧上了天,主要包括能够带来业务敏捷性、可扩展性、效率以及节省成本;而许多公司正以越来越快的步伐,迁移和构建专门面向云环境的关键任务型Java应用程序。我们最近采访了AppDynamics 公司的工程技术主管Bhaskar Sunkara——这家应用程序性能公司专注于Java和云应用程序,探讨了为云环境开发Java应用程序以及在云环境中管理这些应用程序面临的挑战。

云计算的优点已经被捧上了天,主要包括能够带来业务敏捷性、可扩展性、效率以及节省成本;而许多公司正以越来越快的步伐,迁移和构建专门面向云环境的关键任务型Java应用程序。我们最近采访了AppDynamics 公司的工程技术主管Bhaskar Sunkara——这家应用程序性能公司专注于Java和云应用程序,探讨了为云环境开发Java应用程序以及在云环境中管理这些应用程序面临的挑战。

为云环境进行开发面临哪些挑战?

为云环境进行开发面临的主要挑战之一是,了解应用程序与服务的依赖关系(application service dependencies)是如何处理的,这比了解编程语言还要重要。应用程序与服务的依赖关系包括:分布式环境中部署的数据库、消息服务器或其他服务。这些传统上是通过在部署过程中将服务引用映射到物理IP来处理的,但是云带来了一个新的变化因素,连IP地址都不是事先知道的。
那么,您如何知道所有这些依赖关系在哪里、又该如何利用它们?

从根本上来讲,当你拥有面向服务的环境时,会有许多服务彼此“会话”,并且利用众多基础架构元素。在任何一个特定的时间,你的服务可能使用所有其他这些服务。在传统的静态环境中,你很容易了解这些元素在哪里,然后编写代码。开发人员能够确认资源,会知道应用程序一旦部署下去,要使用什么资源。可是在云环境中,无法保证应用程序会使用哪种IP,也无法保证它会如何查找服务或数据。

开发人员需要深入了解如何以一种非常明智的方式来使用服务。高效找到资源的功能需要成为应用程序的一部分,谨慎地使用这项功能方面要有可重复使用的模式。使用查找模式来找到你想使用的服务,是解决这个问题的流行方法之一。如果你在构建应用程序时没有考虑到这些因素,就可能带来无法管理的扩展性和重构问题。

至于正式的规范,J2EE在部署过程中借助资源映射,在资源依赖关系方面已经做得很到位。比如说,应用程序与数据库进行联系,而你与为你提供连接的逻辑资源进行联系。当你部署应用程序时,把这个资源映射到实际的数据库IP/URL,不需要硬编码。

在J2EE开发模式中,开发人员得到JNDI命名上下文,让他们可以查找所需要的服务——这需要用可以将IP依赖关系抽取出来的可感知云的命名上下文来加以包装。这么做的话,可感知云的命名上下文是拥有“服务定位器”(Service Locator)元素的唯一元素,维护起来要容易得多。

为云环境进行开发面临的另一个问题是处理横向扩展——Java开发人员应该知道哪些东西?

云计算的一个基本前提是它能够便于横向扩展(horizontal scaling),但不是所有的应用程序天生都可以横向扩展,它们也从来没必要横向扩展。必须确保云环境中的任何应用程序都具有无状态性(Statelessness)。对于按需基础架构而言,喜欢本地保留状态的习性打破了一切。编写的应用程序必须确保:需要扩展的任何应用层都具有横向扩展的能力。在最近的几年里,我们开始看到了比较新的应用程序中出现这种情况,但这对许多开发人员来说仍是个障碍。

如果让您为从事云环境编程的Java开发人员提议一个最佳实践,那会是什么?

别对数据存储局部化!如果你这么做,这几乎如同将数据处理局部化到某一个Java虚拟机(JVM),而不是把它当作云来对待。这可能会带来局部化到JVM的依赖关系。数据管理应该总是分布式的。你一定要假设服务器会失效,而且是常常失效。关系数据库不再是云环境中的常态。由于应用程序生态系统出现了那么多的变化,应用程序必须天生是无状态的。

当然了,也不要使用物理IP或基于磁盘的定位器来查找你在应用程序中需要使用的服务。要依靠把物理IP抽取出来的位置模式或服务。

那真是个好点子。最后,开发人员将应用程序部署到云环境之前,应用程序测试方面要了解哪些东西?

如果你想测试处于开发周期的应用程序,如果你想看看它在云环境中怎样运行,就面临这个挑战:从本地开发环境迁移到云环境。想从本地开发环境进入到云环境有难度。事实上,没有办法有效地模拟一旦应用程序部署下去,云环境的外观感觉会怎么样。能处理云环境的集成开发环境(IDE)同样仍在不断成熟当中。从本地测试环境切换到云环境的过程越顺畅,开发周期的效率就越高。过去将应用程序部署到云环境上常常困难重重。现在要容易多了,但要让整个过程变得真正的高效顺畅,开发工具依然有很大的发展空间。

原文名:Developing for the cloud: How developing in the cloud is different 作者:Cameron McKenzie et al.

【本文乃51CTO精选译文,转载请标明出处!】

【编辑推荐】 

  1. 微软公布云计算平台Azure收费模式细节
  2. 云计算意在长远,微软云计算服务Windows Azure已经启用
  3. 技术透析:Windows Azure Platform框架与组成
  4. 微软Windows Azure Platform技术解析
  5. 走近微软云:SQL Server到Azure数据同步
  6. 当微软Azure遭遇亚马逊EC2:五大关键区别
  7. Windows Azure云计算平台新增五大功能
  8. 云计算前途光明 Azure用户数突破31000
  9. 如何把应用程序部署到Windows Azure中
     


 

责任编辑:王勇 来源: 来源:51CTO
相关推荐

2011-12-21 09:01:28

云计算编程开发

2021-01-04 10:54:58

云计算容量管理

2013-07-24 09:29:35

云就绪应用DevOps工具分布式网络

2021-11-26 15:14:20

混合云网络安全SASE

2012-05-23 17:35:29

2023-12-12 11:45:54

云服务数据科学家云计算

2020-01-13 11:51:31

云计算技术混合云

2016-10-13 14:10:09

云计算开发容器

2022-02-15 10:45:53

混合云云计算SASE

2017-01-20 15:00:27

数据中心云计算

2024-02-02 11:43:17

云时代数据战略云计算

2022-09-05 15:08:58

云计算IT工具

2023-08-30 16:22:03

云原生云计算

2018-10-24 19:59:45

Kubernetes混合云云扩展

2024-02-18 13:34:42

云计算

2022-02-25 23:44:44

云计算DRP安全

2012-02-29 09:50:52

云计算虚拟化

2016-12-15 15:26:17

与计算

2011-08-31 17:58:00

VS.netLUA开发环境

2021-05-20 14:17:05

云计算混合云架构
点赞
收藏

51CTO技术栈公众号