Google App Engine

✍ dations ◷ 2025-07-22 00:49:26 #Google服务,云端运算,被防火长城封锁的网站,2008年面世

Google App Engine是一个开发、托管网络应用程序的平台,使用Google管理的数据中心。它在2008年4月发布了第一个beta版本。

Google App Engine使用了云计算技术。它跨越多个服务器和数据中心来虚拟化应用程序。

Google App Engine在用户使用一定的资源时是免费的。支付额外的费用可以获得应用程序所需的更多的存储空间、带宽或是CPU负载。

当前,Google App Engine支持的编程语言是Python、Java、PHP和Go(通过扩展,可以支持其他JVM语言,诸如Groovy、JRuby、Scala和Clojure)。支持Django、WebOb、PyYAML的有限版本。Google说它准备在未来支持更多的语言,Google App Engine也将会独立于某种语言。任何支持WSGI的使用CGI的Python框架可以使用。框架可以与开发出的应用程序一同上传,也可以上传使用Python编写的第三方库。

与其他可扩展的托管服务(例如Amazon EC2)比较,App Engine提供了更多基础服务来方便编写可扩展的应用程序,但仅限于App Engine设计框架以内的应用程序。

App Engine的基础服务省却了许多系统管理的操作,以便将规模扩大到数以百万计的访问。Google负责处理一组代码,可以监测、容错,在必要的时候还会开发一些应用实例。

有些应用程序托管服务让用户安装、配置几乎所有*NIX兼容的软件,而App Engine则要求开发者使用Python或Java语言来编程,而且只能使用一套限定的API。当前的API允许程序于一个BigTable非关系数据库上存储和检索数据、提出HTTP请求、发送E-mail、处理图像、还有缓存。大多数现存的Web应用程序,若未经修改,均不能直接在App Engine上运行,因为它们需要使用关系数据库。

带宽和CPU的使用、送达请求的数量、并发请求的数量、以及调用各种API的次数,皆设有每天和每分钟的限额。个别的请求,如果需时超过30秒或返回超过10MB的数据,都会被终止。

Google App Engine的Datastore使用一个与SQL类似的语言,叫做“GQL”。在GQL中,SELECT语句仅可以用于一个表。因为要跨越不只一台机器, GQL不支持效率很低的JOIN语句。欲创建一对多和多对多的关系,可使用ReferenceProperty()。采用这种无共享的方式,即使磁盘坏了,系统也不致瘫痪。

在GQL中,SELECT语句中的WHERE从句只容许对仅仅一列进行>、>=、<或<=比较。所以,仅仅可以构造简单的WHERE从句。在数据建模时,要从关系数据库转换到Datastore,开发者需要转变观念。

App Engine限制每次Datastore请求最多返回1000行数据。大多数Web应用程序,都不会受此影响,因为它们通常并不会在一张页面上列出超过1000条记录(可以用分页和缓存机制),只要按顺序返回结果就可以了。若有应用程序需要在一次操作中返回更多的记录,则需自行使用客户端软件或者Ajax页面,按查询顺序提取更多条记录。

这个Datastore的API是不关联的,有别于一般关系数据库——比如IBM DB2、Microsoft SQL Server、MySQL、Oracle数据库、或者PostgreSQL。

开发者担心App Engine应用程序不能移植到其他平台上,因而被困在单一种技术(Vendor lock-in)之内。

App Engine自SDK1.2.2版开始,已容许以批量的方式下载数据。此外,用户也可使用开源项目gaebar、approcket 和gawsh 来下载、备份在App Engine上的数据。

免费帐户使用App Engine时,受配额限制。应用程序作者可以视乎需要,付钱购买更多配额。

供免费使用的配额曾于2009年5月25日 、2009年6月22日以及2011年5月三度下调。

Google App Engine与Amazon Web Services(一个应用程序服务系统,支持在Amazon的服务器上托管文件、执行代码)直接竞争。不少科技分析师早在多年前已预计过,Google会加入这场竞赛。其中,Techdirt的出版人Mike Masnick写到,“Google终于了解到它需要霸占网络平台这个地位。我们可以期待,开发及落实易于扩展的网络应用程序会变得越来越容易,而应用程序也会越来越具创意。”

此外,红帽公司的 openshift、微软的Azure服务平台以及 Koding 也是Google App Engine的竞争对手。

由于Google App Engine允许用户托管网络应用程序,且服务器不在中华人民共和国境内,故有部分用户利用其搭建代理(如GoAgent)用于突破防火长城的审查,故Google App Engine的域名 *.appspot.com 的SSL加密连接长期遭到防火长城的封锁。

相关

  • .fr.fr为法国国家和地区顶级域(ccTLD)的域名。A .ac .ad .ae .af .ag .ai .al .am .ao .aq .ar .as .at .au .aw .ax .az   B .ba .bb .bd .be .bf .bg .bh .bi .bj .bm .bn
  • 非同源性末端接合非同源性末端接合 (NHEJ) 是一种修复双股DNA断裂的方法。之所以是非同源性,是因为断裂的两段是被直接接上,而非使用了一个同源的模板。与之对比的同源性重组则需要一个同源序
  • 日本阿尔卑斯山脉日本阿尔卑斯(日语:日本アルプス/にほんアルプス nihon arupusu */?),又称中部山岳(中部山岳/ちゅうぶさんがく chūbu sangaku ?),是位于日本中部的飞驒山脉(北阿尔卑斯)、木曾山
  • 洛雷托-乌卡亚利西班牙语洛雷托- 乌卡亚利(Loreto-Ucayali)西班牙语,也称为亚马逊西班牙语(Español Amazónico)或丛林西班牙语(Español de la Selva),是亚马逊地区使用的西班牙语变体,使用者大多分布在秘
  • 真空能量真空能量(Vacuum energy)是一种存在于空间中的背景能量,即使在没有物质的空间(称为自由空间)亦然存在。真空能量导致了多数基本力的存在。它的效应可以在各式各样的实验中观测到,
  • 海王星特洛伊海王星特洛伊(是类似特洛伊小行星的小行星)是与海王星有着相同的轨道与周期的小行星,至2007年3月已经被发现了6颗。这六颗小行星是2001 QR322, 2004 UP10, 2005 TN53, 2005 TO7
  • 老约瑟夫·P·肯尼迪老约瑟夫·帕特里克·“乔”·肯尼迪(Joseph Patrick "Joe" Kennedy, Sr.,1888年9月6日波士顿 - 1969年11月18日。马萨诸塞州海厄尼斯),美国商人、政治家,美国民主党成员,曾任美国
  • 拥有拥有可以指:
  • 列夫·叶梅利亚诺维奇·弗洛德济米尔斯基列夫·叶梅利亚诺维奇·弗洛德济米尔斯基(俄语:Лев Емельянович (Эмильевич) Влодзимирский,1905年1月10日-1953年12月23日)波兰裔俄国人,是
  • 保加尔人保加尔人(保加利亚语:Прабългари)是从公元二世纪起,在欧洲不同地区定居的游牧民族,分散生活欧洲的东部和东南部地区,为巴尔卡尔人与保加利亚人、楚瓦什人、塔塔尔族的先