Adeptia Connect logs several types of messages during the execution of a service (for example, a Process Flow) to help you monitor and troubleshoot the application. Message logging is done at four levels: ERROR, NOTICE, INFO, and DEBUG. The NOTICE log level captures all the notable events in the application including the error messages. For example, the Cluster and Queue Processor component log messages at the NOTICE log level.
Info |
---|
Adeptia recommends to set the log level to NOTICE for logging messages. |
The following sections describe the types of logging, benefits and constraints, logging configuration, and configurable properties.
There are two types of logging that Adeptia Connect supports.
Info |
---|
By default, Asynchronous logging is enabled in Adeptia Connect. Click here to get more details. |
Anchor |
---|
| Synchronous logging |
---|
| Synchronous logging |
---|
|
Synchronous logging
In Synchronous logging, the application logs the messages as and when there is one to be logged and execution of the service is put on hold until the complete message is written in the log. For example, If there are three error messages generated during a Process Flow execution, the execution proceeds to the next stage only after these three error messages are logged. The same execution thread is used for logging also which leads to a stalled execution of the service for the time while the messages are being logged.
Anchor |
---|
| Asynchronous logging |
---|
| Asynchronous logging |
---|
|
Asynchronous logging
In Asynchronous logging, the logging happens in a thread that is separate from the service execution thread. This leads to an uninterrupted execution of the service as it does not need to wait for the logging to be completed. An effective logging mechanism depends on two key factors, low latency and maximum throughput.
- Latency: Time taken for performing the action and producing the result.
- Throughput: The number of actions executed per unit of time.
Info |
---|
Adeptia Connect recommends that you use asynchronous logging to substantially improve the throughput and lower the latency in the overall execution of the service. |
Anchor |
---|
| Benefits and constraints |
---|
| Benefits and constraints |
---|
|
Benefits and constraints of Asynchronous logging
Asynchronous logging benefits a user in terms of achieving lower latency and maximum throughput.
- Maximum throughput: With an asynchronous logger, it can log messages at a higher rate in comparison to synchronous logger.
- Lower latency: As the logging occurs in a separate thread, it significantly lowers the latency to the minimum in the overall execution of the service.
Although asynchronous logging can give significant performance benefits, it has the following limitations to take into account:
Anchor |
---|
| Logging configuration |
---|
| Logging configuration |
---|
|
Logging configuration
Logging parameters are pre-configured in the application. However, if you want to update the configuration parameters, you can follow the steps below to navigate to the Asynchronous logging properties window and update the properties:
- Click Configure > Developer Studio.
- Click Proceed.
- On the Connect Server home page, click Administer tab.
- Go to Setup menu and select the Application Settings option.
- Click Update System Properties.
Navigate to Systems > Asynchronous Logging.
Info |
---|
Setting the abpm.log4j.async.logging.enable property to false changes the logging to be in Synchronous mode. By default, this property is set to true. You can also update the rest of the listed properties based on your requirements. |
Anchor |
---|
| Configuring properties |
---|
| Configuring properties |
---|
|
Configuring properties
If required, you can configure the logger properties in server-configure.properties file. Follow the steps below to perform this action:
- Go to …<ConnectServerInstallFolder>\AdeptiaServer\ServerKernel\etc location.
- Open server-configure.properties file.
The following table contains the list of properties which are configurable:
Property | Description | Possible value |
---|
log4j.logger.root | To include the location in the appenders (Console, jdbc. etc.). | true or false |
log4j.logger.Event | Events logging level | ERROR, NOTICE, INFO, and DEBUG |
log4j.logger.runtime | Runtime logging level | ERROR, NOTICE, INFO, and DEBUG |
log4j.logger.audit | Audit logging level | ERROR, NOTICE, INFO, and DEBUG |
log4j.logger.system | System logging level | ERROR, NOTICE, INFO, and DEBUG |
abpm.log4j.async.logging.enable | Enable/disable asynchronous logging in the application. | true or false |
log4j2.asyncLoggerExceptionHandler | Name of a class that will be notified when an exception occurs while logging the messages. | Name of the class. For example, com.adeptia.indigo.logging. AsyncLoggerExceptionHandler. |
og4j2.asyncLoggerRingBufferSize | Size (number of slots) in the RingBuffer used by the asynchronous logging subsystem. | Minimum size = 128. Maximum size = Based on your requirements. |
log4j2.asyncQueueFullPolicy | To drop events whose level is equal or less than the threshold level (INFO by default) when the queue is full. | Discard |
log4j2.discardThreshold | To determine which events to be dropped when the queue becomes full. This works only when 'log4j2.asyncQueueFullPolicy' property is set. | ERROR, INFO, and DEBUG |
Info |
---|
After you configure the properties, you do not need to restart the Connect Server. |