Configure Logging

By default, the CA ConnectorClosed The Keyfactor CA Connector is installed in the customer environment to provide a connection between a CA and Keyfactor Command when a direct connection is not possible. It is supported on both Windows and Linux and has versions for Microsoft (Windows only) or EJBCA CAs. Client places its log files in the logs directory under the installed directory, generates logs at the Info logging level and stores logs for two days before deleting them. If you wish to change these defaults, follow the directions below for your installation type.

Understanding Log Files

Log files by default are generated using the following layout:

  • Timestamp: The date and time the log was generated, in ISO 8601 extended format.

    Example: 2025-07-30 12:37:48.0517
  • Correlation ID: A randomly generated GUID that identifies all log messages from a single request. It typically appears immediately after the timestamp.

    Example: 3443C462-1AC7-40FA-9FF6-4554B0F761BC

    The correlation ID appears at all logging levels.

  • Logger Name: The fully qualified class or namespace where the log message originated. Useful for filtering or tracing specific components.

    Example: CAConnector.HubListener
  • Log Level: Indicates the severity of the message—ranging from Trace and Debug (low-level detail) to Info, Warn, Error, and Fatal (critical failures).

  • Message: The main content of the log entry. This may include descriptive text, data values, or stack traces in the case of errors.

    Example: Signaled to perform job '3443c462-1ac7-40fa-9ff6-4554b0f761bc' of type 'ICertificateAuthorityClient.GetCATemplates' for CA '4' -

The above references as found in a full log entry would look like:

2025-07-30 12:37:48.0517 3443C462-1AC7-40FA-9FF6-4554B0F761BC CAConnector.HubListener [Info] - Signaled to perform job '3443c462-1ac7-40fa-9ff6-4554b0f761bc' of type 'ICertificateAuthorityClient.GetCATemplates' for CA '4' -
Windows Installations
  1. On the Windows server where you wish to adjust logging, open a text editor (e.g., Notepad) using the “Run as administrator" option.
  2. In the text editor, browse to open the Nlog.config file for the CAClosed A certificate authority (CA) is an entity that issues digital certificates. Within Keyfactor Command, a CA may be a Microsoft CA or a Keyfactor gateway to a cloud-based or remote CA. Connector Client. The file is located in the install directory, which is the following directory by default:

    C:\Program Files\Keyfactor\Keyfactor CA Connector

  3. Your Nlog.config file may have a slightly different layout than shown here, but it will contain the four fields highlighted in Figure 693: CA Connector Client on Windows NLog.config File. The fields you may wish to edit are:

    • The path and file name of the active CA Connector Client log file, by default (based on the default install location):

      fileName="C:\Program Files\Keyfactor\Keyfactor CA Connector\logs\CA_Connector_Log.txt"
      Important:  If you choose to change the path for storage of the log files, you will need to create the new directory (e.g., D:\ConnectorLogs) and grant the service account under which the CA Connector Client is running full control permissions on this directory.
    • The path and file name of previous days' CA Connector Client log files, by default (based on the default install location):

      archiveFileName="C:\Program Files\Keyfactor\Keyfactor CA Connector\logs\CA_Connector_Log_Archive_{#}.txt"

      The CA Connector Client rotates log files daily and names the previous files using this naming convention.

    • The number of archive files to retain before deletion.

      maxArchiveFiles="2"
    • The level of log detail that should be generated and output to the log file:

      name="*" minlevel="Info" writeTo="logfile"

      The default Info level logs error and some informational data but at a minimal level to avoid generating large log files. For troubleshooting, it may be desirable to set the logging level to Debug or Trace. Available log levels (in order of increasing verbosity) are:

      • OFF—No logging

      • FATAL—Log severe errors that cause early termination

      • ERROR—Log severe errors and other runtime errors or unexpected conditions that may not cause early termination

      • WARN—Log errors and use of deprecated APIs, poor use of APIs, almost errors, and other runtime situations that are undesirable or unexpected but not necessarily "wrong"

      • INFO—Log all of the above plus runtime events (startup/shutdown)

      • DEBUG—Log all of the above plus detailed information on the flow through the system

      • TRACE—Maximum log information—this option can generate VERY large log files

<variable name="logDirectory" value="logs/"/>
<variable name="JobId" value="${uppercase:${mdlc:item=correllationToken-JobId}}" />

<targets>
   <target name="buffered_wrapper" xsi:type="BufferingWrapper" slidingTimeout="true" bufferSize="500" flushTimeout="500">
   <target xsi:type="File" name="logfile" fileName="${logDirectory}/CA_Connector_Log.txt"
      layout="${longdate} ${JobId} ${logger} [${level}] - ${message} - ${exception:format=StackTrace}"
      archiveFileName="${logDirectory}/CA_Connector_Log_Archive_{#}.txt" archiveEvery="Day" archiveNumbering="Rolling"
      maxArchiveFiles="2" archiveAboveSize="2147483648" KeepFileOpen="false" ConcurrentWrites="true"/>
   </target>
   <target xsi:type="OutputDebugString" name="String" layout="${longdate} ${logger}::${message}"/>
   <target xsi:type="Debugger" name="debugger" layout="${longdate} ${logger}::${message}"/>
   <target xsi:type="Console" name="console" layout="${logger} ${message}"/>
   <target xsi:type="EventLog" name="eventLog" source="CoreTest2"
      eventId="${event-properties:item=eventID}" category="${event-properties:item=categoryID}" layout="${event-properties:item=message}" />
