Google App Engine

✍ dations ◷ 2025-09-10 12:47:05 #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加密连接长期遭到防火长城的封锁。

相关

  • David Crystal大卫·克里斯托OBE FBA FLSW(英语:Fellow of the Learned Society of Wales)(英语:David Crystal,1941年7月6日-)是一位英国的语言学家、作家。他在1995年获得大英帝国勋章,并在2002
  • 质粒体色素体(英语:plastid),又称质粒体或质体,是植物、藻类、光合营性(英语:pototroph)细菌中所含有的一种囊泡,与光合作用有关。囊泡中含有菌绿素与类胡萝卜素。在紫细菌中,如紫螺菌(英语:Rh
  • 前列腺计算值前列腺计算值是前列腺前后径的平方与前列腺横径的比值;是对良性前列腺增生症患者最大尿流率评估的辅助依据。由于良性前列腺增生症患者前列腺体积与最大尿流率改变不成正比;与
  • 沙特阿拉伯货币管理局沙特阿拉伯货币局 (阿拉伯语:مؤسسة النقد العربي السعودي‎,英语:Saudi Arabian Monetary Agency, SAMA),建立于1952年,为沙特阿拉伯王国的中央银行,其职能
  • 爱国歌《爱国歌》(朝鲜语:애국가/愛國歌 Aegukka ?)是朝鲜民主主义人民共和国的国歌,歌名与韩国和朝鲜建国前的国歌相同,但旋律与歌词都不相同。为与其他版本分别,普遍称为《朝日鲜明》
  • 华盛顿·欧文华盛顿·欧文(Washington Irving、1783年4月3日-1859年11月28日),生于美国纽约州曼哈顿。是美国著名作家、短篇小说家、亦是一名律师,亦曾当过政府官员,是对西班牙及英国的外交官
  • 花钏王花钏王(梵语:चित्रांगद,IAST:Citrāngada),《摩诃婆罗多》人物,福身王与贞信之子,象城国王。花钏为一同名乾闼婆所杀,英年早逝,未留子嗣。花钏王声名远扬,一同名乾闼婆闻名而
  • 固件固件(英语:firmware),是一种嵌入在硬件设备中的软件。通常它是位于特殊应用集成电路(ASIC)或可编程逻辑器件(PLD)之中的闪存或EEPROM或PROM里,有的可以让用户更新。可以应用在非常广
  • 大橡树龙大橡树龙 ( 学名 : "" ) 是一种无效的似鸟龙类,化石发现于马里兰州的阿隆德组(英语:Arundel Formation)。理查德·斯万·卢尔(英语:Richard Swann Lull)为来自阿隆德组的腿骨碎片
  • 关陇集团关陇集团,又称关陇世族、关陇贵族、关陇门阀、武川集团。关陇集团一词由陈寅恪所创,是指北朝的西魏、北周至隋、唐期间,籍贯位于关中(今陕西省)、陇西(今甘肃省东南)的门阀世族。胡