Uploaded image for project: 'JBoss Marshalling'
  1. JBoss Marshalling
  2. JBMAR-127

OutputStreamByteOutput does not override #write(byte[], int, int), causing performance problems

XMLWordPrintable

      OutputStreamByteOutput extends FilterOutputStream but does not override #write(byte[], int, int). This causes the default implementation of FilterOutputStream to be used which simply writes the byte array per-byte to the filtered outputs stream and that kills I/O performance.

      I found this by profiling Infinispan.

      You can see how the invocation counts explode between org.jboss.marshalling.SimpleDataOutput and org.infinispan.io.ExposedByteArrayOutputStream.

      Changing this gives Infinispan a nice boost in performance, something like 30 to 40 %. Some numbers of me inserting 10 K 2 K values into Infinispan with passivation turned on:

      Infinispan 5.1.0.CR2
      
      original	135496 ms
      tuned		100190 ms
      
      Infinispan 5.1.0.CR3
      
      original	140871 ms
      tuned		 97587 ms
      

      Long story short, here's how you should change the class:

      /*
       * JBoss, Home of Professional Open Source
       * Copyright 2010, JBoss Inc., and individual contributors as indicated
       * by the @authors tag. See the copyright.txt in the distribution for a
       * full listing of individual contributors.
       *
       * This is free software; you can redistribute it and/or modify it
       * under the terms of the GNU Lesser General Public License as
       * published by the Free Software Foundation; either version 2.1 of
       * the License, or (at your option) any later version.
       *
       * This software is distributed in the hope that it will be useful,
       * but WITHOUT ANY WARRANTY; without even the implied warranty of
       * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
       * Lesser General Public License for more details.
       *
       * You should have received a copy of the GNU Lesser General Public
       * License along with this software; if not, write to the Free
       * Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
       * 02110-1301 USA, or see the FSF site: http://www.fsf.org.
       */
      
      package org.jboss.marshalling;
      
      import java.io.FilterOutputStream;
      import java.io.IOException;
      import java.io.OutputStream;
      
      /**
       * An {@code OutputStream} which implements {@code ByteInput} and reads data from another {@code OutputStream}.
       * Usually the {@link Marshalling#createByteOutput(java.nio.ByteBuffer)} method should be used to create instances because
       * it can detect when the target already extends {@code OutputStream}.
       */
      public class OutputStreamByteOutput extends FilterOutputStream implements ByteOutput {
      
          /**
           * Construct a new instance.
           *
           * @param outputStream the output stream to write to
           */
          public OutputStreamByteOutput(final OutputStream outputStream) {
              super(outputStream);
          }
      
      	@Override
      	public void write(byte[] b, int off, int len) throws IOException {
      		out.write(b, off, len);
      	}
          
      }
      

            dlloyd@redhat.com David Lloyd
            johannburkard Johann Burkard (Inactive)
            Votes:
            0 Vote for this issue
            Watchers:
            3 Start watching this issue

              Created:
              Updated:
              Resolved: