This page applies to an earlier version of the AppDynamics App IQ Platform.
For documentation on the latest version, see the 4.4 Documentation.


On this page:

Your Rating:
Results:
PatheticBadOKGoodOutstanding!
54 rates

The Controller generates various log files you can use to troubleshoot issues with your deployment.

Controller Log Files

  • install.log: Information about events of the install process such as extraction, preparation and other post-processing tasks. It is located at <controller_home>.
  • server.log: Information for the embedded Glassfish application server used by the Controller. It is located at <controller_home>/logs.
  • audit.log: information about Account/User/Group/Role CRUD and User login/logout operations. This can be used to forward auditable events from the AppDynamics controller into a central log management system or SIEM. New in 4.1.8 It is located at <controller_home>/logs.
  • database.log: Information for the MySQL database that is used by the Controller. It is located at <controller_home>/logs.
  • installation.log: Information about the installation specific to Install4j. It is located at <controller_home>/.install4j.
    Also include the entire .install4j directory and the latest <OS_Temporary_Directory>/i4j_log*, for example /tmp/i4j_log*.
  • startAS.log: Output generated by the underlying Glassfish domain for the Controller.

Manage Log Files

The application server is preconfigured to rotate the server.log file regularly, based on settings in the domain configuration file.

For the other log files, database.log and startAS.log, you need to set up log rotation to prevent them from consuming excessive disk space. You also need to set up log rotation for an additional log file, <controller_home>/db/data/slow.log. This log contains information about slow MySQL queries.

The tool you use to perform the rotation depends on your operating system. On Linux, you can use the mysql-log-rotate script. The script is included with the Controller database installation at <controller_home>/db/support-files. You need to modify the script for your environment, since it is not set up to rotate the database.log file by default. On other systems, you need to create or install a script that performs log rotation and make sure that it get run regularly, for example, by cron or an equivalent task scheduler.

Change the default location or names of the Controller logs

  1. In a web browser, log in to the Controller's Glassfish administration console, as described in Access the Administration Console.
  2. From the left-side navigation tree, expand Configurations -> server-config and click Logger Settings.
  3. Set the new location for server.log by modifying the Log File value.
    The default value points to the logs directory located at the root of the Controller home directory.

    ${com.sun.aas.instanceRoot}/../../../../logs/server.log

     If you specify a directory that does not exist, it is created when you restart the application server.

  4. Change the database.log location by opening the <controller_home>/db/db.cnf file.

  5. Set the value of the log-error property to the new location of the database.log file. This directory location must exist before you restart the Controller or you will get start-up errors.

  6. Change the startAS.log location by opening the <controller_home>/bin/controller.sh file.

  7. Edit the log location specified in the following line to reflect the new location:

    nohup ./asadmin start-domain domain1 > $INSTALL_DIR/logs/startAS.log

     

  8. Open the <controller_home>/appserver/glassfish/domains/domain1/config/domain.xml file, and change the log location specified in the following:

    • log-root attribute of the domain element.

    • file attribute of the log-service element.

    • tx-log-dir attribute of the transaction-service element.

  9. Copy if desired any existing logs from the default directory (<controller_home>/logs) to the new location.

  10. Restart the Controller. See Start or Stop the Controller.

  11. Verify that the database.log, server.log, and startAS.log files are being written to the new location and remove the old log files.

Logging Level Granularity

The Controller logs provide information about possible errors in Controller operations. By default, the Controller writes to the log at the INFO level. When debugging your Controller deployment, you may need to increase the logging level to generate additional information.

You can set the logging level by Controller component, which include:

  • Agents
  • Business Transactions (BTS)
  • Events
  • Incidents
  • Information Points (IPS)
  • Metrics
  • Orchestration
  • Rules
  • Snapshots

Change Default Logging Level by Component

By default, the Controller generates logs at the INFO level. You can change the level for one or all of the components. This may be needed, for example, when you are debugging your system, and want the Controller to generate more information in the form of logs. On the other hand, you may wish to reduce logging verbosity to minimize the reduce the rate of growth of log files. The following steps describe how to change the default log levels.

  1. In a web browser, log in to the Controller's Glassfish administration console, as described in Access the Administration Console.
  2. From the left-side navigation tree, expand Configurations -> server-config and click Logger Settings.
  3. Click the Log Levels tab.
  4. Modify those components that start with "com.appdynamics". By sorting the list by name, you can quickly access the com.appdynamics components. For each component, modify the log level by choosing a new level from the Log Level menu. For example, to debug the system, we suggest setting the log level to FINE.
  5. Click Save.
  • No labels