App Engine应用响应网络请求。当一个客户端(典型的是用户的Web浏览器)使用HTTP请求(比如获取在URL上的网页)连接上应用的时候,网络请求就开始了。当App Engine接收到请求时,它会从地址的域名中识别应用,.appspot.com子域名(为每个应用免费提供的)或你在Google Apps中已经注册创建了的自定义的子域名。App Engine从众多可能的服务中选择一个服务来处理这个请求。选择的依据是哪个服务最可能提供一个快速的响应。然后它使用Http请求的内容调用应用,从应用中获取响应的数据,并且将响应返回给客户端。

从应用的角度看(perspective),这个运行时环境在请求处理开始的时候存在(spring into existence),在请求处理结束时消失。App Engine提供了几种在请求之间保存数据的方法,但是这些机制在运行时环境之外存在(live outside of the runtime environment)。在运行时环境中请求之间的状态不保留,或者至少不希望在请求之间保留状态,App Engine可以在众多的需要用的服务间分发流量来给予每个请求相同的对待,而不管它一次处理的流量是多少。

从全局来看(in the complete picture),App Engine 允许运行时环境在请求处理之后还存在,并且尽可能地重用环境来避免不必要的初期化。你的应用的每个实例都拥有本地内存来缓存导入的代码和初期化的数据结构。App Engine会按需创建或销毁实例来适应你的应用的流量(traffic)。如果你允许多线程的特性,那么一个实例可以充分利用它的资源并发地处理多个请求。

传统意义上,应用代码不能访问运行它的服务器。一个应用可以从文件系统中读取它自己的文件。但是不能向文件中写,也不能读取属于其他应用的文件。应用可以看到App Engine设置的环境变量,这些变量的操纵在请求之间没有必要继续存在。尽管应用可以使用服务来执行网络操作,但是应用不能访问服务器硬件的网络设备。

总之,每个请求存在于它自己的沙箱中。这允许App Engine使用最快的响应服务器来处理这个请求(估算的)。对于我们的向这个应用发出的请求,无法保证同一个应用实例来处理两个请求,尽管这些请求来自于同一个客户端并且都相对很快地到达了。

沙箱也允许App Engine在同一个服务器上运行多个应用而不会出现一个应用影响另一个应用。除了限制对操作系统的访问,运行时环境也限制了时钟的数量以及一个请求可以得到的内存。App Engine使得这些限制有伸缩性,并且对应用使用了更严格的限制,防止应用耗尽资源来保护共享资源。

一个请求处理器(request handler)最多有60秒(up to 60s)的时间将响应返回给客户端。尽管看上去对于一个Web应用来讲这是相当多的,但是App Engine还是会优化应用使其响应时间小于1秒。并且(also),如果一个应用使用了很多的CPU周期的话,App Engine 可能会使它慢下来,那么在提供多个应用的机器上这个应用不会强占处理器(processor)。对于一个CPU密集型的请求处理器,如果它需要很多的处理的话会使用比本来更多的时钟时间(clock time)。当App Engine侦查出CPU的使用方式时时钟时间会响应地改变,分配。(A CPU-intensive request handler may take more clock time to complete than it would if it had expensive use of the processor,and clock time may vary as App Engine detects patterns in CPU usage and allocates accordingly)

Google App Engine为应用提供了三种可用的运行时环境:Java 环境,Python环境,Go环境(Google开发的新的系统语言)。你选择的环境取决于你开发应用使用的语言和相关的技术。

Java环境在Java 6 VM上运行应用。一个应用可以使用Java语言开发,或者大部分其他的可以在JVM上编译或运行的语言,比如PHP(使用Quercus),Ruby(使用JRuby),JavaScript(使用Rhino 解释器),Scala,Groovy和Clojure。应用使用基于Web工业标准的接口访问环境和服务,包括Java Servlets和Java Persistence API (JPA)。任何在沙箱约束中起作用的Java技术都可以在App Engine中运行,使得许多存在的框架和库适用于它。尤其是,App Engine完全支持Google Web Tookit(GWT),一个富Web应用程序框架,使我们可以用Java语言写所有的应用代码(包括在浏览器中运行的用户接口),并且使富图形应用能够在绝大多数浏览器上工作而不需要插件。

Python环境运行由Python2.7编程语言编写的应用,使用自定义的CPython版本,官方的Python解释器。App Engine使用WSGI调用Python 应用,一个广泛使用的应用接口标准。应用可以使用大部分Python的大型的杰出的标准库,以及访问服务和模型数据(modeling data)的富APIs和库。许多开源的Python web应用框架和App Engine一起工作,比如Django,web2py,Pyramid,Flask。App Engine 甚至有一个自己的叫做webapp的轻量级的框架。

这三个运行时环境使用相同的应用服务模型:一个请求路由到app server,应用实例初期化(必要的话),应用代码被调用来处理这个请求,生成响应,响应返回客户端。每个环境都在沙箱约束中运行应用代码,所以任何使用语言本身或某个库来访问沙箱以外的东西都会返回一个错误。

你可以配置实例的创建、销毁和初期化的任何一个方面。如何配置应用取决于花费与性能之间的平衡点。如果倾向于性能,就可以多配置一些运行的实例。开启多个实例处理需要。如果预算有限就调整限制,使用最少的实例来控制请求的排队等候。(if you have a limited budget,you can adjust the limits that control how requests queue up to use a minimum number of instances)

