Google App Engine

✍ dations ◷ 2025-11-16 16:59:39 #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加密连接长期遭到防火长城的封锁。

相关

  • 鉴别诊断指的是将某个特定疾病从其他展现类似症状的疾病中区分开来。医师对病患作鉴别诊断,诊断特定的疾病,或著至少消除立即致命的情有时每个可能的病因都被称为一个鉴别诊断(例如:在评
  • 肾血流量肾血流量(Renal blood flow、RBF),在肾的生理学,是表示每单位时间输送到肾脏的血液体积。在人类中,肾脏一起接受大约心输出量(cardiac output)的22%,在一位70公斤的成年男性达<1.
  • Valentin Haüy华伦泰·阿羽依(Valentin Haüy,1745年11月13日-1822年3月19日),法国人,“盲人教育之父”。华伦泰·阿羽依的兄弟勒内·茹斯特·阿羽依,被公认为是现代矿物学的创建者。1784年,华伦
  • 中等有棘神经元中型多棘神经元(英语:Medium spiny neurons,简称MSNs),也称纹状体棘状突起投射神经元(英语:spiny projection neurons,简称SPNs)是一种特殊的丙胺基丁酸神经元(英语:GABAergic)抑制性(英
  • 法国甲组足球联赛法国足球甲级联赛(法语:Championnat de France de football Ligue 1,法语简称 Ligue 1 ,中文简称“法甲”)是法国顶级足球联赛,由法国足球协会(Fédération Française de Footbal
  • 夏季奥林匹克运动会铁人三项比赛铁人三项自2000年悉尼夏季奥运会起成为每届夏季奥运会比赛项目。因为场地的不同,铁人三项比赛没有官方的奥运会纪录Alistair Brownlee 在伦敦的铁人三项比赛中确立非官方男子
  • Cre-Lox重组Cre-Lox重组是一种用于在细胞DNA的特定位点上进行删除、插入、转座和倒位操作的位点特异性重组酶技术,其特点在于可以让DNA修改对指定的特定细胞群进行,或是使修改过程由特定
  • 索威比索威比(Arthur de Carle Sowerby,1885年-1954年),中文名字苏柯仁,父亲为在中国布道逾四十年的浸礼会教士苏道味(Arthur Sowerby)。苏柯仁在中国度过童年,能说流利中文;后来返回英国读
  • 驴蹄草驴蹄草(学名:)是一种属于毛茛科驴蹄草属的多年生草本植物,又名驴蹄菜、沼泽金盏花(Marsh Marigold)、立金花。原产于北半球的温带地区,包括欧洲的冰岛与俄罗斯北极地区,亚洲温带与北
  • 阿斯特丽德·林格伦纪念奖阿斯特丽德·林格伦纪念奖 (瑞典语:Litteraturpriset till Astrid Lindgrens minne),又译作林格伦文学奖、林格伦儿童文学奖,是由瑞典政府设立的国际儿童文学奖,目的在于纪念瑞