Skip navigation.

Release Notes

  Previous Next vertical dots separating previous/next from contents/index/pdf Contents View as PDF   Get Adobe Reader

BEA WebLogic JRockit 8.1 SDK Release Notes

Version 8.1 Service Pack 2

This document contains important details for this version of BEA WebLogic JRockit 8.1 SDK. It contains information on the following subjects:

 


Installation

WebLogic JRockit 8.1 SDK is available either as a standalone application or as part of the BEA WebLogic Platform suite. For instructions on installing it as a standalone, please see Installing WebLogic JRockit 8.1 SDK. For instructions on installing it as part of WebLogic Platform, please refer to Installing WebLogic Platform.

 


Contents of the SDK

For a detailed description of what is included in this service pack of BEA WebLogic JRockit 8.1 SDK, please refer to What's in the WebLogic JRockit 8.1 SDK?.

 


Important Notes

Before using WebLogic JRockit 8.1 SDK, you should be aware of the information discussed in this section. These important notes are:

Notes for Service Pack 2

This section describes issues resolved in this service pack and other product-related notes. The issues described here were originally identified in WebLogic JRockit 8.1 SDK Service Pack 1 and earlier.

J2SE Certification

This service pack of WebLogic JRockit 8.1 SDK is certified to run with J2SE version 1.4.1_05.

Class or Method Names Using Multi-byte Characters Can Adversely Affect WebLogic JRockit

Class or method names that include multi-byte characters can cause WebLogic JRockit to hang or crash. Under certain conditions, when internal strings are converted to multi-byte strings, the JVM can cause a buffer overrun, which might result in it crashing or hanging up. If you encounter this situation, please contact support (support@bea.com) to obtain a patch to work around it.

file.encoding for Linux Implementations Set to "EUC-JP-LINUX"

WebLogic JRockit has remapped its file.encoding property for Linux implementations using the Japanese locale from EUC-JP to EUC-JP-LINUX.

Preventing JRockit Crashes When Multiple Threads Use JNI GetFieldID

In some circumstances, WebLogic JRockit would crash when using JNI's GetFieldId() and multiple threads called the function. It was discovered that the field cache was not thread safe. The JVM was modified so that read/writes are now guarded with spinlock. GetFieldId() now works even when multiple threads are constantly calling it.

Memory Leak in lowmemposix with High Thread Turnover

This version of WebLogic JRockit modifies the thread clean-up code to correct a problem with how the JVM's thread clean up resulted in their stack memory being left behind, thus, a memory leak. This was a race condition that meant a few stacks for every thousand threads cleaned up were not freed.

This problem occurred in Java programs that had a high thread turnover rate. The user would notice a gradual increase in process size over time, indicative of a memory leak. Java programs using Oracle JDBC drivers under certain conditions would also notice this problem, since this Oracle's driver may create threads for canceling transactions.

Completed Native Threads Released More Often

It was possible for an application with large heap to allocate enough threads to exceed the maximum, process size even when those threads have completed. WebLogic JRockit has been modified in this service pack to release terminated platform threads every 25 completions.

DatagramPacket.getAddress() Returned Wrong Information

When used in a Linux 32-bit implementation, the DatagramPacket.getAddress() was returning the first client address from which the packet has been received, whereas the Windows32-bit version would return the proper source address. WebLogic JRockit has been updated as of this version to correct this situation.

Problem with Stopping JRockit as an NT Service Corrected

Some users experienced a problem when they started WebLogic JRockit an NT server and then stopped the service. Windows would generate an error message and then advise them that the Java service would be closed. Another message would then that indicate that the service could not be stopped. This situation has been corrected.

Controlling JVM Process Size Growth

The version of WebLogic JRockit corrects a problem with the JVMs ability to control process size growth. In earlier versions of WebLogic JRockit, there were occasional problems controlling this growth, even if the Java heap was well within its limit and was almost constant during the run. This indicated a memory leak outside the heap, with the process size growing up to 2 GB before the process hung up or died.

