Interface StreamingDataOutputPlus

    • Method Detail

      • writeToChannel

        int writeToChannel​(StreamingDataOutputPlus.Write write,
                           StreamingDataOutputPlus.RateLimiter limiter)
                    throws java.io.IOException
        Provide a lambda that can request a buffer of suitable size, then fill the buffer and have that buffer written and flushed to the underlying channel, without having to handle buffer allocation, lifetime or cleanup, including in case of exceptions.

        Any exception thrown by the Write will be propagated to the caller, after any buffer is cleaned up.

        Throws:
        java.io.IOException
      • writeFileToChannel

        long writeFileToChannel​(java.nio.channels.FileChannel file,
                                StreamingDataOutputPlus.RateLimiter limiter)
                         throws java.io.IOException
        Writes all data in file channel to stream:
        * For zero-copy-streaming, 1MiB at a time, with at most 2MiB in flight at once.
        * For streaming with SSL, 64KiB at a time, with at most 32+64KiB (default low water mark + batch size) in flight.

        This method takes ownership of the provided FileChannel.

        WARNING: this method blocks only for permission to write to the netty channel; it exits before the FileRegion(zero-copy) or ByteBuffer(ssl) is flushed to the network.

        Throws:
        java.io.IOException
      • flush

        default void flush()
                    throws java.io.IOException
        Throws:
        java.io.IOException