现在还没有说到任何关于App Engine使用的操作系统和硬件配置。有办法知道一个服务器使用的操作系统和硬件,不过这是没有必要的:运行时环境是操作系统之上的一个抽象。允许App Engine管理资源的分配、计算、请求处理、规模扩大(scaling)、负载分布而没有应用的参与。那些需要用到操作系统的特性是由运行环境之外的服务提供,由标准库的调用来提供或仿真,或者在沙箱的定义中以理智的方法(in sensible way)限制。

上述内容描述了App Engine会根据应用的流量动态地分配应用实例来扩展。你也可以在指定的手动分配的实例上运行代码,这些实例就是backends(or simply,"servers")。这些指定的实例十分适合于后台作业和自定义服务,有它们自己的参数来执行代码(have their own parameters for how they execute code)。然而它们不会自动扩展(scale)。当达到了一个服务器的容量时,它根据你的代码来决定下面怎么做。Backends是App Engine的一个新特性,这个体系结构正在演化。在这个版本的书中不会详细谈及这个特性。

运行时环境(The Runtime Environment)的更多相关文章

  1. 编译器设计-RunTime运行时环境

    编译器设计-RunTime运行时环境 Compiler Design - Run-Time Environment 作为源代码的程序仅仅是文本(代码.语句等)的集合,要使其活动,它需要在目标计算机上执 ...

  2. java 常用类库:操作系统System类,运行时环境Runtime

    System类: System 类代表Java程序的运行平台,程序不能创建System类的对象, System类提供了一些类变量和类方法,允许直接通过 System 类来调用这些类变量和类方法. Sy ...

  3. Java运行时环境---内存划分

    背景:听说Java运行时环境的内存划分是挺进BAT的必经之路. 内存划分: Java程序内存的划分是交由JVM执行的,而不像C语言那样需要程序员自己买单(C语言需要程序员为每一个new操作去配对del ...

  4. Java中Error和Exception的异同以及运行时异常(Runtime exception)与检查型异常(checked exception)的区别

    一:Error和Exception的基本概念: 首先Exception和Error都是继承于Throwable 类,在 Java 中只有 Throwable 类型的实例才可以被抛出(throw)或者捕 ...

  5. Apache Flink 分布式运行时环境

    Tasks and Operator Chains(任务及操作链) 在分布式环境下,Flink将操作的子任务链在一起组成一个任务,每一个任务在一个线程中执行.将操作链在一起是一个不错的优化:它减少了线 ...

  6. 在Linux安装ASP.NET Core运行时环境

    我使用的是Centos7 ,其它的Linux请参考微软文档   微软官方介绍文档:                                https://www.microsoft.com/n ...

  7. java 运行时环境和编译器环境

    必须要保证运行环境高于编译环境 1.编译器的环境设置 单击项目右键-> Properties -> Java Compiler -> 5或6 如果编译器的环境高于运行时环境会报错. ...

  8. Maven_运行时环境

    首先,创建一动态web工程. Src-----源码目录 build文件夹在java结构下看不出,但可以在Navigator下可以看出是个源码目录,如下图: 以下图中是运行时环境. 它其实是一组jar包 ...

  9. 教你如何检查一个函数是否为JavaScript运行时环境内建函数

    在开发过程中,对于某些API在现有的JavaScript运行时环境不支持的时候,我们大都会采用加入polyfill来解决这个问题.但有些时候我们可能需要知道现在某个API到底是否为运行时环境所原生支持 ...

随机推荐

  1. phantomjs使用说明

    phantomjs使用说明 12条评论   phantomjs实现了一个无界面的webkit浏览器.虽然没有界面,但dom渲染.js运行.网络访问.canvas/svg绘制等功能都很完备,在页面抓取. ...

  2. NDK(21)JNI的5大正确性缺陷及优化技巧(注意是正确性缺陷)

    转自 : http://www.ibm.com/developerworks/cn/java/j-jni/index.html JNI 编程缺陷可以分为两类: 性能:代码能执行所设计的功能,但运行缓慢 ...

  3. WINCE 开机自动弹USB连接窗口问题(已解决)

    平台:S3C6410+WinCE6.0 问题现像: 当启用UART0也就是COM1时,无论插没插USB线,一开机,它都会弹出个USB连接的窗口, 原因分析: 是因为在三星原版本BSP里的串口驱动上制定 ...

  4. tomcat web.xml 配置

    1<web-app> 2<error-page> 3<error-code>404</error-code> 4<location>/Not ...

  5. bzoj1564

    嗯,这是一道简单题 注意二叉搜索树的子树中序一定是连续的 又因为取值修改是任意的并且修改代价与权值无关 不难想到把权值离散化,然后按找数据值排序,然后dp f[i][j][w]表示从i~j的节点构成一 ...

  6. mssql修改链接数为默认值

    EXEC sys.sp_configure N'show advanced options', N'1'  RECONFIGURE WITH OVERRIDE GO EXEC sys.sp_confi ...

  7. BZOJ2229: [Zjoi2011]最小割

    题解: 真是一道神题!!! 大家还是围观JZP的题解吧(网址找不到了...) 代码: #include<cstdio> #include<cstdlib> #include&l ...

  8. (任寒韬)WebApp群主 - MobileTech 资料

    web app : http://www.lightapp.cn/brand/index/4101 https://github.com/jtyjty99999/mobileTech/blob/mas ...

  9. codeforces 340C Tourist Problem(简单数学题)

    题意:固定起点是0,给出一个序列表示n个点,所有点都在一条直线上,其中每个元素代表了从起点到这个点所走的距离.已知路过某个点不算到达这个点,则从起点出发,到达所有点的方案有许多种.求所有方案走的总路程 ...

  10. Raphael 目标点沿路径不断移动

    <!DOCTYPE html><html lang="en"> <head> <meta charset="utf-8" ...