JNIString Implementation Now Consistent with Sun Implementation

In earlier versions of WebLogic JRockit, the JNI implementation was inconsistent with Sun's implementation. This inconsistency occasionally resulted in emptyString and nullString failures. The WebLogic JRockit implementation of JNI is now consistent with Sun's.

64-bit JRockit Crashing with Orphaned Threads

This service pack of WebLogic JRockit corrects a problem wherein Java applications having high thread turnover were prone to random crashes or hanging of the JVM. This problem occurred on all platforms, but was most frequently seen on 64-bit Linux machines. If a JRockit dump was produced after a crash or hangup, it would often be incomplete or show different problems each time it was generated.

Special Note to 64-bit Linux Users

If you are using 64-bit Linux, ensure that your glibc and kernel versions are up to date with the latest bug fixes from the RedHat Network:

Compliance Test Suite Recommendation

If you are running the J2EE compliance test suite from Sun with WebLogic JRockit on WebLogic Server, we recommend that you set -Xmx and -Xmx to the same size to prevent the system from dumping. If you do encounter a dump on startup, review your -Xmx and -Xmx settings and reduce them, if necessary.

Out-of-Memory Errors Encountered when Running with WLS jDriver

Some users have encountered an out-of-memory error when WebLogic JRockit tried to allocate a new byte array when running with jDriver. When the allocation fails glibc threw a C++ exception which wasn't not caught, causing the program to dump core and terminate. At the same time, no jrockit.dump file is created. This problem has been corrected.

Corrected Hangup in java.lang.Object.getMonitorIndexAndLock(Native Method)

Occasionally, customers have seen some execute threads hang up in a java.lang.Object.getMonitorIndexAndLock(Native Method), call while the CPU pegs to 100% utilization. This version of WebLogic JRockit has been enhanced to alleviate this problem by implementing the correct handling of native weak handles, which are more reachable than final and phantom handles.

Trusted CAs in the JDK cacerts keyStore File Due to Expire

The JDK cacerts file and the WebLogic Server cacerts file are keystore files that contain out-of-the-box trusted Certificate Authority certificates. These trusted CA certs are used in certificate chain verification when using SSL.

In this service pack, WebLogic Server checks each trusted CA certificate in the JDK and WebLogic Server cacerts files for the NotAfter date. If the trusted CA is due to expire (that is, exceed the NotAfter date) within 30 days, a warning message is output about this impending expiration. If a trusted CA has already expired, with one exception, a warning message is output declaring the trusted CAs as having exceeded the NotAfter date.

Two trusted CAs in the JDK cacerts keystore file are due to expire approximately at the release date of this service pack. Thus, you might see one or both of these warning messages output while booting WebLogic Server.

If you use either of these two trusted CAs in your server certificate chain, you should obtain a new trusted CA or certificate from your Certificate Authority of choice (Verisign, Certicom, and so on).

The current JDK cacerts file contains at least one certificate from Verisign that has expired (the Class 4 Certificate Authority, alias verisignclass4ca). No certificate expired message is output when this trusted CA is loaded.

For more information, see Sun Alert 57436 at http://sunsolve.sun.com/pub-cgi/retrieve.pl?doc=fsalert%2F57436.

Notes for Service Pack 1

This section describes issues resolved in this service pack and other product-related notes. The issues described here were originally identified in WebLogic JRockit 8.1 SDK GA and earlier.

Relocating WebLogic JRockit RPMs Obtained from Red Hat

While the BEA download site only distributes WebLogic JRockit packages using the BEA installer, if you are subscribed to Red Hat Network, you can obtain WebLogic JRockit binaries in RPM format from the Red Hat Enterprise Linux AS channel. If you do obtain the WebLogic JRockit RPMs, you can relocate them from the default directory (/opt/bea/jrockit81_141) to a directory you specify.

For complete details, please refer to Overriding the Default Installation Path with RPM in Installing WebLogic JRockit.

Avoiding Paging-related Performance Degradation

