Uploaded image for project: 'JDK'
  1. JDK
  2. JDK-4369826

JRE runs out of memory buffering child processs output (Linux)

XMLWordPrintable

    • Icon: Bug Bug
    • Resolution: Fixed
    • Icon: P4 P4
    • 1.4.1
    • 1.1.6, 1.3.0, 1.4.0
    • core-libs
    • hopper
    • generic, sparc
    • generic, solaris_2.6, solaris_8
    • Verified


      This bug applies to the Kestrel reference release for Solaris
      (and probably the Linux releases).

      The JRE creates threads to buffer the stdout and stderr streams from
      child processes created by Runtime.exec().

      A sime test program:

      ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

      public class CP {

          static void main(String[] args) {

      try {
      Process p = Runtime.getRuntime().exec("cat /dev/zero");
      // pretend we are very busy.
      Thread.sleep(1000000000);
      } catch (Exception e) {
      e.printStackTrace();
      }
          }
      }

      ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

      # /files3/jdk1.3U/bin/java CP
      java.lang.OutOfMemoryError
              <<no stack trace available>>
      ^C

            kkladkosunw Konstantin Kladko (Inactive)
            foliversunw Fred Oliver (Inactive)
            Votes:
            0 Vote for this issue
            Watchers:
            0 Start watching this issue

              Created:
              Updated:
              Resolved:
              Imported:
              Indexed: