+

Search Tips   |   Advanced Search

Intelligent Management: controlling the generation of the plugin-cfg.xml file

We can override the default attribute values of the plugin-cfg.xml file that is automatically generated by the on demand router (ODR).

The following elements are formatted as com.ibm.ws.odr.plugincfg.<element>.<attributeName>, where <element> is the name of the configuration file keyword that denotes the element containing an attribute, and <attributeName> is the name of the attribute located within that element. Configure the elements as JVM system properties. To set a JVM system property on the ODR in the console, click Servers > On demand routers > on_demand_router > Java and Process Management > Process definition > Java Virtual Machine > Custom properties > New.


Config

This element starts the plug-in configuration file. It can include one or more of the following elements and attributes.

com.ibm.ws.odr.plugincfg.config.ASDisableNagle

Whether the user wants to disable Nagle's algorithm for the connection between the plug-in and the server.

The default value is false.

com.ibm.ws.odr.plugincfg.config.AcceptAllContent

Whether or not we can include content in POST, PUT, GET, and HEAD requests when a Content-Length or Transfer-encoding header is contained in the request header. We can specify one of the following values for this attribute:

  • True if the content is to be expected, and read for all requests.

  • False if the content is to be expected and read only for POST and PUT requests.

The default value is false.

The default value is true.

com.ibm.ws.odr.plugincfg.config.AppServerPortPreference

Specifies which port number is used to build URI's for a sendRedirect.

The default value is HostHeader.

com.ibm.ws.odr.plugincfg.config.ChunkedResponse

Whether the plug-in groups the response to the client when a Transfer-Encoding : Chunked response header is present in the response.

We can specify one of the following values for this attribute:

  • True if the plug-in is to chunk the response to the client when a Transfer-Encoding : Chunked response header is present in the response.

  • false if the response is not to be chunked.

The default value is false.

com.ibm.ws.odr.plugincfg.config.IISDisableNagle

Specifies to disable nagle algorithm.

The default value is false.

com.ibm.ws.odr.plugincfg.config.IISPluginPriority

Priority in which the Web server loads the plug-in. We can specify one of the following values for this attribute:

  • High

  • Medium

  • Low

The default value is High.

com.ibm.ws.odr.plugincfg.config.IgnoreDNSFailures

Specifies if the plug-in ignores DNS failures within a configuration when started. When set to true, the plug-in ignores DNS failures within a configuration and starts successfully if at least one server in each ServerCluster resolves the host name. Any server for which the host name is not resolved is marked unavailable for the life of the configuration. The host name is not resolved later during the routing of requests. If a DNS failure occurs, a log message is written to the plug-in log file and the plug-in continues initializing instead of the Web server not starting.

The default value is false.

com.ibm.ws.odr.plugincfg.config.RefreshInterval

The time interval, in seconds, at which the plug-in should check the configuration file for updates or changes. The plug-in checks the file for any modifications that occur since the plug-in configuration was loaded.

The default value is 60. In a development environment in which changes are frequent, set the time interval to less than 60 seconds. In production, set a higher value than the default, because updates to the configuration do not occur as often. If the plug-in reload is not successful, the plug-in log file contains a message, and the previous configuration is used until the plug-in configuration file successfully reloads. Refer to the plug-in log file for more information if an error occurs.

com.ibm.ws.odr.plugincfg.config.ResponseChunkSize

The plug-in file reads the response body in 64k chunks until all of the response data is read, which causes a performance problem for requests whose response body contains large amounts of data.

Use this attribute to specify the maximum chunk size to use when reading the response body. For example, Config ResponseChunkSize="N">, where N equals the chunk size in kilobytes.

If the content length of the response body is unknown, a buffer size of N kilobytes is allocated and the body is read in N kilobyte size chunks, until the entire body is read. If the content length is known, then a buffer size of either content length or N is used to read the response body.

The default chunk size is 64k.

com.ibm.ws.odr.plugincfg.config.VHostMatchingCompat

Specifies to use the port number for virtual host matching. The following values can be specified:

  • True for physically matching using the port number for which the request is received.

  • False for logically matching using the port number contained in the host header.

The default is False.

com.ibm.ws.odr.plugincfg.odrIncludeStopped

Specifies to allow the inclusion of stopped ODRs. The following values can be specified:

  • True for including stopped ODRs.

  • False for not including stopped ODRs.

The default is False.

com.ibm.ws.odr.plugincfg.config.TrustedProxyEnable

Trusted proxies. The following values can be specified:

  • True for including trusted proxies.

  • False for not including trusted proxies.