If you don't set the maximum heap size (-Xmx), fragmentation might cause paging to occur, degrading system performance. This is because WebLogic JRockit grows the heap aggressively when fragmentation occurs, potentially out-stripping the physical memory available. Although WebLogic JRockit sets the default maximum heap size to 75% of physical memory in the system, it will grow the heap aggressively when the heap becomes fragmented. To avoid this situation, you should override the default and manually set -Xmx to no more than 75% of the available physical memory.

For complete details, please refer to Setting the Initial and Maximum Heap Size in Tuning the WebLogic JRockit JVM.

Avoiding a Crash when Using -Xgc:gencopy and a Set Nursery Size

Starting WebLogic JRockit with the generational copy garbage collector (-Xgc:gencopy) and a nursery explicitly set to more than 15% of initial heap size will cause the JVM to crash. To avoid this situation, either accept the default nursery size by not specifying -Xns or set the nursery size to less than 15% of the -Xms setting.

For more information on setting the nursery size, please refer to Setting the Size of the Nursery in Tuning the WebLogic JRockit JVM.

Unified Format for -Xverbose:memory Output Across all Garbage Collectors

To ensure consistency of information displayed when -Xverbose:memory is specified, the output for that option has been unified across all garbage collectors; that is, specifying -Xverbose:memory will result in the same type of information displayed, regardless of the garbage collector used. For details, please refer to Displaying Logging Information in Starting and Configuring WebLogic JRockit.

Support for windows-31j Encoding on jDriver

This version of WebLogic JRockit (J2SE 1.4.1) now supports MS932 windows-31j encoding on jDriver. Previously, this support was not available because the windows-31j converter was not included in lib/charsets.jar. This affected WebLogic JRockit's support for Japanese language implementations.

Support for 64-bit Files on Linux

When running WebLogic JRockit on Linux some users were experiencing a "File size limit exceeded" exception and the application stopped, indicating that the JVM was not able to handle large (greater than 2 GB) files. This issue was reported in CR103219 and has been corrected. WebLogic JRockit now supports 64-bit files.

Unified Root Directory Names for Linux

The root directory names for WebLogic JRockit SDK Linux installations are now the same, regardless of the Intel architecture used. Based on the installation method you use, the root directories are as listed in Table 1:

Table 1 Unified Root Directory Names

Installer

Root Directory for IA32

Root Directory for IA64

RPM

/opt/bea/jrockit81sp1_141_03/

/opt/bea/jrockit81sp1_141/

BEA

$BEAHOME/jrockit81sp1_141_03/

$BEAHOME/jrockit81sp1_141/


 

Note: When available, a microversion number will be added to the directory name for IA64.

Zip File Header Limitation Expanded

Although the JDK allows for zip file headers to contain more than 256 bytes of additional information, an exception was being thrown when these files became larger than that. This issue was reported in CR104622. In response, the ZipFile() constructor was modified to support up to 64 KB of extra header information.

Buffer Overrun Problem Corrected

A confluence of coding and the compiler used on that code was causing a rare buffer overrun (see CR099551). This situation has been corrected and future problems of this sort should no longer occur.

Using the Correct Version of glibc with IA32 Linux

Red Hat Enterprise Linux AS / ES / WS 2.1users need to ensure that glibc version i686 is installed, not glibc version i386 version. Otherwise, you might encounter a segfault error upon startup. Additionally, do not add the folder /lib or /lib/i386 to your LD_LIBRARY_PATH. If /lib is in LD_LIBRARY_PATH, /lib/libpthread.so will be the linked runtime, instead of /lib/i686/libpthread.so.

Memory Footprint Appears Increased

The implementation of java.lang.Runtime.freeMemory() has been corrected. Previously, it regarded the whole nursery as being free. Because of this, an application may incorrectly get the impression that WebLogic JRockit now uses more memory. This is not the case since previously a higher value than was actually free was returned.

Mimicking GA Behavior for SP1 Implementations

If you start WebLogic JRockit with the gencon garbage collector (either implicitly, as the default, or explicitly) and you specify explicit values for -Xmx and -Xns, you will need to double the value specified for -Xns to mimic the GA behavior.

