Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

Resend Request logic is the FIX session mechanism by which a given system, upon detecting a higher than expected message sequence number from its counterparty, requests a range of ordered messages resent from the counterparty. The counterparty resends the requested message range sequentially until both systems are back in sequence.  

Info

Customers must wait for in-flight resend requests to be fulfilled before logging out or failing over to the backup gateway.

Info

For each resend request, it is required that the client system cannot request more than 2500 messages. If the missing messages exceed this value, the client systems can submit multiple resend requests. Only one resend request will be processed at a time. New Resend request received while already processing a resend request will be rejected

The following topics discuss the Session Layer Resend Request:

Table of Contents

Basic Versus Enhanced Resend Logic 

For resend requests on CME Globex, two types of resend logic are currently supported:

Note

Important

  1. Basic FIX Resend Logic - standard FIX protocol resend request logic, which is NOT RECOMMENDED.

  2. Enhanced CME Globex Resend Logic - additional resend logic beyond that defined in the FIX protocol to facilitate rapid recovery in high transaction-per-second (TPS) scenarios which is HIGHLY RECOMMENDED.

Basic resend logic as defined by the FIX protocol will fail in the scenario in which, once a gap is detected and a resend request initiated, the counterparty continues to send incrementally out-of-sequence messages (known in FIX protocol as 'gap continuation'), each of which triggers another resend request. In high TPS situations, this will create a loop or hard disconnect.

Enhanced resend logic solves this problem by identifying any resend request sent in a 'gap continuation' scenario as a duplicate Resend Request which the counterparty can discard. Therefore a system implementing enhanced resend logic must observe the following rules:

  • A newly detected message sequence gap must be distinguished from a continuation of a gap and a new gap versus a duplicate Resend Request must be issued accordingly.

  • When a message sequence number gap is newly detected (the sequence number received is greater than expected), issue a new Resend Request on its own sequence number. The requested sequence number range must be the next expected sequence number to infinity.

  • For each subsequent message that constitutes a continuation of the gap, issue a duplicate Resend Request. This message must be sent on the same message sequence number of the original Resend Request, tag 43-PossDupFlag must be set to 'Y' and tag 122-OrigSendingTime must not be sent.

  • The FIX Engine should detect receipt of the first message sent in response to a previous Resend Request and discontinue issuing the Resend Requests marked PossDup.

  • The FIX Engine should issue a new Resend Request, if needed, only after the receipt of the counterparty's response has been completed.

  • For resend requests from the Client System to CME Globex, both basic and enhanced resend logic are supported.

Note

Warning

Basic FIX resend logic, while currently support will be phased out. ALL CLIENT SYSTEMS WILL BE REQUIRED TO MIGRATE TO ENHANCED CME GLOBEX RESEND LOGIC. For new system development, it is imperative that enhanced CME Globex resend logic be implemented.

...

In addition to the above, client applications implementing basic resend logic must adhere to the following:

  • Tag 122-OrigSendingTime, is required.

  • Tag 369-LastMsgSeqProcessed, is not allowed.

Client System Maximum Resend Request Limit

For each resend request, it is required that the client system cannot request more than 2500 messages. CME Group recommends that client systems request all missing messages. In response to the Resend Request from the client system, CME Group will send all non-administrative messages for the requested range.

If the client system exceeds this value, CME Globex sends a Session Level Reject (tag 35-MsgType=3) message. Tag 58-Text in this message will contain the following: "Range of messages to resend is greater than maximum allowed 2500."

...

During normal resend processing, the Sequence Reset - Gap Fill message is used when the sending application chooses not to resend specific messages, for example stale orders or administrative messages.Session-Layer-Resend-Request-Sequence-Reset-Gap-FillImage Removed

...

Enhanced Resend Request from Client System to CME Globex

...

Info

Enhanced resend logic is identical from client system to CME Globex and vice versa. The following examples depict the client system initiating the resend request.

...

  1. The message sent by CME Globex has tag 34-MsgSeqNum=11 and is higher than the client system is expecting.

  2. The client system responds with a iLink 2 Resend Request with tag 7-BeginSeqNo=10 and tag 16-EndSeqNo=0 indicating infinity.

  3. Before CME Globex receives the Resend Request, it has already sent messages 12 and 13.

  4. When the client system receives messages 12 and 13, the absence of the tag 122-OrigSendingTime and tag 369-LastMsgSeqNumProcessed = 199 indicates that messages 12 and 13 are not the resend responses it is expecting.

  5. The client system, therefore, issues duplicate Resend Requests with tag 43-PossDupFlag=Y.

  6. When CME Globex receives the original Resend Request, it processes it by re-sending messages 10 - 13 with tag 43-PossDupFlag =Y and tag 122-OrigSendingTime tag populated.

  7. Since the subsequent Resend Requests were sent as duplicates with tag 43-PossDupFlag=Y and CME Globex has already processed the original message, per the FIX Protocol, CME Globex ignores the duplicate Resend Requests.

Resend Logic from CME Globex to Client System

...

Info

Resend Request behavior from client system to CME Group is unchanged; i.e., no real-time messages will be processed until the Resend Request is satisfied.

Please refer to Session Layer - Resend Request for more information.

Example

Time

From Client System to CME Globex

From CME Globex to Client System

tag 35-MsgType

tag 34-MsgSeqNum

tag 49-SenderCompID

tag 50-SenderSubID

tag 57-TargetSubID

tag 7-BeginSeqNo

tag 16-EndSeqNo

tag 36-NewSeqNo

tag 43-PossDupFlag

tag 123-GapFillFlag

1

Execution Report

8

100

CME

68

ATS

2

Resend Request

2

200

ZUB007N

ATS

68

98

0

3

Execution Report

8

98

CME

68

ATS

Y

4

Execution Report

8

99

CME

68

ATS

Y

5

Execution Report

8

101

CME

68

ATS

6

Execution Report

8

100

CME

68

ATS

Y

7

Heartbeat

0

102

CME

68

ATS