The default is False. The trusted proxies are collected from the defined trusted security proxies on the On demand router properties > On demand router settings console page.


Log

The log describes the location and level of log messages that are written by the plug-in. If a log is not specified within the configuration file, the log messages might be written to the error log.

com.ibm.ws.odr.plugincfg.log.Name

The fully qualified path to the log file to which the plug-in writes error messages.

The default value is profileRoot/logs/http_plugin.log.

com.ibm.ws.odr.plugincfg.log.LogLevel

The level of detail of the log messages that the plug-in writes to the log. We can specify one of the following values for this attribute:

  • Trace. All of the steps in the request process are logged in detail.

  • Stats. The server selected for each request and other load balancing information relating to request handling is logged.

  • Warn. All warning and error messages resulting from abnormal request processing are logged.

  • Error. Only error messages resulting from abnormal request processing are logged.

  • Debug. All of the critical steps performed in processing requests are logged.

  • Detail. All of the information about requests and responses are logged.

The default value is Error.

CAUTION:

A lot of messages are logged at the trace level, which can cause the file system to fill up very quickly. Never use a trace setting in a normally functioning environment as it adversely affects performance.


ServerCluster

This element is a group of servers that are generally configured to service the same type of requests.

In the simplest case, the cluster contains only one server definition. When you define more than one server, the plug-in completes a load balance across the defined servers by using either a Round Robin or a Random algorithm. The default is Round Robin.

com.ibm.ws.odr.plugincfg.cluster.CloneSeparatorChange

Some pervasive devices cannot handle the colon character (:) used to separate clone IDs in conjunction with session affinity. This attribute tells the plug-in to expect the plus character (+) as the clone separator. We must change the server configurations so that the server separates clone IDs with the plus character as well.

The default value is false.

com.ibm.ws.odr.plugincfg.cluster.LoadBalance

The Round Robin implementation has a random starting point. The first server is selected randomly, and the Round Robin value is used to select servers from that point forward. This implementation ensures that in multiple process-based Web servers, all of the processes do not start by sending the first request to the same server.

The default load balancing type is Round Robin.

com.ibm.ws.odr.plugincfg.cluster.PostSizeLimit

The maximum number of bytes of request content allowed for the plug-in to attempt to send the request to a server. If a request is received that is greater than this size, the plug-in ends the request.

The default value is -1 bytes, which indicates that there is no limit for the post size.

com.ibm.ws.odr.plugincfg.cluster.RemoveSpecialHeaders

The plug-in adds special headers to the request before it is forwarded to the server. These headers store information about the request that the application then uses. By default, the plug-in removes these headers from incoming requests before adding the required headers.

The default value is true. If we set the attribute to false, you introduce a potential security exposure by not removing headers from incoming requests.

com.ibm.ws.odr.plugincfg.cluster.RetryInterval

An integer that specifies the length of time that elapses from the time a server is marked down to the time that the plug-in reattempts to make a connection.

The default value is 60 seconds.


Server

This element is a server instance configured to handle requests routed to it based on the routing rules of the plug-in configuration. The server element corresponds to an application server running on either the local workstation or a remote workstation.

com.ibm.ws.odr.plugincfg.server.ServerIOTimeout

Enables the plug-in to set a timeout value, in seconds, for sending requests to and reading responses from the server.

When you select a value for this attribute, consider the following:

  • It might take several minutes for a server to process a request. Setting the value of the ServerIOTimeout attribute too low might cause the plug-in to send a false server error response to the client.

  • If a value is not set, the plug-in, uses the default value to write requests to the server, and to read responses from the server until the TCP connection times out. The default value is 900.

  • For older product versions, the default value is 0. If the plug-in uses a default timeout value of 0, an error might occur.

For more information on how to configure the ServerIOTimeout attribute, see the web server plug-in configuration technote.

com.ibm.ws.odr.plugincfg.server.ConnectTimeout

Enables the plug-in to perform non-blocking connections with the application server, which are beneficial when the plug-in is unable to contact the destination to determine if the port is available or unavailable.

If no value is specified, the plug-in performs a blocking connect in which the plug-in waits until an operating system times out and allows the plug-in to mark the server unavailable. A value greater than 0 specifies the number of seconds the plug-in waits for a successful connection. If a connection does not occur after that time interval, the plug-in marks the server unavailable, and proceeds with one of the other servers defined in the cluster.

The default value is 0.

com.ibm.ws.odr.plugincfg.server.ExtendedHandShake

