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

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

原创
作者:编译/布加迪 2011-03-17 17:59:33

云计算 云计算的优点已经被捧上了天,主要包括能够带来业务敏捷性、可扩展性、效率以及节省成本;而许多公司正以越来越快的步伐,迁移和构建专门面向云环境的关键任务型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中
     

 

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/237495.html<

(0)
运维的头像运维
上一篇2025-04-22 12:20
下一篇 2025-04-22 12:22

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注