【译】resin4.0 API——resin.xml

        原文:http://caucho.com/resin-4.0/admin/config-resin-xml.xtp#Resourcesdatabasesqueuescachesandcustom

       resin中,所有的用户自定义配置都配在resin.xml里。resin.xml概要着重描述了资源,集群,域名映射与URL映射控制,以及习惯性配置。


目录

 1.    概念和命名约定

 2.    resin.xml概要

 3.    默认配置:服务默认配置,集群默认配置,web应用默认配置

 4.    服务:一个JVM实例

 5.    监控(watchdog):保护服务

 6.    集群:执行共同任务的多个服务

 7.    host:HTTP虚拟host

 8.    Web应用:HTTP/Servlet应用(即静态或动态的应用)

 9.    Rewrite:控制URL映射

10.   负载均衡:用于对多个后端服务器负载均衡

11.  日志:JDKjava.util.logging

12.  resource:数据库,队列,缓存

13.  健康:监控,操作,与报告

14.  安全:身份验证与权限约束


1.      概念和命名约定

·cluster(集群)-   一个集群包含多个server。

·environment(环境)  -   应用的(原文是独立类加载环境 insolated class-loader contexts)的上下文,即应用享有的资源。server,host,web-app是最主要的环境。

·host - 一个HTTP虚拟host

·proxy cache(代理缓存) -   HTTP代理缓存(译注:收到请求之后,检查本地的缓存来确定是否要向后端服务器发起请求,向后端发起请求并收到回复的情况下,把响应回复又缓存在本地。类似nginx)

·resource(资源)- 应用可使用的驱动或服务。含:JNDI,CDI,JMS队列,习惯性CDI配置。resin特有的资源含:安全,身份验证,健康检测和重定向/URL映射系统。

·rewrite/dispatch(重定向/调度)  -   定向HTTP请求到servlet和相应响应代码。类似于使用apache的mod_rewrite进行URL地址的重定向。

·server(服务)  -    一个Resin JVM实例。一台机器上可以有多个server。

·watchdog(监控)   -   一个用于监控Resin server的JVM实例,它可以在它认为有必要的时候自动重启server。

·web-app (web应用)– 一个HTTP web应用,里面包含了servlet。

2.      resin.xml概要

例:

<resinxmlns="http://caucho.com/ns/resin" xmlns:resin="urn:java:com.caucho.resin">

  <cluster-default>         

    <!-- shared configuration across allclusters -->

    <resin:importpath="classpath:META-INF/caucho/app-default.xml"/>

    <resin:importpath="${__DIR__}/health.xml" optional="true"/>

  </cluster-default>         

  <cluster id="my-cluster">

    <server-default>

      <!-- thread limits, JVM config,keepalives, ports, HTTP -->

      <http port="8080"/>

    </server-default>

    <server id="server-a"address="192.168.1.10" port="6800"/>

    <server id="server-b"address="192.168.1.11" port="6800"/>

    <host id="www.myhost.com"root-directory="hosts/myhost.com">

    <resin:MovedPermanentlyregexp="/old-file" target="/new-path"/>
   
    <web-app-deploypath="webapps"
           expand-preserve-fileset="WEB-INF/work/**"/>
      <web-app id="/custom">

      </web-app>
 
    </host>
  
  </cluster>

</resin>

<cluster>是server,host,以及通用资源的容器。cluster中的server共用它的配置。

3.      默认配置:服务默认配置,集群默认配置,web应用默认配置(server-default,cluster-default, web-app-default)

想给一组server配一些默认项,比如最大线程数,http端口号时,你可以把这些公共的配置放在<server-default>中。类似的,对于cluster,virtual-host或web-app-default,你可以用<cluster-default>,<host-default>和<web-app-default>去管理这些公共配置。

以下例子中,用<cluster-default>和<resin:import>来管理公共web-app配置,且health-system的配置也通用于所有的cluster。

例子:

