本章提供了 Google App Engine 的一些概念。我们将看看 Google App Engine 的开发以及 Google App Engine 怎样通过开发和运行服务来实现云计算的概念。
什么是 Google App Engine ?
Google App Engine 是一个基于 Python (译者注:现在也已经支持 JAVA 语言了)的应用服务运行平台,在 Google 大量的基础架构上提供了 Web 应用托管、数据存储以及高速网络的功能。
开发人员可以利用 Google App Engine 提供的 API 免费创建应用服务,包含着下面的一些限制:
注意:本文写作的时候 Google App Engine 还只是免费试用,而且暂时没有收费计划。
上面的这些限制考虑到下面的特性就不会奇怪了:
运行环境已经通过底层的操作系统抽象出来从而避免了系统平台的依赖性。 Google 的基础架构通过分发在多个服务器为你的应用提供了自动和按需的流量整形和负载均衡功能。每一个应用都运行在一个单独的安全沙盒上,而不会影响到其他应用和引起资源冲突。应用可以运行在一个默认的 appspot.com 域名上,或者是你自己的 Google App 帐号。使得应用建立并运行起来只需要一些简单的设置工作。
Google App Engine 和云计算
云计算描述了运行在第三方提供的分布式运算资源上的应用。有些云计算提供商提供通用计算和存储能力,而另一些提供专门或专业服务。
云上的终端用户应用
最引入注目的云计算例子是终端用户应用。这集成了软件为服务(Software as a Service (SaaS))以及平台为服务(Platform as a Service(PaaS))的计算模型。用户通过标准的 Web 浏览器和应用进行交互,而不用关心发布和内部管理。
云上的服务
除了能够发布交互式应用,供应方可以通过通信或者数据交互协议发布服务的 API 或者是开启服务的平台。这些服务可能还包括主机系统提供。还有的一些云服务包括:
Web 服务:Salesforce.com,the United States Postal Service,Google Maps都为其特定的任务提供了 API 。
服务平台:Mule, Postini, SecureWorks和Cape Clear通过引入基于 ESB 技术的第三方提供或者用户的应用的商业系统提供了整合能力。
管理服务:Sun Microsystems, IBM, Liquid Computing, 和3Tera为终端用户和服务软件提供了主机服务,同时还包括用户架构和 IT 团队支持。
Google App Engine 和云计算
Google App Engine 为终端用户提供了 3 个特别的云计算特性:
怎样开始实现一个云计算服务呢?本章接下来的部分描述了 Google App Engine 如何使得这个任务非常容易。
在使用 Google App Engine 之前
在使用 Google App Engine 之前需要知道一些基础知识:
容易使用是 Google App Engine 的一个主要设计目标。可以通过 SDK 或者是标准的 Python 代码使用一个 App 模拟器来对代码进行测试。 Python 的解释特性使得可以快速的做行测试以及原型设计。 SDK 和 App 模拟器的硬件需求是很低的,所以只要是一个简单的工作站和基本的互联网能力都可以工作得很好。
提示:“Dive into Pytho”是学习 Python 语言的好的途径,包括基本的和高级的概念。这本书可以从 http://www.diveintopython.org 上获得。
和用户交互的 App Engine 应用需要支持一个 Web 应用框架。 Python 的 Web 服务网关接口(Web Server Gateway Interface (WSGI))是你的 App Engine 应用可以使用的和 Web 服务器以及应用服务器通信的标准机制。 App Engine 支持 WSGI ,并且可以工作在任何兼容的应用服务器上。如果需要阅读有关 WSGI 的背景,以及和应用服务器的集成,请阅读第四章。
设置开发环境
开发和发布环境是 App Engine 服务的一个组合,可以下载一个 SDK 到你的工作站上。 Google App Engine 需要一个账号来绑定环境,就像 Google Docs 和 Gmail 一样。你可以在 http://code.google.com/appengine上注册和获取 SDK 。按照下面的步骤开始吧 。
dev_appserver.py –help
appcfg.py –help
现在你已经做好编写和管理 App Engine 工程的准备了!
Hello, World!
App Engine 应用在本地文件系统中的组织方式和上传到 Google 服务器后的组织方式是一样的。一个工程至少要包含有一个 Python 程序文件和一个 YAML 文件,用来告诉 Web 服务器如何运行,以及如何响应用户的请求。
什么是 YAML ? YAML 是一种用于配置文件、存储和网络消息的跨语言、用户友好的数据序列化语言。 YAML 容易为人所阅读,而且比 XML 消耗更少的资源。“ YAML ”代表“YAML Ain’t a Markup Language,”,可以从 http://yaml.org 上找到更多的信息。
创建一个名为greetingprogram的目录,并在其中生成一个greeting.py文件:
Listing 1-1. greeting.py
# Greeting program
print 'Content-Type: text/plain'
print ''
print 'Hello, World!'
这个程序唯一需要提及的是需要告诉 Web 服务器响应的内容类型。在第二章和第三章中将看到如何利用 WSGI 框架,而不是每次都这样输出类型。
Listing 1-2显示了你的新应用中使用 YAML 定义的运行元信息。app.yaml是默认的,因为 Web 服务器启动的时候会搜索此文件。使用不同的文件名将触发一个AppConfigNotFoundError错误。
Listing 1-2. app.yaml
application: greetingprogram
version: 1
runtime: python
api_version: 1
handlers:
- url: /.*
script: greeting.py
打开一个系统终端,转到开发目录,输入下面的命令:
dev_appserver.py greetingprogram/
这将启动应用服务器并在控制台下显示服务器日志。greetingprogram/目录是你的开发目录,包含 Python 文件和 YAML 文件。如果没有问题的话,你可以看到下面的信息:
Running application greetingprogram on port 8080:
最后,指向浏览器中的这个地址,并验证你的 greeting 程序,如图 1-1 所示。
图 1-1 greeting.py 的输出
小结
Google App Engine 是一个运行在 Google 可伸缩基础架构上的开发面向终端用户软件服务( SaaS )的服务平台( Paa S )应用框架。 App Engine 设计得可以让只有很少 Python 和 Web 编程知识的开发者都可以很容易的书写和发布复杂的应用。 Google App Engine 简化了云应用的发布及其组件,这在其他终端应用的云计算平台上可能不稳定。
本章的程序并没有实际意义。怎样完成一个实际的项目并发布到 Web 上去呢?在第二章中将通过使用 SDK 中的开发工具来熟悉这一过程。