"Bad File Descriptor" Exception Thrown when Too Many Files are Open

CR101146 reports that WebLogic JRockit might throw an IOException: Bad file descriptor if too many files are open. To work around this situation, increase the maximum number of files you can open to 2048 by setting ulimit -n 2048. You can only increase this number if the maximum number of files you can open is equal to or greater than 2048. If maximum number of processes is lower than 2048, have your system administrator increase it to at least 2048.

NullPointerException Thrown for Synchronized JNI-function Returning Double

As reported in CR107067, a JNI function declared as:

public native synchronized float foo();

will throw a NullPointerException upon returning to the JNI-stub. This issue will be resolved in WebLogic JRockit 8.1 Service Pack 2.

Extensive Use of Runtime.exec() Might Cause Crash on IA64

If you are running a Linux version of WebLogic JRockit on an IA64 SMP machine and are using Runtime.exec() extensively, you might encounter arbitrary crashes during processing. This issue, reported in CR104064, is caused by an O/S-level problem that has been resolved by a patch now available from RedHat at:

http://rhn.redhat.com/errata/RHSA-2003-198.html

Running tnameserv and Console on Linux64

As reported in CR111919, if you are a Linux64 user, you will encounter a problem running tnameserv and the JRockit Management Console. You will see one of these error messages:

Error: could not find libjava.so
Error: could not find Java 2 Runtime Environment

To workaround this situation, from the command line, enter:

cd <PATH_TO_JROCKIT_81SP1>/jre/lib
ln -s ia64 sparcv9

Once you done this, you should be able to run tnamserv and the Console by using your normal scripts.

Notes for GA

This section describes the issues were resolved in WebLogic JRockit 8.1 SDK GA and other important product-related information. The issues described here were originally identified in WebLogic JRockit 8.0 SDK and earlier.

Dealing with Heavily Contended Locks

If you are running a high-stress application with heavily contended locks on a multiprocessor system, you can attempt to improve performance by using the option -XXenablefatspin. This option enables the ability to spin for a short time before going to sleep. While in most cases, -XXenablefatspin improves performance slightly—particularly if the contended locks in your code are only held for a short period of time—be aware that, in some cases (perhaps up to 20%), it degrades performance. Future versions of WebLogic JRockit are expected to automatically adjust the spinning for different locks, eliminating the need for this option.

Getting CPU Usage Information in the Management Console

To be able to get CPU usage information in the JRockit Management Console from a JRockit instance running on Windows 2003 Server, the JRockit instance needs to be running as a user who has administrative rights on the computer in question.

Using Linux on Hyper Threading-enabled Intel Processors

If you are using Linux on Hyper Threading-enabled Intel processors, be aware of the following:

Unknown pthread Library

If you receive the following error:

ERROR: The pthread library is unknown. Are you running a supported Linux distribution? (Segment-register gs appears to be unused)

You should make sure that the environment variable LD_ASSUME_KERNEL=2.2.5 is not set.

Invalid Command Line Flags

Be sure to use only valid command line options when starting WebLogic JRockit JVM. If you use an invalid option, WebLogic JRockit will exit. Note that this behavior is different from that of previous versions of the VM, where it was ignored. For a list of valid command line options, please refer to Command Line Options by Name, in Tuning WebLogic JRockit JVM.

 


Documentation

The documentation set has been completely updated and reorganized since WebLogic JRockit 8.0. Significant changes include the following:

Copies of all WebLogic JRockit 8.1 SDK documents can be found at:

http://download.oracle.com/docs/cd/E13188_01/jrockit/docs81/index.html

 


Note About OS Support

BEA will support WebLogic JRockit 8.1 SDK and provide bug fixes on only those operating system distributions that have been certified by BEA. While it may be possible to run WebLogic JRockit on other non-certified distributions, BEA makes no such guarantees. In addition, BEA will not be responsible for providing any bug fixes for non-certified distributions.

 

Back to Top Previous Next