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

RESP endpoint should bundle flush calls to allow pipelining

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: Major Major
    • 14.0.8.Final, 15.0.0.Final
    • None
    • None
    • None

      Our current Netty service handlers all call flush once the operation is completed. This works fine, however if a pipeline of commands are sent on the socket, this can cause a big latency issue as each command is individually flushed. If we add the FlushConsolidationHandler, instead the commands will be flushed when one of the following three things happen

      1. The socket buffer has been fully read and readComplete event is fired (this is what happens when a person does a sync get call for example or not enough bytes is written to cause a second command to be parsed)
      2. The downstream write buffer has been filled up from a large amount of writes (Default is 16 MB iirc)
      3. The threshold of manual flushes has been invoked (256 is the default, configurable)

      In testing with RESP endpoint with other improvements this increased performance of pipelined commands by an order of magnitude. It should also help HR commands when users invoke getAsync or putAsync in a row.

              wburns@redhat.com Will Burns
              wburns@redhat.com Will Burns
              Archiver:
              rhn-support-adongare Amol Dongare

                Created:
                Updated:
                Resolved:
                Archived: