Uploaded image for project: 'Infinispan'
  1. Infinispan
  2. ISPN-14238

Memcached server: corrupted response

This issue belongs to an archived project. You can view it, but you can't modify it. Learn more

XMLWordPrintable

    • Icon: Bug Bug
    • Resolution: Done
    • Icon: Blocker Blocker
    • 14.0.2.Final, 15.0.0.Final
    • 14.0.1.Final
    • None
    • None

      While doing a stress test with the new changes to the memcached decoder, the spymemcached throws IllegalStateException: No read operation, meaning the server is sending something that isn't supposed to send.

      Adding trace/debug messages, found the following pattern. This is the last request done by this decoder instance (spymemcached closes the connection after the exception)

      2022-10-18 17:02:57,536 TRACE (non-blocking-thread--p2-t18) [org.infinispan.server.memcached.MemcachedDecoder] Resetting parameters using instance @21234f16
      2022-10-18 17:02:57,536 DEBUG (jgroups-27,pedro-desktop-25592) [org.infinispan.server.memcached.MemcachedDecoder] Sending response 1752 for instance 21234f16, rsp=[B@637f1839, throw=null
      2022-10-18 17:02:57,536 TRACE (non-blocking-thread--p2-t18) [org.infinispan.server.memcached.MemcachedDecoder] Decode using instance @21234f16
      2022-10-18 17:02:57,536 TRACE (non-blocking-thread--p2-t18) [org.infinispan.server.memcached.MemcachedDecoder] Decode header using instance @21234f16
      2022-10-18 17:02:57,536 TRACE (non-blocking-thread--p2-t18) [org.infinispan.server.memcached.MemcachedDecoder] Operation: 'get'
      2022-10-18 17:02:57,536 TRACE (non-blocking-thread--p2-t18) [org.infinispan.server.memcached.MemcachedDecoder] Decode using instance @21234f16
      2022-10-18 17:02:57,536 TRACE (non-blocking-thread--p2-t18) [org.infinispan.server.memcached.MemcachedDecoder] Decoding key using instance @21234f16
      2022-10-18 17:02:57,536 TRACE (jgroups-27,pedro-desktop-25592) [org.infinispan.server.memcached.MemcachedDecoder] Write response using instance @21234f16: [B0x53544F5245440D0A
      2022-10-18 17:02:57,536 DEBUG (non-blocking-thread--p2-t18) [org.infinispan.server.memcached.MemcachedDecoder] Queueing response 1753 for instance 21234f16, operation=GetRequest
      2022-10-18 17:02:57,536 DEBUG (non-blocking-thread--p2-t18) [org.infinispan.server.memcached.MemcachedDecoder] Sending response 1753 for instance 21234f16, rsp=UnpooledByteBufAllocator$InstrumentedUnpooledUnsafeHeapByteBuf(ridx: 0, widx: 1030, cap: 1030), throw=null
      2022-10-18 17:02:57,536 TRACE (non-blocking-thread--p2-t18) [org.infinispan.server.memcached.MemcachedDecoder] Write response using instance @21234f16: UnpooledByteBufAllocator$InstrumentedUnpooledUnsafeHeapByteBuf(ridx: 0, widx: 1030, cap: 1030)
      2022-10-18 17:02:57,536 TRACE (non-blocking-thread--p2-t18) [org.infinispan.server.memcached.MemcachedDecoder] Resetting parameters using instance @21234f16
      

      The test shows a concurrent set() and get() request. The set() ack is delivered by JGroups while the get() is being handled.

      The theory is that Netty queues the writeAndFlush invocation (the JGroups threads is not a Netty thread) but the get() request is response is sent immediately.

              pruivo@redhat.com Pedro Ruivo
              pruivo@redhat.com Pedro Ruivo
              Archiver:
              rhn-support-adongare Amol Dongare

                Created:
                Updated:
                Resolved:
                Archived: