- 
    Type:Bug 
- 
    Resolution: Done
- 
    Priority:Critical - P2 
- 
    Affects Version/s: 1.1.4, 1.1.5
- 
    Component/s: None
- 
    None
- 
    Environment:mongo server 1.6.5
- 
        None
- 
        Fully Compatible
- 
        None
- 
        None
- 
        None
- 
        None
- 
        None
- 
        None
The ruby client driver loses track of its position in the stream of responses from the server if an exception occurs while Connection#send_with_safe_check or Connection#receive_message are running. This commonly occurs when the client application uses a Timeout; a Timeout::Error exception may be raised while Connection#receive is blocked. Other exceptions are possible here (due to other asynchronous signals or perhaps due to unexpected IO conditions). When an exception occurs at this point, the server will eventually send a response, but the client driver is no longer waiting for it. The response is typically consumed by the subsequent mongo operations; all following request appear to get the response from the preceding request.
(Unless there is a sequence number in the mongo protocol that is being ignored by the client driver...) I'd advise adding an exception handler to the critical section of Connection#receive_message and Connection#send_with_safe_check that closes the socket when any exception occurs. (See attached patch)
- related to
- 
                    RUBY-231 Responses sometimes out of order on Ruby 1.9.2 -         
- Closed
 
-