如今,云计算无处不在。最简单的说,云计算是通过互联网存储和访问不同的数据和程序,而基础架构即服务(iaas)是云的基本构件。iaas支持在云环境中自然开发,测试和使用应用程序。在本文中一个想通过iaas托管java应用程序的用户,如何选型国外主流的5大云供应商服务。它简要介绍iaas,然后比较5个主流云提供商:amazon ec2,google compute engine,ibm softlayer,微软azure和digital ocean。
iaas可帮助企业避免购买和运行自有服务器的复杂性。而且,不需要维护和升级软件。它在许多情况下具有较低的基础架构成本,从而帮助没有时间和资本的新企业投资自己的硬件基础设施。
iaas的其他一些好处包括:
服务可作为大量资源分发。
灵活,iaas提供弹性缩放。
成本,可根据业务需求的不同而不同。
多个用户可以使用单个硬件。
位置独立性,只要有互联网连接,并且云的安全协议允许,通常可以从任何地方访问云服务。
以上是iaas用于构建web应用程序的优势,所有需要做的就是决定要选择哪个凯发在线的解决方案。唯一的问题是今天有这么多的选择。作为java开发人员,我最初在评估各种iaas服务时遇到了一些困难。因此,在本文中,我将介绍托管java web应用程序的五个最佳凯发在线的解决方案,并将它们相互比较。
亚马逊ec2
亚马逊弹性云(amazon ec2)是一种web服务,可在云中提供可调整的计算容量。它有助于启动和管理服务器实例,从而使其适合用于web规模计算的开发人员。
▲
实例有不同的大小和配置。 ec2允许aws提供不同的实例类型,可用于满足特定需求。因此,可以根据需要启动不同的虚拟机。如果正在部署java应用程序,则可以将应用程序服务器(tomcat,web sphere等)安装到一个虚拟机中,并在具有适当配置的单独vm上使用其他服务,如微服务,数据库等。
使用amazon ec2,可以灵活的选择不同的实例类型,操作系统和软件包。amazon ec2具有内存,cpu和实例存储配置,有助于存储选择。此外,可以选择最适合你的操作系统和应用程序的启动分区大小。
使用ec2的唯一缺点就是费用。随着我的工作流程变得更加复杂,我使用更多的服务,很难投入成本。然而,为了帮助估算成本,亚马逊提供了一个月度计算器。
与其他服务提供商相比,网络并不灵活。由于大量数据必须从lan的一端移动到另一端,因此数据传输距离远远超过互联网上常见的拥塞问题。
amazon ec2可以说是行业的标准。许多领先的网站和应用程序使用ec2。比如instagram,reddit,netflix,adobe,三星等等。你可以找到很多使用amazon ec2的案例!
google compute engine
google compute engine(gce)可帮助你在google上为自己的服务,使用相同基础架构,并运行虚拟机。gce为企业提供更大的灵活性和控制能力以及访问计算资源的规模,从根本上改变企业对解决问题的思考方式。gce很像ec2,但虚拟机运行在google的基础设施上。在google compute platform上部署java很简单。
▲
网络定价昂贵。由于gce比较新,与aws不同,编程语言的选择是有限的。google compute engine中不支持aws中支持的一些java api。从gce到任何其他平台的过渡并不容易。还应该注意,为了运行任何java框架,gce需要为用户做更多的帮助,因为它们没有集成的包。
最常见的gce客户包括evernote,飞利浦,可口可乐,htc,摩托罗拉,同时可汗学院,spotify,口袋妖怪和百思买等也利用gce的数据仓库和分析功能。
ibm softlayer
正如ibm倡导的“无需妥协的云”,它提供高容量,可扩展性和安全性的云服务。 ibm softlayer的高速内部网连接对企业复杂应用程序所需的iaas凯发在线的解决方案,但必须支付额外的费用才能使其工作。
▲
softlayer的裸机基础架构可以与虚拟化服务器结合使用,提供一系列的hyper-v技术的凯发在线的解决方案,从而可以优化生产工作负载。并在softlayer的数据中心之间提供了极佳的高性能带宽,使云环境能够承受从一个数据中心到另一个数据中心的数据突然增加。同时,softlayer的单一租户服务器模式通过综合防火墙保护数据,为敏感信息提供保护。除ibm softlayer外,没有其他云提供商提供自定义虚拟机类型。softlayer提供调用其api的maven依赖关系。
softlayer的服务没有捆绑在一起。虽然ibm提供广泛的服务,但不仅仅是云服务。相反,它们将公有云服务与内部和ibm品牌的服务相结合,从而提供“虚拟it部门”,即联系ibm进行托管服务以进行软件更新和维护。
重要用户如artomatix,cedato和clicktale等。
微软azure
全面的服务,可帮助你快速开发,部署和管理全球各地微软的数据中心的应用程序。它支持windows,linux和社区虚拟机映像以及跨平台开发工具和框架。支付所用的费用,就可以可以节省大量成本并实现更高的效率。
▲
azure的服务器可以让用户在云端完全控制。application insights是面向多个平台上的web开发人员的服务。遵循“检测,评估,诊断,稳定和关闭”的标准安全模式,强调安全性。 azure还提供简单,用户友好的服务,以增加保护,如多因素身份验证和应用密码要求。如果你需要使用自定义第三方软件或许多应用程序的凯发在线的解决方案在单台机器上运行,那么azure的iaas凯发在线的解决方案能提供帮助。作为java开发人员,你将发现在这里轻松部署和扩展webapps。
实例之间的负载平衡可能会中断应用程序的状态;即不能保证来自同一用户的两个请求将转到相同的实例。azure在选择实例类型时不提供灵活性。此外,它需要专业的管理和维护,包括修补和服务器监控。
在微软azure上的代表用户是essar,cloudmunch,apppoint和shephertz,通过azure节省了65%的部署。
digital ocean
digital ocean针对linux开发者。它提供了简单的设置,为用户提供了一个干净,易于使用的界面,具有很少的功能和一键式部署。它具有控制面板来管理诸如双因素身份验证,良好的api,自动备份和dns管理等功能。它提供了与其他服务相比便宜的ssd主机。
▲
提供的服务是虚拟机和dns管理,无负载平衡,托管数据库,分析,hadoop集群等必不可少的服务。如果不仅仅关注自动缩放和高可用性,更多地投入管理服务器,那么digital ocean适合你的使用。对于java开发人员,官方网站有一个社区提供教程。
digital ocean的不足是它们的磁盘位于管理程序中,并且它们不使用集中式存储,如果托管在故障管理程序上,则导致完全数据丢失的风险相对较高。但是,如果你有这样的风险,并且有备份,那么你可以用你满意的价格获得一些出色的服务器。
digital ocean的用户包括nodebb,rockerbox,ghost和taskrabbit。重要案例是jquery基金会正在使用digital ocean。
综合比较: