Google App Engine

✍ dations ◷ 2025-07-01 19:23:29 #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加密连接长期遭到防火长城的封锁。

相关

  • 哈特韦尔利兰·哈里森·“李”·哈特韦尔(英语:Leland Harrison "Lee" Hartwell,1939年10月30日-),美国凤凰城亚利桑那州立大学可持续发展学院教授,西雅图福瑞德哈金森肿瘤研究中心前总裁暨
  • 圣瓦西里主教座堂圣瓦西里主教座堂(俄语:Собор Василия Блаженного,全称 Собор Покрова пресвятой Богородицы, что на Рву,意指
  • 自治州俄罗斯自治州,其国内简称自治州(俄语:Автономная область),是俄罗斯联邦主体的其中一个类型。俄罗斯联邦目前只有一个自治州,即犹太自治州。但在苏联时期,其境内
  • 八正道八圣道分(巴利语:Ariyo aṭṭhaṅgiko maggo,梵语:Ārya aṣṭāṅga mārgaḥ),又译为八正道、八圣道、八支正道、八支圣道、八圣支道,佛教术语,是指佛教徒修行达到最高理想境地涅
  • 调性调性(Tonality)是调的主音和调式类别的总称,例如,以C为主音的大调式,其调性即是“C大调”,以a为主音的小调式,其调性就是“a小调”等。以此类推,一般音乐中主要有24个调性。
  • 美国总统纪念币美国总统1美元纪念币(Presidential $1 Coin)计划来源于美国国会109-145号法案(2005年12月22日生效)。该法案授权美国国家铸造局制造正面刻有美国总统图像的1美元纪念币。参议院
  • Never Worn WhiteNever Worn White (字面意义:“从未披上婚纱”)是美国歌手凯蒂·佩芮的一首单曲,于2020年3月5日由国会音乐集团发售。凯蒂在与歌曲同时发布的音乐录影带中宣布自己怀孕。2020年3
  • 重口裂腹鱼重口裂腹鱼(学名:),俗称雅鱼、丙穴鱼,是鲤科裂腹鱼属鱼类,原产于中国四川省雅安市周公河。重口裂腹鱼外型与鳟鱼相似,通常居住在清澈而湍急的河流之内,肉质鲜美而细嫩,当地人会以砂锅
  • 南贝富塔卡区南贝富塔卡区(马达加斯加语:Befotaka),是马达加斯加的行政区,位于该国东南部,由阿齐莫-阿齐那那那区负责管辖,首府设于贝富塔卡,面积3,097平方公里,2011年人口50,651,人口密度每平方公
  • 科拉多·基尼科拉多·基尼(Corrado Gini,1884年5月23日-1965年3月13日),意大利统计学家,人口学家和社会学家,开发出基尼系数,判断收入分配公平程度的指标。科拉多·基尼1884年出生于意大利特雷维