Used when a proxy firewall is between the plug-in and the application server. In such a case, the plug-in is not failing over, as expected.

The plug-in marks a server as stopped when the connect() ends. However, when a proxy firewall is in between the plug-in and the application server, the connect() succeeds, even though the back-end application server is stopped. This causes the plug-in to not failover correctly to other application servers.

The plug-in contains this attribute to ensure that it is started before sending the request.

The default value is false.

com.ibm.ws.odr.plugincfg.server.MaxConnections

Maximum number of pending connections to a server that flows through a Web server process at any point in time.

The default value is set to -1.

com.ibm.ws.odr.plugincfg.cluster.WaitForContinue

Whether to use the HTTP 1.1 100 Continue support before sending the request content to the application server. The default value is false. The plug-in does not wait for the 100 Continue response from the application server before sending the request content.

This property is ignored for POST requests to prevent a failure from occurring if the application server closes a connection because of a time-out.

Enable this function when configuring the plug-in to work with certain types of proxy firewalls.


Property

com.ibm.ws.odr.plugincfg.property.ESIEnable

Used to enable or disable the Edge Side Include (ESI) processor. If the ESI processor is disabled, the other ESI elements in the file are ignored.

The default value is true.

com.ibm.ws.odr.plugincfg.property.ESIMaxCacheSize

An integer specifying, in 1K byte units, the maximum size of the cache. The default maximum size of the cache is 1024K bytes (1 megabyte). If the cache is full, the first entry to be evicted from the cache is the entry that is closest to its expiration time.

com.ibm.ws.odr.plugincfg.property.ESIInvalidationMonitor

Indicates whether or not the ESI processor receives invalidations from the application server.

The default value is false.

com.ibm.ws.odr.plugincfg.property.https.keyring

Use this element to specify the initialization parameters when the protocol of the transport is set to HTTPS.

This attribute is a supported name that is recognized by the transport. The default value for the keyring element is profileRoot/etc/plugin-key.kdb.

com.ibm.ws.odr.plugincfg.property.https.stashfile

The default value for the stash file is profileRoot/node/etc/plugin-key.sth

com.ibm.ws.odr.plugincfg.property.PluginInstallRoot

Installation path for the plug-in. The default value is "". Set the value, however, to the fully qualified path of the plug-in installation root, or the property is not displayed in the plugin-cfg.xml file.


plugin-cfg.xml file generation considerations

To generate HAPluginCfgGeneration definitions on demand:

  1. Disable automatic generation. Set the cell custom property ODCPluginCfgDisabled_<genDefID> to true.

  2. To generate a new plug-in, run this command:
    <WAS_HOME>/bin/wsadmin.sh -lang jython -f <WAS_HOME>/bin/manageODC.py generateHAPluginCfgs
    <generationDefinitionIDs> <nodeName> <serverName>
    where:

    generationDefinitionIDs

    is a list of HAPluginCfgGeneration IDs separated by commas of the form ODCPluginCfg_<genDef>.

    nodeName

    is the name of the node that performs the generation.

    serverName

    is the process name that performs the generation. Any Intelligent Management augmented process can generate the HAPluginCfgs configuration on demand, except for XDAGENT processes. For example:
    <WAS_HOME>/bin/wsadmin.sh -lang jython -f <WAS_HOME>/bin/manageODC.py generateHAPluginCfgs
    ODCPluginCfg_1,ODCPluginCfg_2 dmgrNodeName dmgr

To limit how often the HAPluginCfgGeneration definitions are regenerated, set the cell custom property ODCPluginCfgMinGenerationDelay with a value that represents the time in minutes between possible generations. For example:

The configured HAPluginCfgGeneration definitions are regenerated every 10 minutes at the most. If the generator receives notification to rebuild the pluginCfgs, it delays the generation of pluginCfgs written within the last 10 minutes.

To limit how often an ODR generated plugin-cfg.xml file is regenerated, set the JVM property com.ibm.ws.odr.plugincfg.minGenerationDelay to a value that represents the time in minutes between possible generations and then cycle the ODR.

By default, the configured static runtime weight value is used to include stopped ODR processes in a generated plugin-cfg.xml file.

To include stopped ODR processes in a generated plugin-cfg.xml file based on the current runtime weight value (always 0), configure the following settings:


Related concepts

  • Overview of request flow prioritization


    Related tasks

  • Configure an ODR to dynamically update the web server plug-in configuration
  • Create ODRs
  • Route requests directly from a web server to a back-end application server


    Related information:

    Webserver Plugin configuration