<resinxmlns="http://caucho.com/ns/resin" xmlns:resin="urn:java:com.caucho.resin">

  <cluster-default>

    <resin:importpath="classpath:META-INF/caucho/app-default.xml"/>
   
    <resin:importpath="${__DIR__}/health.xml" optional="true"/>

  </cluster-default>

  <cluster id="my-cluster-a">

    ...

  </cluster>

  <cluster id="my-cluster-b">
    ...
  </cluster>

</resin>  

4.      服务:一个JVM实例

详细配置见serverconfiguration。

一个<server>标签配置cluster中的一个JVM实例。一个server的独立配置不通用于整个集群配置。watchdog根据<server>标签的内容去启动一个Resin JVM,<server>标签中也配置JVM参数。

·  server id 用于标识一个server。

·  局域网IP地址和端口用于和server交互

·  JVM参数,比如-Xmx

·  线程配置如thread-idle-min和thread-idle-max

·  TCP端口(含HTTP端口)的超时时间和cluster端口

·  负载均衡配置,包含负载比重和超时时间

·  使用Unix setuid的用户名和用户组名,保证安全性

<server>配置了cluster中的servers,server使用 --elastic-server和--cluster command-line 启动,server们共享cluster中的<server-default>配置。

5.      监控(watchdog):保护服务

watchdog监控Resin server的JVM实例,当实例出错的时候,watchdog会自动重启它。watchdog承担为server设置JVM参数的工作,打印日志,处理Unix的setuid。

6.      集群:执行共同任务的多个服务

详细配置说明见:clusteringconfiguration

一个Resin集群包含一组执行共同任务的server,比如说提供HTTP请求服务,负载均衡,或处理JMS队列。每个的server都会属于某个cluster。即使只有一个server,也会隶属于一个cluster。

server共同的任务会被配置在cluster中,无论是传统的HTTP请求,JMS队列或是SOA型的服务。HTTP类型的服务需要特别配置<host>标签,而重定向系统,非HTTP类服务可以使用CanDI型配置。

例子:http servlet的cluster配置

<resinxmlns="http://caucho.com/ns/resin">

  ...

  <cluster id="http">

    <server id="a"address="192.168.1.10" port="6800">

      <http port="8080"/>

    </server>

    <host id="">

      <web-app-deploypath="webapps"

          expand-preserve-fileset="WEB-INF/work/**"/>

    </host>

  </cluster>

</resin>

一个resin cluster也可以用作非HTTP资源。Resin会管理JVM生命周期,watchdog自动重启,系统健康检查以及cluster交互。当然服务也会受自身代码的操纵管理。(废话)

例子:非http servlet的cluster(原文是cluster for httpservlets,应该有问题,此处是non-http配置)

<resinxmlns="http://caucho.com/ns/resin"  xmlns:myservice="urn:java:com.mycom.myservice">

 ...

 <cluster id="http">

    <server id="a"address="192.168.1.10" port="6800"/>

    <myservice:MyServiceaddress="${resin.address}">

      ... <!-- CanDI configuration for theservice -->

    </myservice:MyService>

 </cluster>

</resin>

<cluster>标签形成了一个class-loader资源环境,这个资源可以被所有的host和server中的所有web-apps共享。公共的CDI资源如数据库,队列和缓存可以配置在cluster中,则可以被整个环境所访问。

7.      host:HTTP虚拟host

详细配置见:virtualhost configuration

用<host>标签可以配置一个HTTP虚拟host。host的名字用id或host-name属性标识。名字为空的host,如id=””这样的是默认host。

host可以专门用<host>标签配置,也可以用<host-deploy>标签隐式配置。host们共享<host-default>中的公共配置。<host-deploy>中包含一个隐式定义的host的目录,比如说”webapps”目录用于<web-app-deploy>。

<host>标签映射一个HTTP url到一个虚拟host上。这个host可以对应一个或多个<web-app-default>、<web-app>、<web-app-deploy>中的web-app。

对于cluster来说,<host-deploy>可以当做命令行部署的目的地。所有cluster中的server可以继承拓展命令行部署的host。

