|  | Resin Documentationapp server | 
| resin.conf: top-level configuration
 The top-level <resin> tag contains any <cluster> defined for a deployment. It also provides an resources for class-loaders, logging and shared resources. 
 child of <resin> <cluster> configures a set of servers used for load-balancing and for sharing distributed sessions. 
 
<resin xmlns="http://caucho.com/ns/resin">
  <cluster id="app-tier">
    <server id="a" address="192.168.0.1"/>
    <server id="b" address="192.168.0.2"/>
    <host id="">
      <web-app-deploy path="webapps"/>
    </host>
  </cluster>
</resin>
 child of <resin> <cluster-default> configures common configuration for all clusters.default true By default, Resin's  <environment-system-properties> schema 
element environment-system-properties {
  r_boolean-Type
}
<jmx-service> enables the clustered JMX management. <jmx-service> schema 
element jmx-service {
  enable?
}
<log-service> enables persistent storage of warning and critical log messages in the administration. <log-service> schema 
element log-service {
  enable?
  & level?
}
<management> controls system-wide management capabilities, like the clustered JMX reporting, transaction logging, and persistence logging. It also defines a system-wide administration authenticator, providing a centralized place to manage administration identity. The <user> configuration is particularly important since it is used as a security measure for the watchdog as well as for remote JMX capabilities. 
 <management> schema 
element management {
  jmx-service?
  & log-service?
  & path
  & secure?
  & user*
}
element user {
  name
  & password
  & disable?
}
userThe <user> tags in <management> define Resin administrators for the /resin-admin service and also add security for JMX remoting and the watchdog. Since the authenticator is available to all web-apps, you can
use the <management> login as a simple security authenticator for
the entire site.  The role of the logged-in user is ,
for configuring security authentication and for the  The password field is an MD5 hash of the username and password for security.
The /resin-admin or  
 <user> schema 
element user {
  name
  & password
  & disable?
}
<resin> is the top-level configuration tag for the resin.conf file. The <resin> tag needs to specify the Resin namespace, to allow for validation of the configuration file. The environment of the top-level <resin> is the global classpath. This environment can be important for <log> configuration for threads which run with using only the global class loader. Because the <resin> environment does not have a dynamic class loader, dynamically loaded classes, like custom jars in resin/lib are not available. <resin> schema 
element resin {
  
  & cluster*
  & cluster-default*
  & environment-system-properties?
  & management?
  & min-free-memory?
  & root-directory?
  & security-manager?
  & security-provider?
  & watchdog-manager?
}
Example: minimal resin.conf 
<resin xmlns="http://caucho.com/ns/resin"
       xmlns:resin="http://caucho.com/ns/resin/core">
  <root-directory>/var/www</root-directory>
  <cluster id="web-tier">
    <server id="">
      <http address="*" port="8080"/>
    </server>
    <resin:import path="app-default.xml"/>
    <host id="">
      <web-app id="" root-directory="/var/www/htdocs"/>
    </host>
  </cluster>
</resin>
child of <resin>,<cluster>,<host>,<web-app> All Resource tags are available to the <host>, for example, resources like <database> or <authenticator>. Resources defined at the host level are available for all web-apps in the host. Example: shared database in resin 
<resin xmlns="http://caucho.com/ns/resin">
  <database jndi-name="jdbc/test">
    <driver type="org.postgresql.Driver">
      <url>jdbc:postgresql://localhost/test</url>
      <user>caucho</user>
    </driver>
  </database>
  <cluster id="app-tier">
     ...
  </cluster>
</resin>
child of <resin>,<cluster>,<host>,<web-app> <root-directory> specifies the base directory for the contexts. All EL-style directory paths are relative to the root-directory. <root-directory> schema 
element root-directory {
  r_path-Type
}
<security-manager> enables the use of the security manager for the JVM. Because the JVM security manager is very slow, we generally do not recommend enabling it for server applications. Instead, see the watchdog configuration for alternative methods for securiting the JVM in ISP configurations. <security-manager> schema 
element security-manager {
  r_boolean-Type
}
Example: enabling security-manager <resin xmlns="http://caucho.com/ns/resin"> ... <security-manager/> ... <security-provider> adds one or more security providers. Each entry specifies the name of a security provider class. The name is used to instantiate an instance of the object, which is then passed to Security.addProvider. <security-provider> schema 
element security-provider {
  string
}
Example: adding custom security providers 
<resin xmlns="http://caucho.com/ns/resin"
       xmlns:resin="http://caucho.com/ns/resin/core">
  ...
  <security-provider>
    com.sun.net.ssl.internal.ssl.Provider
  </security-provider>
  <security-provider>
    example.MyProvider
  </security-provider>
  ...
resin
 <stat-service> periodically checks the status of the server, and reports errors as necessary. 
 <stat-service> schema 
element stat-service {
  cpu-load-exit-threshold?
  & cpu-load-log-info-threshold?
  & cpu-load-log-warning-threshold?
  & cpu-load-thread-dump-threshold?
  & sample-period?
  & thread-dump-interval?
}
systemThe ${system} variable return the  Example: returning -Dfoo=bar 
<resin xmlns="http://caucho.com/ns/resin"
      xmlns:resin="http://caucho.com/ns/resin/core">
  <resin:message>${system['foo']}</resin:message>
  ...
</resin>
The <watchdog> tag is used in ISP-style configurations where the <watchdog-manager> is configured separately from the resin.conf instances, and where the configuration file is generally not readable by the instance users. The <watchdog> tag corresponds to the <server> tag in standard resin.conf configurations, and specifies the resin.conf, the root directory and resin-user. 
 <watchdog> schema 
element watchdog {
  attribute id { string }
  & chroot?
  & group-name?
  & java-exe?
  & java-home?
  & jvm-arg*
  & resin-conf?
  & resin-root?
  & open-port { address & port }*
  & user-name?
}
For ISP configurations, <watchdog-manager> is used for a separate resin.conf just to configure the watchdog-manager itself. The <watchdog-manager> selects the <user-name>, <resin-conf>, ports, and Resin home directories before giving access to the user's Resin instance. 
 <watchdog-manager> schema 
element watchdog-manager {
  watchdog*
  & watchdog-address?
  & watchdog-default*
  & watchdog-jvm-arg*
  & watchdog-port?
}
<xa-log-service> enables the transaction-manager logging. The XA log enables Resin to recover from server crashes and complete XA commits. <xa-log-service> schema 
element xa-log-service {
  enable?
}
 
 |