Sun JDK vs OpenJDK - Sun JRE vs OpenJDK JRE

Geir Magnusson Jr. geir at pobox.com
Sat Sep 13 14:02:46 UTC 2008


On Sep 13, 2008, at 9:44 AM, Dalibor Topic wrote:

> Frans Thamura wrote:
>> anyone have a list that compare Sun JDK with OpenJDK and also OpenJDK
>> JRE with "Sun JRE
> There is no OpenJDK JRE, specifically. The comparison that makes sense
> is one between
> Sun Java SE 6 JDK and the OpenJDK jdk6 project.
>
> Differences are:
>
> a) licenses:
>
> OpenJDK jdk6 is Free Software, Sun's Java SE 6 JDK downloads are  
> not, in
> particular because
> * they contain proprietary third party components (also known as
> 'encumbrancies'), that wouldn't be trivial to rip and replace in a
> stable release series
> * they contain Sun's own proprietary code that has not been / could  
> not
> be opened up so far

Like what?  And why can't it be opened up?

>
>
> b) deployment code:
>
> OpenJDK does not have a plugin or a webstart implementation.
>
> The code Sun has in the deployment area has been largely rewritten for
> Java SE 6 update 10, and the new code,
> being a significant chunk of software, requires a new run through the
> business decision making process on Sun's side.

I thought you already made the decision to "open source" java, and  
beyond that, there's Schwartz's commitment to "open source" everything.

I know this might come across as trolling,  but I am honestly  
mystified why Sun isn't just going all-in here and just put anything  
that is their property out under the GPL (I realize there's encumbered  
stuff, but you should just jettison that stuff and get the  
replacements from the community).  Sun maintains the control they need  
for the business, and the software receives the "freedom" for which  
RMS feels it so richly deserves :)

Seriously though... why not just OSS it?


>
> Meanwhile, the IcedTea project augments the OpenJDK jdk6 project with
> independent implementations
> of the plugin and webstart, called gcjwebplugin and netx. Those
> independent implementations have a different
> set of strengths and weaknesses from Sun's implementations: they  
> work on
> 64 bit Linux, for example, a platform
> that hasn't been supported by Sun's own plugin yet. On the other hand,
> gcjwebplugin currently lacks an
> adequate Java-JavaScript integration that's required by some applets  
> to
> execute as well as expected.

Seems like Sun is using IcedTea as a kind of "shadow project"?  I  
don't follow things closely anymore, but someone was asking me about  
this the other day and I couldn't really explain it clearly.   I find  
the whole thing baffling.  Now that you are a Sun employee and  
historically have been direct and honest, can you tell us about how  
this is structured?

It appears that there are three repos of Sun-sourced Java code :

1) openjdk, which seems to be an incomplete implementation  repository  
meant to feed...

2) IcedTea, which provides build infrastructure and patches the stuff  
sun can't or doesn't want to OSS, which itself seems to have a good  
community

3) Sun's internal repo from which their Java SE product builds are  
created (confusingly referred to as the RI...), and .... from which  
the misnamed "JDK 7" builds are created from?

Is the latter true?  I've never been able to grok where the JDK 7  
stuff comes from.  I'd have thought all work would be done out here in  
the opendjk community (after all, it's been *years* since Sun  
announced the project...) but...

Any insight you can provide as an insider would be welcome.

>
>
> c) bundled code:
>
> Sun's Java SE 6 download comes with a lot of (third party) software
> bundled in, for example
> Java DB, Rhino, Visual VM, etc. OpenJDK jdk 6 project leaves such
> software out as much as possible,
> concentrating on the necessities required for a compatible
> implementation of Java SE 6.

I don't know about VisualVM, but the rest is free/open  software.  Why  
not just include those as well?

>
>
> IcedTea augments OpenJDK jdk6 with Rhino, though there is still work  
> to
> be done on making the integration seamless.
> There is also some initial work on integrating VisualVM into IcedTea.
>
> d) encumbered code:
>
> The Java SE 6 JDK still mostly contains the ~4 % of encumbered, i.e.
> third party code that couldn't be licensed as
> Free Software, and  was replaced by open source implementations from  
> the
> community in OpenJDK 6.

So why not jettison the 3rd party code and focus the community around  
the open/free stuff?  Seems like the thing to do if Java is free.  I  
can understand not doing it right off the bat, but it's been years  
now...

geir




More information about the discuss mailing list