因为host可定义环境资源,因此它可以定义共享资源如数据库,缓存,CDI服务和队列。host也可以定义URL映射规则。

8.      Web应用:HTTP/Servlet应用(即静态或动态的应用)

详细配置见:deployconfiguration

一个web-app是一个基于http请求的应用,用servlet来处理请求。web-apps可以在WEB-INF/web.xml和WEB-INF/resin-web.xml中配置。一般用my-web-app.war这样的文件部署或者通过命令行以集群的形式部署,也可以把它按一个文件夹的形式放在webapps目录下。

在resin.xml配置文件中,web-app可以用<web-app>配置在<host>中或用<web-app-deploy>标签的形式隐式配置。web-app共享<web-app-default>中的公共配置。<web-app-deploy>指定一个webapps目录。

web-app标签的范围内也可放置资源环境,我们可以放置共享资源如数据库,缓存,CDI服务和队列。host也可以定义URL映射规则。

9.      Rewrite:控制URL映射

详细配置见:rewrite/dispatchconfiguration

如果URL需要做变动或想要更美观的URL,你需要控制URL格式或映射URL,resin的rewrite标签可以帮到你。rewrite的功能类似于Apache的mod_rewrite,同时也集成了resin的HTTP和servlet映射功能。

举个例子, wiki需要改变易读URL(readable URL)为servlet可识别的URL来读取参数。以下例子中服务允许接收*.php,*.gif等后缀的URL请求,所有的请求都可以对应到一个页面。它同时也重定向所有其他的URL到/index.php页面。

例子:wiki的分发规则

<web-appxmlns="http://caucho.com/ns/resin"  xmlns:resin="urn:java:com.caucho.resin">

<resin:Dispatchtarget="\.(php|gif|css|png|js)"/>

<resin:Dispatch>

  <resin:IfFileExists/>

</resin:Dispatch>

<resin:Dispatchregexp="^" target="/index.php"/>
 
</web-app>

Resin的负载均衡,http代理和fast-cgi都再重定向规则里配置。这意味着你可以让HTTP请求由一个web-app处理或者一组后端服务集群处理。

例子:负载均衡

<web-appxmlns="http://caucho.com/ns/resin" xmlns:resin="urn:java:com.caucho.resin">

    <resin:LoadBalanceregexp="^/test" cluster="backend-cluster"/>

</web-app>

10.  负载均衡:用于对多个后端服务器负载均衡

详细配置说明见:loadbalancing configuration

Resin的HTTP负载均衡基于轮询机制分配后端服务器的HTTP流量,在服务器发生故障时可自动切换。负载均衡基于resin的集群,当有添加或删除server的情况时可以自动弹性处理。

负载均衡基于重定向操作,soket参数和超时标准可以在<server>中配置。它可以识别服务器是否有效,超时或过载。

例:负载均衡分发配置

<web-app xmlns="http://caucho.com/ns/resin"  xmlns:resin="urn:java:com.caucho.resin">

    <resin:LoadBalanceregexp="^/test" cluster="backend-cluster"/>
 
</web-app>

例:负载均衡超时时间配置

<resinxmlns="http://caucho.com/ns/resin" xmlns:resin="urn:java:com.caucho.resin">

<clusterid="backend-cluster>           

  <server id="a"address="192.168.1.10" port="6800">

   <load-balance-socket-timeout>60<load-balance-socket-timeout>

   <load-weight>200<load-balance-weight>

  </server>


  ...

11.  日志:JDKjava.util.logging

详细配置方法见:loggingconfiguration

Resin的日志打印基于JDK的java.util.logging。另外,watchdog会把控制台输出打印到log/jvm-server.log。

JDK的日志打印模块由两个元素构成:log handler和logger。log handler获得日志信息并处理。Resin进行基本的日志格式化并将日志保存到日志文件中。Java代码中使用JDK logger来发送信息。每一个logger都有一个名字,通常命名为java类的名字,并在日志中打印带着个名字标识的日志。比如"com.caucho.util.ThreadPool"。

