...
Code Block | ||
---|---|---|
| ||
<Timestamp> ERROR [CC_Layer] LayerImpl::sendMessage2ClientId() has failed: Message cannot be sent: client TestSMTPClient is not logged in. |
Description or root cause
This message occurs when there is an attempt to send a message to a not initialized ("logged in") Client of Transport Adapter (TA). The disclosed in log record "client" name represents the name of TA Client in FIXEdge.properties.
...
Solution or troubleshooting recommendationssteps
1. First of all, review BL_Config.xml file for the Rule, that routes messages to mentioned Client, and check if it is correct and does what is required by your system. Remove the Rule if there is no need for it.
For instance, the ERROR in this specific example was caused by the default BL Rule which was left unintentionally in place:
...
Solution or troubleshooting recommendations
reconnect Reconnect the session.
New incoming connection was rejected
...
Solution or troubleshooting recommendationssteps
Contact your counter-party for an explanation from their side and related events that make bring more light on the root cause.
Error during processing Logon message
...
This is related to setup with LDAP authentication. Authentication is performed against Session identifier (SenderCompID and TrargetCompID) and LDAP using the Username (tag 553) and Password (tag 554) from FIX Logon message.
Solution or troubleshooting recommendationssteps
- Work with the counterparty to make sure that those supplied Logon credentials are correct.
- Check if credentials are correct in LDAP and any other issues with LDAP itself.
- Review and check the LDAPAuthenticate section in the BL_Config.xml file.
Unable to establish the connection (Error code = 10060)
Code Block | ||||
---|---|---|---|---|
| ||||
<Timestamp> ERROR [Engine] <Thread ID> Session <Session_Name> : Unable to establish connection: connect() to (xxx.xxx.xxx.x:xxxxx) failed. A connection attempt failed because the connected party did not properly respond after a period of time, or established connection failed because connected host has failed to respond. (Error code = 10060) |
...
- Check what application uses the port. Make sure that another copy of the application is not running.
- Modify the Listening ports in the engine.properties: ListenPort
DEBUG
...
Incorrect path to the properties file
Code Block | ||
---|---|---|
| ||
<Timestamp> DEBUGERROR [BL_RoutingTable] No OnActionFail is specified for rule for 'Rule_Name'.Engine] Unable to initialize EngineAdaptor. Reason: Please check settings: Cannot open the file "<path>". No such file or directory. |
Description or root cause
These messages usually indicate that you have a routing rule, but haven’t specified what will happen if the Rule fails.This message appears when the IncludeProperties property is specified with the non-existent path.
Solution or troubleshooting recommendations
These are not errors, just indications that the <OnActionFail> condition might be also set up.
WARN
...
steps
Change the value of the IncludeProperties property in the FIXEdge.properties file.
DEBUG
No OnActionFail is specified for the rule
Code Block | ||
---|---|---|
| ||
<Timestamp> WARNDEBUG [EngineBL_RoutingTable] Session <Session_Name>No :OnActionFail theis telecommunicationspecified linkfor errorrule was detected (Connection::receive(), EOF).for 'Rule_Name' |
Description or root cause
It means that the TCP connection was terminated unexpectedly by the counter-party, without Logouts exchangeThis message usually indicates that you have a routing rule, but haven’t specified what will happen if the Rule fails.
Solution or troubleshooting recommendations
Contact counter-party and query them for the sanity of their FIX adaptor/engine.
...
steps
This is not error, just indication that the <OnActionFail> condition might be also set up.
'StorageCreationTime' property was updated
Code Block | ||
---|---|---|
| ||
<Timestamp> WARNDEBUG [Engine] "StorageCreationTime" is updated Sessionwith <Session_Name>the : FixEngine::CreateSession(...) "MessageStorageType storageType" parameter is deprecated. Please use SessionExtraParameters::storageType instead.current date in the FIX log storage "<path to file>/<storage file name with timestamp>", because of parameter absence |
Description or root cause
...
This message indicates that 'StorageCreationTime' property was updated in log storage. This message appears
...
in case of re-using old FIX log storage with absent 'StorageCreationTime' property.
Solution or troubleshooting steps
This message can be ignored . To remove this record from the log FIX Antenna user should use the non-deprecated FixEngine::CreateSession method.
...
since it is not an error.
WARN
The telecommunication link error
Code Block | ||
---|---|---|
| ||
<Timestamp> WARN [Engine] Session <Session_Name> : sessionthe wastelecommunication createdlink inerror dangerwas mode - it does not use persistent message storage.detected (Connection::receive(), EOF) |
Description or root cause
It means that a session uses transient storage, i.e. no log files with FIX messages will be created.
Solution or troubleshooting recommendations
In FIXEdge.properties file you can turn on logging for a session by setting 'FixLayer.FixEngine.Session.<SessionName>.StorageType = persistentMM' (or persistent). For Admin Session (a session between FIXEdge and FIXICC Agent) you need to change the property Monitoring.AdminSession.AdminClient.StorageType (which is in engine.properties file) accordingly, but we don’t recommend doing this for Admin Session - there will be quite a lot of messages.
Garbled message
...
the TCP connection was terminated unexpectedly by the counter-party, without Logouts exchange.
Solution or troubleshooting steps
Contact counter-party and query them for the sanity of their FIX adaptor/engine.
"MessageStorageType storageType" parameter is deprecated
Code Block | ||
---|---|---|
| ||
<Timestamp> WARN [Engine] Session <Session_Name> : FixEngine::CreateSession(...) "MessageStorageType storageType" parameter is deprecated. Please use SessionExtraParameters::storageType instead |
Description or root cause
Some of the FIX Antenna API methods can become deprecated in the new version of the product's release. This message appears if the FIX Antenna API user creates the session with deprecated FixEngine::CreateSession API method and passes storage type not via SessionExtraParameters structure. It is recommended to pick another method for session creation.
Solution or troubleshooting steps
This message can be ignored. To remove this record from the log FIX Antenna user should use the non-deprecated FixEngine::CreateSession method.
The session was created in danger mode
Code Block | ||
---|---|---|
| ||
<Timestamp> WARN [Engine] Session Garbled<Session_Name> message: <FIX_Message> |
Description or root cause
The FIX Protocol takes the optimistic view; it presumes that a garbled message is received due to a transmission error rather than a FIX system problem. Therefore, if a Resend Request is sent the garbled message will be retransmitted correctly. If a message is not considered garbled then it is recommended that a session-level Reject message be sent.
What constitutes a garbled message:
• BeginString (tag #8) is not the first tag in a message or is not of the format 8=FIX.n.m.
• BodyLength (tag #9) is not the second tag in a message or does not contain the correct byte count.
Solution or troubleshooting recommendations
...
Parse Error: Incorrect size of a repeating group.
Code Block |
---|
Parse Error : Incorrect size of repeating group. Expected: 1. In fact: 2. Parsing stopped at column: 228 in tag N/A in message E with sequence number 979. |
Description or root cause
This error will occur if the validation option 'verifyRepeatingGroupBounds' is enabled and FIX Engine receives a message with incorrect repeating group size. In this case, the FIX message will be rejected.
Before FIX Engine version 2.28.1 (and FIXEdge version 6.11.0), this parameter was always enabled.
Solution or troubleshooting recommendations
To revert this parameter after updating to the versions stated above, this parameter should be set to false. Additionally, for FIX Engine, the field should be set to false.
Authentification service doesn't send a response in time
Code Block | ||
---|---|---|
| ||
<timestamp> WARN [LogonHandler] <thread> Session <SenderCompId, TargetCompId> : process logon failed - request is timed out |
Description or root cause
This WARN record occurs in the FixEdge.log file if FIXEdge doesn't receive a response in time.
Solution or troubleshooting recommendations
Check the incoming FIX session logs and if there are no messages User Response (BF) then the issue is on the Authentification Service side.
Cannot find the property "StorageCreationTime" in the storage
Code Block | ||
---|---|---|
| ||
<Timestamp> WARN: session was created in danger mode - it does not use persistent message storage |
Description or root cause
It means that a session uses transient storage, i.e. no log files with FIX messages will be created.
Solution or troubleshooting steps
In FIXEdge.properties file you can turn on logging for a session by setting 'FixLayer.FixEngine.Session.<SessionName>.StorageType = persistentMM' (or persistent). For Admin Session (a session between FIXEdge and FIXICC Agent) you need to change the property Monitoring.AdminSession.AdminClient.StorageType (which is in engine.properties file) accordingly, but we don’t recommend doing this for Admin Session - there will be quite a lot of messages.
Garbled message
Code Block | ||
---|---|---|
| ||
<Timestamp> WARN [Engine] Garbled message: <FIX_Message> |
Description or root cause
The FIX Protocol takes the optimistic view; it presumes that a garbled message is received due to a transmission error rather than a FIX system problem. Therefore, if a Resend Request is sent the garbled message will be retransmitted correctly. If a message is not considered garbled then it is recommended that a session-level Reject message be sent.
What constitutes a garbled message:
• BeginString (tag #8) is not the first tag in a message or is not of the format 8=FIX.n.m.
• BodyLength (tag #9) is not the second tag in a message or does not contain the correct byte count.
Solution or troubleshooting steps
Make sure that the FIX message was re-transmitted correctly. If not, contact your counterparty regarding malformed messages from their side.
Parse Error: Incorrect size of a repeating group
Code Block |
---|
Parse Error : Incorrect size of a repeating group. Expected: 1. In fact: 2. Parsing stopped at column: 228 in tag N/A in message E with sequence number 979 |
Description or root cause
This error will occur if the validation option 'verifyRepeatingGroupBounds' is enabled and FIX Engine receives a message with incorrect repeating group size. In this case, the FIX message will be rejected.
Before FIX Engine version 2.28.1 (and FIXEdge version 6.11.0), this parameter was always enabled.
Solution or troubleshooting steps
To revert this parameter after updating to the versions stated above, this parameter should be set to false. Additionally, for FIX Engine, the field should be set to false.
The authentication service doesn't send a response in time
Code Block | ||
---|---|---|
| ||
<timestamp> WARN [LogonHandler] <thread> Session <SenderCompId, TargetCompId> : process logon failed - request is timed out |
Description or root cause
This WARN record occurs in the FixEdge.log file if FIXEdge doesn't receive a response in time.
Solution or troubleshooting steps
Check the incoming FIX session logs and if there are no messages User Response (BF) then the issue is on the Authentification Service side.
FIXEdge can't create a log directory in the specified path
Code Block | ||
---|---|---|
| ||
<timestamp> WARN [Engine] Session <SenderCompId, TargetCompId>: There was an error while creating path <path>. Using default log directory <logDir>. The error reason: <err.message>. |
Description or root cause
This WARN record occurs if FIXEdge C++ can't create a log directory for the FIX session in the specified path.
Solution or troubleshooting steps
Check the value of the LogDirectory property specified for this session.
The property was overridden
Code Block | ||
---|---|---|
| ||
<timestamp> WARN [Engine] The "<property_name>"property was overridden by the file <filename>. |
Description or root cause
This message appears when the value of some property was overridden by another properties file.
Solution or troubleshooting steps
This message can be ignored.
INFO
The active session was closed non-gracefully
Code Block | ||
---|---|---|
| ||
<Timestamp> INFO [Engine] Session <Session_Name> : Change state: old state=Established new state=NonGracefullyTerminated
<Timestamp> INFO [Engine] Session <Session_Name> : active session was closed non-gracefully (The confirming Logout message was received from the counterparty.) |
Description or root cause
This message appears when the session was terminated by Logout and IntradayLogoutTolerance mode is enabled. This mode means that during the next session start the same set of logs will be used and the next Logon will be sent with sequence number previous+1 (unless you use ForceSeqNumReset=ALWAYS. See matrix of possible IntradayLogoutTolerance+ForceSeqNumReset combinations).
Solution or troubleshooting steps
This message doesn't indicate an issue, just informs that session was disconnected correctly and sequence numbers were preserved.
Reject task finished
Code Block | ||
---|---|---|
| ||
<Timestamp> INFO [Engine] <thread> Cannot find the property "StorageCreationTime" in the storage "<path>/<session id>_<timestamp>", used current date.Session <Session_Name> : Reject task finished |
Description or root cause
...
In FIXEdge there is an option to reject messages that should be routed into the session, which exists, but currently isn't available. This message appears when all such messages were rejected.
Solution or troubleshooting recommendations
Ignore, if starting a session without any previous state (For example on the clean log)
INFO
...
steps
This message doesn't indicate an issue, just informs that the task was finished.
The backup session has the same parameters as the primary session
Code Block | ||||
---|---|---|---|---|
| ||||
<Timestamp> INFO [Engine] Session <Session_Name> : Change state: old state=Established new state=NonGracefullyTerminated <Timestamp> INFO [Engine] Session <Session_Name> : active session was closed non-gracefully (The confirming Logout message was received from the counterparty.).The backup session has the same parameters as the primary session |
Description or root cause
This message appears when the session was terminated by Logout and IntradayLogoutTolerance mode is enabled. This mode means that during the next session start the same set of logs will be used and the next Logon will be sent with sequence number previous+1 (unless you use ForceSeqNumReset=ALWAYS. See matrix of possible IntradayLogoutTolerance+ForceSeqNumReset combinations).This message appears when the backup session has the same parameters as the primary session.
Solution or troubleshooting recommendationssteps
This message doesn't indicate an issue, just informs that session was disconnected correctly and sequence numbers were preserved.
...
the backup session's parameters are the same as for the primary session.
A FIX Session storage type isn't specified
Code Block | |||||
---|---|---|---|---|---|
| |||||
<Timestamp> INFO [Engine] <thread> Session <Session_Name> : Reject task finished.property 'Session.TESTSESSION.StorageType' is not found. PersistentMM storage type is used |
Description or root cause
In FIXEdge there is an option to reject messages that should be routed into the session, which exists, but currently isn't available. This message appears when all such messages were rejectedThe option for storage type is not set so the most efficient storage type (PersistentMM) is used.
Solution or troubleshooting recommendations
This doesn't indicate an issue, just informs that the task was finished.
...
steps
Make sure that the storage type is specified correctly. Check if there are spaces between the property and its value.
New log message storage was created
Code Block | ||||
---|---|---|---|---|
| ||||
<Timestamp> INFO [Engine] <thread> Session <Session_Name> : The backup session has the same parameters as the primary session. <sender, target> : Created new [FIX/FAST] log storage with file name "<path to file>/<storage file name with timestamp>" |
Description or root cause
This message appears when the backup session has the same parameters as the primary sessionFIX Antenna creates new log message storage.
Solution or troubleshooting recommendationssteps
This message doesn't indicate an issue, just informs that the backup session's parameters are the same as for the primary session.
...
task was finished.
LogDirectory property was specified with a non-existent path
Code Block | ||||
---|---|---|---|---|
| ||||
<Timestamp> INFO [Engine] Session <thread> Session property 'Session.TESTSESSION.StorageType' is not found. PersistentMM storage type is used<sender, target>: Path <location> doesn't exist. Trying to create it. |
Description or root cause
The option for storage type is not set so the most efficient storage type (PersistentMM) is usedThis message appears when the LogDirectory property was specified with the non-existent path for the FIX session.
Solution or troubleshooting recommendations Make sure that the storage type is specified correctly. Check if there are spaces between the property and its valuesteps
This message can be ignored. To use the particular existing log directory user must change the value of the LogDirectory property for the FIX session.