[jacorb-developer] FYI - ORB classloader change in Java 7u55, Java 8u5 - Suggestions needed

Timothy Astle timothy.astle at caris.com
Sat May 10 01:54:46 CEST 2014


I've been in contact with the author of the change in the JRE.  He's 
been very cordial.

When I contacted him about the change, this was the first reply:

"The loading of a third party singleton ORB has changed. It is loaded by 
the system loader only, thus requiring that
the specified class is on the application's classpath. Thus, when 
-Dorg.omg.CORBA.ORBSingletonClass is specified
then classpath variable needs to be amended, also. A CORBA compliant 
singleton ORB is essentially a TypeCode factory.
Its instantiation is via the no-args ORB.init() method call. As it is a 
singleton, it should be loaded with appropriate privileges.
The same functionality should be available from a full ORB 
(org.omg.CORBA.ORBClass).

As such, it is not a bug per se. But the absence of relevant release 
note document is a problem.
Unfortunately, as this change had generated a number of JBS issues, we 
noticed that a relevant release note was not created.
This is being rectified at present."

I then asked for a recommendationbecause I have a simple WAR deployment 
requirement, and he replied as follows:

"I would ask that you bear with us, a while on this, as we address this 
backward compatibility issue, and look
to solve the issues raised.  We were aware that there might be some 
compatibility issue, and had marked it as a risk,
but as  the Singleton ORB is limited in scope, and functionality we 
anticipated that it would be reasonably OK to
proceed with the refactored loading strategy. The anticipation was that 
deployments could modify the classpath,
and that TCCL loading of the full ORB would be sufficient in most cases.

In any case, we looking into this ORBSingleton conundrum, and will get 
back to shortly on this."

I might be reading into this, but it seems like they're going to address 
the problem.

If I get any more information, I'll be happy to pass it along.

Tim




On 09/05/2014 7:48 PM, Ravindra Kumar wrote:
> Hi
> Apparently i have also encountered the same issue. It is a bug definitely.
>
> thanks
> rainvdra
>
>
> On Sat, May 10, 2014 at 12:42 AM, Timothy Astle <timothy.astle at caris.com>wrote:
>
>> http://hg.openjdk.java.net/jdk7u/jdk7u60/corba/rev/a8d27c3fc4e4
>>
>> The change looks to be introduced into:
>> * Java 8 update 5
>> * Java 7 update 55
>> * Java 6 (looks like it was backported there too)
>>
>> It appears that people are just starting to encounter this issue as they
>> update their JREs:
>> * https://java.net/jira/browse/GLASSFISH-21047
>> * http://stackoverflow.com/questions/23225144/java-7u55-
>> eclipse-system-fragment-classloader
>>
>> It can affect web applications that are distributing JacORB within the web
>> application itself.  Oracle changed the classloader that searches for the
>> ORBSingletonClass, so now the implementation class must be on the System
>> classpath, not the web application's classpath, else the JRE will not find
>> the implementation.  You can see how this applies to servlet containers
>> here: http://tomcat.apache.org/tomcat-7.0-doc/class-loader-howto.html
>>
>> People will most likely see this exception when it is encountered:
>>
>> Caused by: org.omg.CORBA.INITIALIZE: can't instantiate default ORB
>> implementation com.sun.corba.ee.impl.orb.ORBSingleton vmcid: 0x0 minor
>> code: 0 completed: No
>> at org.omg.CORBA.ORB.create_impl_with_systemclassloader(ORB.java:309)
>> at org.omg.CORBA.ORB.init(ORB.java:294)
>>
>> I was in contact with the committer from Oracle today.  He says this is
>> not a bug, but they admit that the documentation on the change was poor and
>> they've been getting a fair amount of issues filed about it in their bug
>> database (http://bugs.java.com).  I believe they aim on remedying this.
>>
>> So I'm left with a question to the experienced JacORB developers:
>>
>> Is there a way that I can distribute JacORB within a WAR file and have it
>> work given the breaking change in the JRE?  I was basically just doing this:
>>
>> Properties props = new Properties();
>> props.setProperty("org.omg.CORBA.ORBClass", "org.jacorb.orb.ORB");
>> props.setProperty("org.omg.CORBA.ORBSingletonClass",
>> "org.jacorb.orb.ORBSingleton");
>> org.jacorb.orb.ORB orb = (org.jacorb.orb.ORB) org.omg.CORBA.ORB.init(args,
>> props);
>>
>> I know the JacORB docs always mention supplying the ORB to the
>> bootclasspath (http://www.jacorb.org/TomcatHowto.html), but I didn't seem
>> to have any problems just bundling it into the WAR itself.
>>
>> Any tips would be appreciated,
>>
>> --
>> Tim Astle
>> _______________________________________________
>> jacorb-developer maillist  -  jacorb-developer at lists.spline.
>> inf.fu-berlin.de
>> https://lists.spline.inf.fu-berlin.de/mailman/listinfo/jacorb-developer
>>
> _______________________________________________
> jacorb-developer maillist  -  jacorb-developer at lists.spline.inf.fu-berlin.de
> https://lists.spline.inf.fu-berlin.de/mailman/listinfo/jacorb-developer
>
>

-- 
Tim Astle
Development Manager
Web Technologies

*CARIS* <http://www.caris.com>
115 Waggoners Lane
Fredericton, New Brunswick
Canada    E3B 2L4
Tel: +1.506.458.8533     Fax: +1.506.459.3849
www.caris.com

*CARIS 2014*
June 2-5, 2014 | Brest, France | 2-5 juin, 2014
Join us in France at CARIS 2014 as we focus on Developing the Blue 
Economy. www.caris.com/caris2014/
Venez nous rejoindre en France pour CARIS 2014 et appuyons ensemble 
l'Économie Bleue. www.caris.com/caris2014-fr/

Download your free copy of CARIS Easy View today!
www.caris.com/easyview

_________________________________________________________________________
This email and any files transmitted with it are confidential and 
intended only for the addressee(s). If you are not the intended 
recipient(s) please notify us by email reply. You should not use, 
disclose, distribute or copy this communication if received in error.

Any views or opinions expressed in this email are solely those of the 
author and do not necessarily represent those of the company. No binding 
contract will result from this email until such time as a written 
document is signed on behalf of the company.



More information about the jacorb-developer mailing list