通过配置,我们可以设置日志的名称和日志等级。日志等级对所有的log-handler生效,设置之后只有符合等级的日志才会被打印。因此一些handler会收到所有的日志信息,但是logger只会接受info等级的信息。

以下log-handler发送所有日志信息到JVM的控制台输出。它也接受所有info等级的日志和MyBean的finer等级日志。所以控制台输出会包含所有的info和finer日志。

例:基本日志配置

<resinxmlns:resin="urn:java:com.caucho.resin">

  <log-handler name=""level="all" path="stdout:"

               timestamp="[%y-%m-%d%H:%M:%S.%s] {%{thread}} "/>

  <logger name=""level="info"/>

  <logger name="com.foo.MyBean"level="finer"/>
  ...

</resin>


12.  resource:数据库,队列,缓存

详细配置见:database configuration

可以用标准XML语法配置所有基于java开发的resource,比如说ActiveMQ队列。Resin可以把resource注册为CDI或JNDI形式,便于应用使用。

一些常用的资源,比如数据库,Resin有专门的标签用于配置。大多数使用基于CDI的形式。

resource和web-app、host、cluster一样使用class-loader环境。因为环境之间是独立的,web-app/foo中的一个foo数据库配置不会影响web-app/bar。

CDI形式的配置是java类与XML之间的直接关联。你可以实例化Java beans,配置他们的CDI标签和属性,然后把它注入其他beans。

举个例子,以下配置配置了一个Resin集群式jcache,它可以以@Inject Named的形式注入任意一个应用。也可以说,你的应用可以使用CDI形式获取jcache实例以及其他Resin配置的实例。

ClusterCache实例在集群之间共享缓存数据。

例:jcache配置

<web-app xmlns="http://caucho.com/ns/resin"

       xmlns:resin="urn:java:com.caucho.resin"

        xmlns:ee="urn:java:ee">

  <resin:ClusterCacheee:Named="test-cache" resin:Jndi="cache/test">

   <expire-timeout>1h</expire-timeout>

  </resin:ClusterCache>       

</web-app>

13.  健康:监控,操作,与报告

详细配置方法见:healthconfiguration

Resin的健康系统持续监控服务器的健康。

·sensors(传感器):收集Resin内部状态数据。

·meters:保存传感器和JMX数据在内部数据库。

·health-checks:评估Resin系统的健康。

·actions:执行具体操作来处理Resin健康问题。如:发送邮件,收集更多细节信息,或重启服务。

·reports:对服务器历史情况生成pdf报告。

a)        健康检查

运行健康检查需要几分钟时间。期间会检查JVM状态,返回简单的响应来告知服务器的健康状态是OK,WARNING,CRITICAL或者FATAL。如果你使用Nagios管理工具,这个过程是很类似的。Resin有几项固定的健康检查项,它很直接地描述一个用户自定义健康检查。

健康检查的结果中会记录这次检查是否通过,可以设置触发动作比如说发邮件或重启服务。

在下面这个例子中,JvmDeadlockHealthCheck包含了JVM的线程死锁检测。如果检测到线程死锁,健康检查的结果将会是fatal(致命的)。MemoryTenuredHealthCheck用于检测JVM的空闲空间。如果空闲空间过小,他会强制进行一次堆垃圾回收。如果垃圾回收也失败了,则返回一个critical结果。

例:健康检查

<resinxmlns="http://caucho.com/ns/resin"

         xmlns:resin="urn:java:com.caucho.resin">

<cluster-default>

  <health:JvmDeadlockHealthCheck/>

  <health:MemoryTenuredHealthCheck>

   <memory-free-min>1m</memory-free-min>

  </health:MemoryTenuredHealthCheck>

</cluster-default>

</resin>

b)        健康操作

健康操作可以根据健康检查结果,JMX值或者根据定时事件触发。每分钟Resin会检测一次是否符合条件启动某个健康操作。

内置的操作有:重启,生成报告,发送邮件,收集信息比如线程快照,执行自定义的PHP页面。自定义操作也可以简单地实现。

以下例子展示了当健康检查结果是fatal或持续处于critical状态超过5分钟时对resin执行重启操作。