</targets>
<rules>
   <logger name="*-EVENT" minlevel="Info" writeTo="eventLog" final="true" />
   <logger name="*" minlevel="Trace" writeTo="logfile">
      <filters defaultAction="Log">
         <when condition="starts-with('${logger}', 'Keyfactor.ServiceCollection.Extensions') and level &lt; LogLevel.Error" action="Ignore"/>
         <when condition="contains('${logger}', 'HttpClient') and level &lt; LogLevel.Warn" action="IgnoreFinal"/>
      </filters>
   </logger>
</rules>

Figure 693: CA Connector Client on Windows NLog.config File

Linux Installations
  1. On the CA Connector Client machine where you wish to adjust logging, open a command shell and change to the directory in which the CA Connector Client is installed. By default this is /opt/keyfactor/ca-connector.
  2. In the command shell, change to the directory in which the CA Connector Client is installed.
  3. Using a text editor, open the nlog.config file in the root of the installation directory. Your nlog.config file may have a slightly different layout than shown here, but it will contain the five fields highlighted in the below figure. The fields you may wish to edit are:

    • The path and file name of the active CA Connector Client log file, by default (based on the default install location):

      fileName="/opt/keyfactor/ca-connector/logs/CA_Connector_Log.txt"
      Important:  If you choose to change the path for storage of the log files, you will need to create the new directory (e.g., /opt/kyflogs) and grant the service account under which the keyfactor-ca-connector-default service is running full control permissions on this directory.
    • The path and file name of previous days' CA Connector Client log files, by default (based on the default install location):

      archiveFileName="/opt/keyfactor/ca-connector/logs/CA_Connector_Log_Archive_{#}.txt"

      The CA Connector Client rotates log files daily and names the previous files using this naming convention.

    • The number of archive files to retain before deletion:

      maxArchiveFiles="2"
    • The level of log detail that should be generated and output to the log file:

      name="*" minlevel="Info" writeTo="logfile"

      The default Info level logs error and some informational data but at a minimal level to avoid generating large log files. For troubleshooting, it may be desirable to set the logging level to Debug or Trace. Available log levels (in order of increasing verbosity) are:

      • OFF—No logging

      • FATAL—Log severe errors that cause early termination

      • ERROR—Log severe errors and other runtime errors or unexpected conditions that may not cause early termination

      • WARN—Log errors and use of deprecated APIs, poor use of APIs, almost errors, and other runtime situations that are undesirable or unexpected but not necessarily "wrong"

      • INFO—Log all of the above plus runtime events (startup/shutdown)

      • DEBUG—Log all of the above plus detailed information on the flow through the system

      • TRACE—Maximum log information—this option can generate VERY large log files

<variable name="logDirectory" value="logs/"/>
<variable name="JobId" value="${uppercase:${mdlc:item=correllationToken-JobId}}" />

<targets>
   <target name="buffered_wrapper" xsi:type="BufferingWrapper" slidingTimeout="true" bufferSize="500" flushTimeout="500">
   <target xsi:type="File" name="logfile" fileName="${logDirectory}/CA_Connector_Log.txt"
      layout="${longdate} ${JobId} ${logger} [${level}] - ${message} - ${exception:format=StackTrace}"
      archiveFileName="${logDirectory}/CA_Connector_Log_Archive_{#}.txt" archiveEvery="Day" archiveNumbering="Rolling"
      maxArchiveFiles="2" archiveAboveSize="2147483648" />
   </target>
   <target xsi:type="OutputDebugString" name="String" layout="${longdate} ${logger}::${message}"/>
   <target xsi:type="Debugger" name="debugger" layout="${longdate} ${logger}::${message}"/>
   <target xsi:type="Console" name="console" layout="${logger} ${message}"/>
   <target xsi:type="EventLog" name="eventLog" source="CoreTest2"
      eventId="${event-properties:item=eventID}" category="${event-properties:item=categoryID}" layout="${event-properties:item=message}" />
</targets>
<rules>
   <logger name="*-EVENT" minlevel="Info" writeTo="eventLog" final="true" />
   <logger name="*" minlevel="Trace" writeTo="logfile">
      <filters defaultAction="Log">
         <when condition="starts-with('${logger}', 'Keyfactor.ServiceCollection.Extensions') and level &lt; LogLevel.Error" action="Ignore"/>
         <when condition="contains('${logger}', 'HttpClient') and level &lt; LogLevel.Warn" action="IgnoreFinal"/>
      </filters>
   </logger>
</rules>

Figure 694: CA Connector Client on Linux NLog.config File