<html>
  <head>

    <meta http-equiv="content-type" content="text/html; charset=ISO-8859-1">
  </head>
  <body bgcolor="#FFFFFF" text="#000000">
    <br>
    <div class="moz-forward-container">Hi all,<br>
      <br>
      <br>
      in a Java heap dump of 7u21 we can see accumulating tons of GC
      related diagnostics message strings.<br>
      This will result in an OOME finally. These millions of strings are
      e.g.:<br>
      <br>
      "end of minor GC",   <span id="form1:panelPage1">"end of major
        GC",  "Copy",  "Allocation Failure",  </span>"PS Scavenge"<br>
      <br>
      Interestingly these stings are root objects and are never been
      collected. What is<br>
      the purpose of these messages? Are they supposed to go into a
      logfile?<br>
      We didn't see them anywhere.<br>
      <br>
      And what JVM flag needs to be enabled to trigger their creation?<br>
      <br>
      From memoryManager.cpp<br>
      <br>
          if (<b>is_notification_enabled()</b>) {<br>
          320       bool isMajorGC = this ==
      MemoryService::get_major_gc_manager();<br>
          321       GCNotifier::pushNotification(this, isMajorGC ? "end
      of major GC" : "end of minor GC",<br>
          322                                   
      GCCause::to_string(cause));<br>
      <br>
      <br>
      In other words, how can we set the boolean _notification_enabled
      to false in order to suppress<br>
      the creation of these annoying strings?<br>
      <br>
      Further on I'm wondering why these strings are being created in
      Java heap rather than as internal strings<br>
      in perm in order to avoid millions of duplicates.<br>
      <br>
      Right now I consider this a bug which is btw not reproducible with
      JRockit and also not reproducible<br>
      with Java SE 6. Only 7.<br>
      <br>
      <br>
      Thanks and Regards<br>
      <br>
      Thomas <br>
      <br>
      <br>
      <br>
      <br>
      <div class="moz-signature">-- <br>
        <a moz-do-not-send="true" href="http://www.oracle.com"
          target="_blank"><img style="border: 0px solid ; width: 114px;
            height: 26px;" src="cid:part1.01090103.09080205@oracle.com"
            alt="Oracle"></a><br>
        <font color="#666666" face="Verdana, Arial, Helvetica,
          sans-serif" size="2">THOMAS VIESSMANN | Senior Principal
          Technical Support Engineer - Java<br>
          Phone: <a moz-do-not-send="true" href="tel:+49814302496">+498914302496</a>
          | Mobile: <a moz-do-not-send="true" href="tel:+491743005467">+491743005467</a>
          <br>
          <font color="#ff0000">Oracle</font> Customer Technical Support
          - Java<br>
          <br>
          ORACLE Deutschland B.V. & Co. KG | Riesstr.25 | D-80992
          Muenchen </font><br>
        <br>
        <font color="#666666" face="Verdana, Arial, Helvetica,
          sans-serif" size="1">ORACLE Deutschland B.V. & Co. KG<br>
          Hauptverwaltung: Riesstr. 25, D-80992 Muenchen<br>
          Registergericht: Amtsgericht Muenchen, HRA 95603<br>
          Geschäftsführere: Juergen Kunz<br>
          <br>
          Komplementärin: ORACLE Deutschland Verwaltung B.V.<br>
          Hertogswetering 163/167, 3543 AS Utrecht, Niederlande<br>
          Handelsregister der Handelskammer Midden-Niederlande, Nr.
          30143697<br>
          Geschäftsführer: Alexander van der Ven, Astrid Kepper, Val
          Maher<br>
        </font> <br>
        <hr>
        <hr> <a moz-do-not-send="true"
          href="http://www.oracle.com/commitment" target="_blank"><img
            style="border: 0px solid ; width: 44px; height: 28px;"
            src="cid:part5.08060401.00050709@oracle.com" alt="Green
            Oracle" align="middle"></a> <font color="#4b7d42"
          face="Verdana, Arial, Helvetica, sans-serif" size="1">Oracle
          is committed to developing practices and products that help
          protect the environment</font>
        <!-- This signature was generated by the MyDesktop Oracle Business Signature utility version 3.8.6 -->
      </div>
      <br>
    </div>
    <br>
  </body>
</html>