例:重启操作

<resinxmlns="http://caucho.com/ns/resin"

         xmlns:resin="urn:java:com.caucho.resin">

<cluster-default>

  <health:Restart>

    <health:Or>

      <health:IfHealthFatal/>

      <health:IfHealthCriticaltime="5m"/>

    </health:Or>

  </health:Restart>

... 

</cluster-default>

...

</resin>


c)        健康仪

健康仪收集每分钟的数据然后记录在内部数据库里。这些数据用于展示在/resin-admin中或者生成PDF报告。

以下两个例子来自默认的health.xml配置文件,配置中使用内部的JDK MBeans来存储JDK数据。第一个例子保存了操作系统的屋里存储数据。第二个meter每60s保存一次JIT编译时间。

例:JMX meters

<resin xmlns="http://caucho.com/ns/resin"

          xmlns:resin="urn:java:com.caucho.resin">

<cluster-default>

  <health:JmxMeter>

    <name>OS|Memory|Physical MemoryFree</name>

   <objectName>java.lang:type=OperatingSystem</objectName>

   <attribute>FreePhysicalMemorySize</attribute>

  </health:JmxMeter>

 
  <health:JmxDeltaMeter>

    <name>JVM|Compilation|CompilationTime</name>

   <objectName>java.lang:type=Compilation</objectName>

   <attribute>TotalCompilationTime</attribute>

  </health:JmxDeltaMeter>
... 

</cluster-default>

...

</resin>


d)        健康报告

PDF报告中可以自定义选择图或测量数据。每个图包含一组检测数据。比如,一个关于线程的图标可以展示JDK处于不同状态的线程数量(runnable,blocke等等),可以表现出Resin的线程池状态。

例:汇总报告

<resinxmlns="http://caucho.com/ns/resin"

         xmlns:resin="urn:java:com.caucho.resin">

<cluster-default>

  <health:MeterGraphPage>

    <name>Summary</name>

    <period>6h</period>

    <columns>3</columns>

    <graph name="RequestCount">

      <meter>Resin|Http|RequestCount</meter>

    </graph>

    <graph name="Threads">

      <meter>JVM|Thread|JVM ThreadCount</meter>

      <meter>Resin|Thread|ThreadCount</meter>

      <meter>Resin|Thread|Thread IdleCount</meter>

      <meter>JVM|Thread|JVM RunnableCount</meter>

      <meter>JVM|Thread|JVM BlockedCount</meter>

      <meter>JVM|Thread|JVM NativeCount</meter>

      <meter>JVM|Thread|JVM WaitingCount</meter>

    </graph>

</cluster-default>

</resin>


14.  安全:身份验证与权限约束

详细配置方法见:securityconfiguration

安全项可以使用CanDI型的资源或者使用servlet <security-constraints>来配置。

·autenticator(身份验证):检查用户的身份证明(密码)。

·登陆:通过HTTP/servlet验证身份并得到证明。

·constraints(权限约束):允许或不允许用户访问某些资源。

以下例子使用基本的表单登陆来保护/admin.jsp页面的访问。只有用户有admin权限才可以访问。<resin: XmlAuthenticator>配置身份验证源(基于文件)。<resin:FormLogin>配置了登陆表单。<resin:Allow>限制了可以访问的页面。

例:表单登陆验证

<web-appxmlns:resin="urn:java:com.caucho.resin">

 

  <resin:XmlAuthenticator>

    <user name="admin"

            password="{SSHA}h5QdSulQyqIgYo7BIJ3YfnRSY56kD847"

             role="user,admin"/>

  </resin:XmlAuthenticator>

 

  <resin:FormLogin>

    <login-page>/login.jsp</login-page>

    <error-page>/form_error.jsp</error-page>

  </resin:FormLogin>

 

  <resin:Allowurl-pattern="/admin.jsp">

     <resin:IfUserInRolerole="admin"/>

  </resin:Allow>


</web-app>


你可能感兴趣的:(resin,服务器,Web应用)