云服务Web service是什么?

作者: 阮一峰

我认为,下一代互联网软件将建立在Web service(也就是”云”)的基础上。我把学习笔记和学习心得,放到网志上,欢迎指正。

今天先写一个最基本的问题,Web service到底是什么?

一、Web service的概念

想要理解Web service,必须先理解什么是Service(服务)。

传统上,我们把计算机后台程序(Daemon)提供的功能,称为”服务”(service)。比如,让一个杀毒软件在后台运行,它会自动监控系统,那么这种自动监控就是一个”服务”。通俗地说,”服务”就是计算机可以提供的某一种功能。

根据来源的不同,”服务”又可以分成两种:一种是“本地服务”(使用同一台机器提供的服务,不需要网络),另一种是”网络服务”(使用另一台计算机提供的服务,必须通过网络才能完成)。

举例来说,我现在有一批图片,需要把它们的大小缩小一半。那么,我们可以把”缩放图片”看成是一种服务。你可以使用”本地服务”,在自己计算机上用软件缩小图片,也可以使用”网络服务”,将图片上传到某个网站,让服务器替你缩小图片,完成后再通过网络送回给你。这就好比,一件事你可以自己做,也可以交给另一个人去做。肚子饿了,你可以自己做饭,也可以打电话去订一份比萨,让店家替你做好送上门。

“网络服务”(Web Service)的本质,就是通过网络调用其他网站的资源。

举例来说,去年我写过一个”四川大地震图片墙”,它能动态显示关于四川地震的最新图片。但是,所有的图片都不是储存在我的服务器上,而是来自flickr.com。我只是发出一个动态请求,要求flickr.com向我提供图片。这种情况下,flickr.com提供的就是一种Web service。如果我把图片都存放在本地服务器,不调用flickr.com,那么我就是在使用”本地服务”。

所以,Web service让你的网站可以使用其他网站的资源,比如在网页上显示天气、地图、twitter上的最新动态等等。

二、Web Service架构和云

如果一个软件的主要部分采用了”网络服务”,即它把存储或计算环节”外包”给其他网站了,那么我们就说这个软件属于Web Service架构。

Web Service架构的基本思想,就是尽量把非核心功能交给其他人去做,自己全力开发核心功能。比如,如果你要开发一个相册软件,完全可以使用Flickr的网络服务,把相片都储存到它上面,你只要全力做好相册本身就可以了。总体上看,凡是不属于你核心竞争力的功能,都应该把它”外包”出去。

最近很红的”云计算”(cloud computing)或者”云服务”(cloud services),实际上就是Web Service的同义词,不过更形象一些罢了。它们不说你把事情交给其他计算机去做,而说你把事情交给”云”去做。

三、本地服务的缺陷

“网络服务”是未来软件开发和使用的趋势,本地服务将用得越来越少,主要因为以下三个原因:

* 本地资源不足。很多数据和资料,本地得不到,只有向其他网站要。

* 成本因素。本地提供服务,往往是不经济的,使用专业网站的服务更便宜。这里面涉及硬件和人员两部分,即使你买得起硬件,专门找一个人管理系统,也是很麻烦的事。

* 可移植性差。如果你想把本机的服务,移植到其他机器上,往往很困难,尤其是在跨平台的情况下。

四、Web Service的优势

除了本地服务的缺点以外,Web Service还有以下的优越性:

* 平台无关。不管你使用什么平台,都可以使用Web service。

* 编程语言无关。只要遵守相关协议,就可以使用任意编程语言,向其他网站要求Web service。这大大增加了web service的适用性,降低了对程序员的要求。

* 对于Web service提供者来说,部署、升级和维护Web service都非常单纯,不需要考虑客户端兼容问题,而且一次性就能完成。

* 对于Web service使用者来说,可以轻易实现多种数据、多种服务的聚合(mashup),因此能够做出一些以前根本无法想像的事情。

五、Web service的发展趋势

根据我的观察,目前Web service有这样几种发展趋势。

* 在使用方式上,RPC和soap的使用在减少,Restful架构占到了主导地位。

* 在数据格式上,XML格式的使用在减少,json等轻量级格式的使用在增多。

* 在设计架构上,越来越多的第三方软件让用户在客户端(即浏览器),直接与云端对话,不再使用第三方的服务器进行中转或处理数据。

云主机支持哪些操作系统? 云主机支持哪些应用系统?

YUNVM云主机支持所有主流操作系统,如果用户需要的操作系统不在如下清单中,请联系客服,当前已经提供的操作系统包括:
Windows 2008R2 (x86_64)
Windows 2008
Windows 2003
Windows 2003 (x86_64)
Windows XP
CentOS 5.5
CentOS 5.5 (x86_64)
Ubuntu 10.10
Ubuntu 10.10 (x86_64)
Debian 5.0
Debian 5.0 (x86_64)
YUNVM云主机支持常见的所有应用系统,如:
网店类:
Shopex ECShop Ecmall EcGroupon
综合、CMS类:
PHP168 Dedecms CmsTop ECMS PhpCMS
论坛类:
Discuz Phpwind
博客、微博及其他SNS类:
WordPress Xweibo 拼图秀 iWeibo

选择YUNVM云主机的理由

高性能 采用硬件加速的虚拟化技术,配合虚拟化驱动;选择验证节点和资源池,以性能保证为前提;不同层级SLA,充分保证云服务器的计算性能在增长下依然得到稳固的保障。
低成本 灵活智能的资源调度与分配,使得硬件资源被充分利用,降低单用户使用成本;支持月付、无需押金,弹性扩容,避免“超买”成本支出,只需为使用的存储能力、计算能力与资源支付费用。
高安全 虚拟磁盘数据存储在网络环境中,使用冗余存储,消除单点存储故障,良好病毒防范查杀能力、完善备份机制,确保数据安全;虚拟网络采用自定义防火墙和组隔离技术,强大防攻击力,确保网络安全。
可靠性 采用优质资源、品牌设备,单用户独占主机资源,避免资源抢占;良好物理隔离,避免受同台物理机上其他服务器的故障影响;采用网络化的虚拟磁盘技术,分离数据与云服务器,出现故障,自动迁移。
全球部署 在北京、上海、武汉、成都、香港、美国等地建立了超过100个的云计算服务节点,跨网跨节点迁移部署,实现云服务器的动态迁移动态增长,全国范围的配置和路由均可灵活选择。
灵活性 不仅可以根据自己的需求选择想要的数据中心、带宽类型、硬件服务器配置和镜像等相关配置,还可以选择适合自己的计费模式。高度弹性、即时扩容,在线调整配置与带宽。
自助管理 用户对自己的弹性计算云拥有完全的控制权,通过业务平台自主管理。集中管理各节点云服务器,提供远程控制台、逐分钟的性能监控、安全规则、内网管理、快照管理等详尽实用的功能。