From Fedora Project Wiki
No edit summary
 
(36 intermediate revisions by 3 users not shown)
Line 1: Line 1:
{{admon/tip | Guidance | For details on how to fill out this form, see the [https://docs.fedoraproject.org/en-US/program_management/changes_guide/ documentation].}}
<!-- The actual name of your proposed change page should look something like: Changes/Your_Change_Proposal_Name.  This keeps all change proposals in the same namespace -->


= Adjust java/java-devel requires to multi-vendor JDK world and replace legacy JDKs by third party Eclipse Temurin repositories =
= Adjust java/java-devel requires to multi-vendor JDK world and replace legacy JDKs by third party Eclipse Temurin repositories =


{{Change_Proposal_Banner}}


== Summary ==
== Summary ==
Line 18: Line 14:
* rcm ticket: https://pagure.io/releng/issue/TODO
* rcm ticket: https://pagure.io/releng/issue/TODO
* named side tag ticket: tbd
* named side tag ticket: tbd
* FESCo shepherd: [[User:FASAccountName| Shehperd name]] <email address>




== Current status ==
== Current status ==
[[Category:ChangePageIncomplete]]
[[Category:ChangeAcceptedF42]]
<!-- When your change proposal page is completed and ready for review and announcement -->
<!-- When your change proposal page is completed and ready for review and announcement -->
<!-- remove Category:ChangePageIncomplete and change it to Category:ChangeReadyForWrangler -->
<!-- remove Category:ChangePageIncomplete and change it to Category:ChangeReadyForWrangler -->
Line 39: Line 34:
ON_QA -> change is fully code complete
ON_QA -> change is fully code complete
-->
-->
* Writing in progress <!-- [Announced] -->
* done
* [<will be assigned by the Wrangler> Discussion thread]
* [https://lists.fedoraproject.org/archives/list/devel-announce@lists.fedoraproject.org/thread/AKNHHXKEEKGHIAALVDOHX3IWIS3Y77LG/ Announced]
* FESCo issue: <will be assigned by the Wrangler>
* [https://discussion.fedoraproject.org/t/f42-change-proposal-third-party-legacy-jdks-system-wide/132049 Discussion thread]
* Tracker bug: <will be assigned by the Wrangler>
* FESCo issue: [https://pagure.io/fesco/issue/3277 #3277]
* FESCo exception/denial to enable temurin repos by default: todo by maintainer once appropriate
* Tracker bug: [https://bugzilla.redhat.com/show_bug.cgi?id=2319402 #2319402]
* Release notes tracker: <will be assigned by the Wrangler>
* Release notes tracker: <will be assigned by the Wrangler>


Line 50: Line 47:
* RPMs can be easily integrated. Remaining issues are summed up at: https://github.com/adoptium/installer/issues/848 ;  but they do not block immediate usage
* RPMs can be easily integrated. Remaining issues are summed up at: https://github.com/adoptium/installer/issues/848 ;  but they do not block immediate usage
* RPM with repository on review: https://bugzilla.redhat.com/show_bug.cgi?id=2313339
* RPM with repository on review: https://bugzilla.redhat.com/show_bug.cgi?id=2313339
* repos will be shifted from f42 onwards only
* JDKs will be obsoleted  from f42 onwards only. The Repository may be available also for older Fedoras, as they can coexists.
* to keep en system-jdk idea as it is, the requires of "java", "java-devel" and "java-headless" will be revisited
* to keep en system-jdk idea as it is, the requires of "java", "java-devel" and "java-headless" were revisited
** current idea is to encapsulate them to "javapackages-tools", "javapackages-tools-devel" and "javapackages-tools-headless" which handles system JDK anyway in user independent way (https://fedoraproject.org/wiki/Changes/Decouple_system_java_setting_from_java_command_setting#Summary)
** those will be encapsulated them to "javapackages-tools" and "javapavckages-local" which handles system JDK anyway in user independent way (https://fedoraproject.org/wiki/Changes/Decouple_system_java_setting_from_java_command_setting#Summary)
** the documentation of https://docs.fedoraproject.org/en-US/packaging-guidelines/Java/#_buildrequires_and_requires will be updated
** the documentation of https://docs.fedoraproject.org/en-US/packaging-guidelines/Java/#_buildrequires_and_requires will be updated
* RPM with Eclispe-temurin repository will be created (https://docs.fedoraproject.org/en-US/workstation-working-group/third-party-repos/)
** all non-system LTS JDKs will be orphaned or replaced by obsoleting package with possible dependency on the repository wrapper)
* then all non-system LTS JDKs will be orphaned or replaced by obsoleting package with possible dependency on the repository wrapper)


As 'Change Checkpoint: Proposal submission deadline (System Wide Changes) Tue 2024-12-24' and 'Branch Fedora Linux 42 from Rawhide Tue 2025-02-04' is in reasonable time, we hope to finish all peacefully (as all initial tests are already finished).
As 'Change Checkpoint: Proposal submission deadline (System Wide Changes) Tue 2024-12-24' and 'Branch Fedora Linux 42 from Rawhide Tue 2025-02-04' is in reasonable time, we hope to finish all peacefully (as all initial tests are already finished).


== Detailed Description ==
== Detailed Description ==
 
<!--
{{admon/important | JDK TEAM NOTE: | in el10 there is only one jdk, however, the non binding java/java-devel, and all the whole "system jdk in javapackages-tools" is quite a precedent for it, and considering we will be updating system jdk in el aprox 3x, we should take exceptional care here, as it may solve - or bite back - the issue we are facin gin el9 now}}
{{admon/important | JDK TEAM NOTE: | in el10 there is only one jdk, however, the non binding java/java-devel, and all the whole "system jdk in javapackages-tools" is quite a precedent for it, and considering we will be updating system jdk in el aprox 3x, we should take exceptional care here, as it may solve - or bite back - the issue we are facin gin el9 now}}
 
-->
Fedora currently ships:
Fedora currently ships:
* java-1.8.0-openjdk (LTS)
* java-1.8.0-openjdk (LTS)
Line 69: Line 65:
* java-21-openjdk (LTS), system JDK
* java-21-openjdk (LTS), system JDK
* java-latest-openjdk (STS) - currently JDK22, soon JDK23, in time of finish JDK24
* java-latest-openjdk (STS) - currently JDK22, soon JDK23, in time of finish JDK24
* In future, java-25-openjdk will fork from java-latest-openjdk, and will become system jdk, as jdk21 before (https://fedoraproject.org/wiki/Changes/Java21#java-21-openjdk_as_the_system_JDK_in_F40) and jdk17 before that and so on...
* In future, java-25-openjdk (LTS) will fork from java-latest-openjdk, and will become system jdk, as jdk21 before (https://fedoraproject.org/wiki/Changes/Java21#java-21-openjdk_as_the_system_JDK_in_F40) and jdk17 before that and so on...
** java-21-openjdk will then follow the fate of java-17-openjdk, 11 and 1.8.0 as written lower.
** java-21-openjdk will then follow the fate of java-17-openjdk, 11 and 1.8.0 as written lower.


We, OpenJDK maintainers in Fedora, would like to orphan/close non system JDKs in favor of Temurin JDKs. Adoptium Temurin (https://adoptium.net/temurin/releases/) is de-facto standard build of JDK, with huge support and compatibility, and all current Fedora JDK contributors are long term members and contributors to Temrun JDK (and its RPMs).
We, OpenJDK maintainers in Fedora, would like to orphan/retire non system JDKs in favor of Temurin JDKs. Adoptium Temurin (https://adoptium.net/temurin/releases/) is de-facto standard build of JDK, with huge support and compatibility, and all current Fedora JDK contributors are long term members and contributors to Temrun JDK (and its RPMs).
Adoptium is dedicated, to keep Temurin RPMs well integrated and healthy for Fedora. Adoptium efforts are tracked in https://github.com/adoptium/installer/issues/848 . Adoptium is maintaining theirs repos
Adoptium is dedicated, to keep Temurin RPMs well integrated and healthy for Fedora. Adoptium efforts are tracked in https://github.com/adoptium/installer/issues/848 . Adoptium is maintaining theirs repos
(https://adoptium.net/installation/linux/#_centosrhelfedora_instructions) for ages, and they're heavily used.
(https://adoptium.net/installation/linux/#_centosrhelfedora_instructions) for ages, and they're heavily used.


Practically We see several approaches:
=== Practically We see several approaches: ===
* simply orphan jdk 8,11 and 17 (in f42 the only system JDK will be 21)
# simply orphan jdk 8,11 and 17 (in time of f42 the only system JDK will be 21 over all live fedoras)
** However past (orphaning of jdk 6 and 7 ) had learned us a lesson that avarage packager (despite being experienced java/C programmer) is unable to maintain OpenJDK packages
## However past (orphaning of jdk 6 and 7 ) had learned us a lesson that avarage packager (despite being experienced java/C programmer) is unable to maintain OpenJDK packages
* orphan the packages and close them. enhance https://docs.fedoraproject.org/en-US/quick-docs/installing-java/ that non system JDK can be installed after enabling the adoptium repos (https://adoptium.net/installation/linux/#_centosrhelfedora_instructions)
## note that it means, that  the packages would be orphaned also in  older fedoras
* provide rpm which will contain the 3d party repository\
# orphan (including the orphaning in f40+f41) or retire in f42++
** integrate it with gnome software and and fedora setup of 3rd party repos
## enhance https://docs.fedoraproject.org/en-US/quick-docs/installing-java/ that non system JDK can be installed after enabling the adoptium repos (https://adoptium.net/installation/linux/#_centosrhelfedora_instructions)
** we would like try to do an fluent transition - so the current 8,11 and 17 packages will also install the rpm wiht repository files and thus once we remove jdk8-17 (or future) from distribution, they will be smoothly updated by temurin jdk (with check if other 3rd party repos are enabled)
# orphan (including the orphaning in f40+f41) or retire in f42++
## provide rpm which will contain the 3d party repository
## enhance https://docs.fedoraproject.org/en-US/quick-docs/installing-java/ informing about that
# orphan (including the orphaning in f40+f41) or retire in f42++
## provide rpm which will contain the 3d party repository\
## enhance https://docs.fedoraproject.org/en-US/quick-docs/
# orphan (including the orphaning in f40+f41) or retire in f42++
## provide rpm which will contain the 3d party repository
## `obsolate` will be handled via the above repository rpm
## integrate it with gnome software and and fedora setup of 3rd party repos
## we would like try to do an fluent transition - so the current 8,11 and 17 packages will also install the rpm wiht repository files and thus once we remove jdk8-17 (or future) from distribution, they will be smoothly updated by temurin jdk (with check if other 3rd party repos are enabled)
### not sure if this technically possible nor correct
 
I'm voting for option 5, without the hard 5.4 requirement (so worthy to try, but not not invasivly nor mandatory)


java-latest-openjdk remain also maintained in Koji, as it is necessary testing ground for future system JDK.
java-latest-openjdk remain also maintained in Koji, as it is necessary testing ground for future system JDK.
Line 90: Line 99:
jdk 23+21. In some short time, we will maintain 25+21, a bit alter 26+25+21... And once 25 will become system JDK in all live fedoras, we will ditch 21 in favor of Temurins
jdk 23+21. In some short time, we will maintain 25+21, a bit alter 26+25+21... And once 25 will become system JDK in all live fedoras, we will ditch 21 in favor of Temurins


=== java packages requires mass change ===
=== java packages `requires` mass change ===
In original draft, we had an intention to remove versionless (eg java, javac, java-devel..) from Eclipse Temurin JRE/JDK, however we found that it would be exceptionally negative step considering current state of java. Many vendors - from Oracle, over Azul, Red Hat, Amazon to Eclipse Adptium, offers 3rd party repositories with theirs javas, or at least place to download binaries - including rpms - and all of them provides at least java, and most of them also javac and java-devel. We get inspiration from https://fedoraproject.org/wiki/Changes/Drop_Mandatory_Requires_on_JRE and we would like to gain an advantage from all this. Thus java, and java-devel will remain global requires, which will be satisfied by any LTS java.</br>
The javastack (via javapackages-tools) will be reworked to:
'''below section will be dropped'''</br>
*encapsulate dependencies on system jdk (or any other koji-based jdk) to javapackages tools
To keep an system JDK concept as we have it now, we would like to replace mandatory requires on java/java-devel by javapackaes-tools(-headless,-devel). Except aligning with above java/javac  "globally available provides" and  "dropping of mandatory requirements", most of the java packages do not require java/javac.  They already require javapackages-tools, for runtime, and maven/ant (or similar) for buildtime, so this change will affect only 14 from aprox. 400 packages we mass rebuild during system JDK bump. Those will be fixed manually. Not sure if this can be considered mass rebuild.</br>
*allow any application to work on any, even 3rd party java
</br>
 
'''and replaced by resutls of meeting with javasig members:'''</br>
This should be achieved via following chnages to reqires changes and generated changes:
FIXME: It seems that not that much playing with provides is necessary
*`javapackages-local` for packages with `ant` or no build - `requires java-%{system}-openjdk-devel` (`%jpackage_script`)
* https://issues.redhat.com/browse/RHEL-54070
**`javapavckages-local%VERSIONED` for older ones
** Decouple javastack to run with any jdk - even not rpm ones
**For slower transitions to newer jdks
* Javapackages-local for packages with ant and no build - requires java-system-openjdk-devel (%jpackage_script)
*`javapackages-tools`
** Javapavckages-local%VERSIONED for older ones
**`requires java-%{system}-openjdk-headless`
*Headless jpackage script currently do not support headless. Will be worthy to do
**`javapackages-tools%VERSIONED` for older ones
** java-sig is already on that
**Do not requires java-%{system}-openjdk
** `%jpackage_script` macro goes with requires to system jdk too
***'''Will not be added''' - satisfied by Javapackages-tools with java || java-xyz-openjdk requires
Other packages will need to manually adjust from java-system-openjdk-/headless/devel to java-(system+1)-openjdk-/headless/devel
* Requires generator which crawls through launchers of packages (including `jpackage_script` ) which source `java_functions`
This affects mass rebuilds (instead of just release++ a java-xy-openjdk must do xy++). Positive si that there is more time to do that (as much time as the latest jdk is kept, that is while it is system jdk in some fedora, that measn 2-3 releases
** will be pointing to used jre headless
* Runtime requires:
**`%jpackage_script` is implicitly affected by generator and will generate requires to corresponding `%{build_time_sdk's}-headless jre`  (which is currently system jdk, which is jdl 21, unless specified differently)
** Jpackage script dependency generator should generate them, otherwise use versioned java
*Other packages will need to manually adjust from `java-%{system}-openjdk-/headless/devel` to `java-(system+1)-openjdk-/headless/devel`
**This affects mass rebuilds (instead of just release++ a java-xy-openjdk must do xy++). Positive si that there is more time to do that  
** Indirectly this is '''not enforcing''' new system jdk when new LTS is promoted in Fedora
***Otherwise generic `java-devel` will no longer satisfy new systemjdk after system bump
 
*`JAVA_HOME` remains main override (rpm generated requires are not affected (maybe todo?))
 
 
https://docs.fedoraproject.org/en-US/packaging-guidelines/Java/ will be adjusted accordingly
 
the packages built by pure javac or jsut build requires java without any javapackages tools will be adjsuted manually
 
'''Note, that this is much smaller effort then it looks like. 99% of packages are living with generated provides, and will get the change automagically. The remaining - aprox 10 - packages will be handled manually'''
 
=== adoptium-temurin-java-repository ===
* the adoptium repository is provided via '''adoptium-temurin-java-repository package'''
** review: https://bugzilla.redhat.com/show_bug.cgi?id=2313339
** sources https://src.fedoraproject.org/rpms/adoptium-temurin-java-repository
** builds https://koji.fedoraproject.org/koji/packageinfo?packageID=41159
* This package is available since  f39 over epel 8 and 9 up to future. Since f42 it will be obsoleting retired java-(1.8.0,11,17)-openjdk-*
* repository is disabled by default
* can be enabled by gnome-software or via its repo file
* installs:
** temurin-11-jdk
** temurin-11-jre
** temurin-17-jdk
** temurin-17-jre
** temurin-21-jdk
** temurin-21-jre
** temurin-22-jdk
** temurin-22-jre
** temurin-23-jdk
** temurin-23-jre
** temurin-8-jdk
** temurin-8-jre
* Warning, jdk contains both jre and jdk, so if you install jdk and jre (of same version) you will have two java  alternatives masters, and one javac master.
 
sudo dnf install  adoptium-temurin-java-repository


* Versioned -local packages?
==== Known issues ====
** Not a good practise
list of known regressions is:
* What about non-RPM Java?
* https://github.com/adoptium/installer/issues/848#issuecomment-2133516101
** Will work it out per package
It may be beter to report bugs here rather then in fedora bugzilla


== Feedback ==
== Feedback ==
<!-- Summarize the feedback from the community and address why you chose not to accept proposed alternatives. This section is optional for all change proposals but is strongly suggested. Incorporating feedback here as it is raised gives FESCo a clearer view of your proposal and leaves a good record for the future. If you get no feedback, that is useful to note in this section as well. For innovative or possibly controversial ideas, consider collecting feedback before you file the change proposal. -->
<!-- Summarize the feedback from the community and address why you chose not to accept proposed alternatives. This section is optional for all change proposals but is strongly suggested. Incorporating feedback here as it is raised gives FESCo a clearer view of your proposal and leaves a good record for the future. If you get no feedback, that is useful to note in this section as well. For innovative or possibly controversial ideas, consider collecting feedback before you file the change proposal. -->
todo
The feedback from devel thread was moreover positive. Many things needed to be clarified, but all was clarified at the end.


== Benefit to Fedora ==
== Benefit to Fedora ==
Line 147: Line 193:
-->
-->
The number of legacy JDKs have grown, and hand in hand with that the number of theirs usages dropped to minimum. It seems there is no longer any need to maintain them, as theirs usage is only highly specialized.
The number of legacy JDKs have grown, and hand in hand with that the number of theirs usages dropped to minimum. It seems there is no longer any need to maintain them, as theirs usage is only highly specialized.
By providing 3rd party repo, we allow the specialized use-cases to continue to exist. By discontinuing theirs build in koji we well untie or hands to move forward and focus on future JDKs. Also we will enable fedora to provide highly stable, often updated, secure, 100% integrate-able and passionately maintained builds of legacy JDKs, which will serve as proper replacement if really needed.
By providing 3rd party repo, we allow the specialized use-cases to continue to exist. By discontinuing theirs build in koji we well untie or hands to move forward and focus on future JDKs. Also we will enable fedora to provide highly stable, often updated, secure, 100% integrate-able and passionately maintained builds of legacy JDKs, which will serve as proper replacement if really needed. As a side effect of the changes in `provides/requires`, we will allow every JDK, from any vendor, which follows unofficial packaging JEP (which covers java and javac alternatives master and java/java-devel provides) to be effectively part of system if wanted, and not just silent companion.
=== More time for pacakges to react to new LTS ===
Another positive is more time for packages to adapt and/or die faster. Currently, if package was unable to adjsut to new system JDK, the package was moved to require exactly one, versioned, known newest java it worked with. And so it very often went rotten. Now, if new LTS is introduced, the package will still work with the previous one, until the owner decides to really move on. If not, then this package will die by its own in *one year*, when "it's" jdk will be removed from fedora


== Scope ==
== Scope ==
Line 161: Line 209:
* Other developers: <!-- REQUIRED FOR SYSTEM WIDE CHANGES -->
* Other developers: <!-- REQUIRED FOR SYSTEM WIDE CHANGES -->
<!-- What work do other developers have to accomplish to complete the feature in time for release?  Is it a large change affecting many parts of the distribution or is it a very isolated change? What are those changes?-->
<!-- What work do other developers have to accomplish to complete the feature in time for release?  Is it a large change affecting many parts of the distribution or is it a very isolated change? What are those changes?-->
** we will need help from javapackages-tools, maven and ant maintainers, to totally decuple system jdk from installed java
** javapackages-tools, maven and ant maintainers are already on board to to totally decuple system jdk from installed java


* Release engineering: [https://pagure.io/releng/issues #Releng issue number] <!-- REQUIRED FOR SYSTEM WIDE CHANGES -->
* Release engineering: [https://pagure.io/releng/issues #Releng issue number] <!-- REQUIRED FOR SYSTEM WIDE CHANGES -->
Line 182: Line 230:
<!-- What happens to systems that have had a previous versions of Fedora installed and are updated to the version containing this change? Will anything require manual configuration or data migration? Will any existing functionality be no longer supported? -->
<!-- What happens to systems that have had a previous versions of Fedora installed and are updated to the version containing this change? Will anything require manual configuration or data migration? Will any existing functionality be no longer supported? -->
No meter what approach will be selected at the end, there will be upgrade impact.
No meter what approach will be selected at the end, there will be upgrade impact.
* in ideal usecase, the JDKs from koji simply replaces themselves by those from Eclipse Temurin
* if user had legacy JDKs, after update the jdks will be gone and users will get just disabled 3rd party repo and information what to install
* in worst case, user will just get disabled 3rd party repo and updated docs.


In all cases system jdk will remain on machine, and in all cases legacy jdks will be replaced or disappear. I would really be unhappy to simply discontinue them, and leave unmaintained software on target boxes.
In all cases system jdk will remain on machine


<!-- REQUIRED FOR SYSTEM WIDE CHANGES -->
<!-- REQUIRED FOR SYSTEM WIDE CHANGES -->
Line 219: Line 266:


Only legacy JDK
Only legacy JDK
#  get system withotu any JDK
#  get system without any JDK
#  manually install any of legacy LTS jdks
#  manually install any of legacy LTS jdks
#  update to next fedora
#  update to next fedora
#  the legacy jdk should not be there or should be gone
#  the legacy jdk should not be there, should be gone
#  temurin repository should be there
#  you should be able to install legacy temurin jdks


System JDK and legacy JDK
System JDK and legacy JDK
Line 229: Line 278:
#  update to next fedora
#  update to next fedora
#  system JDK should be there
#  system JDK should be there
#  the legacy jdk should not be there or should be gone
#  the legacy jdk should not be there, should be gone
#  temurin repository should be there
#  you should be able to install legacy temurin jdks


<!-- REQUIRED FOR SYSTEM WIDE CHANGES -->
<!-- REQUIRED FOR SYSTEM WIDE CHANGES -->
=== Minecraft ===
There were concerns in discussion thread, that Minecraft may have issues to run, or to be modded. This usecase is valuable, and I would like to prevent any loses on fedora Minecraft community.


== User Experience ==
== User Experience ==
Line 265: Line 318:
== Documentation ==
== Documentation ==
<!-- Is there upstream documentation on this change, or notes you have written yourself?  Link to that material here so other interested developers can get involved. -->
<!-- Is there upstream documentation on this change, or notes you have written yourself?  Link to that material here so other interested developers can get involved. -->
Only eclipse temurin install pages and java packages guidelines


* todo link1
Please use https://fedoraproject.org/wiki/Changes/ThirdPartyLegacyJdks#Release_Notes
* todo link2


== Release Notes ==
== Release Notes ==
Line 276: Line 327:
Release Notes are not required for initial draft of the Change Proposal but has to be completed by the Change Freeze.  
Release Notes are not required for initial draft of the Change Proposal but has to be completed by the Change Freeze.  
-->
-->
tbd
 
* `java-1.8.0-openjdk`, j`ava-11-openjdk` and `java-17-openjdk` are now '''''deprecated''''', in '''f39, f40 and f41
** they print laud and clear message out
* `java-1.8.0-openjdk`, `java-11-openjdk` and `java-17-openjdk` are '''''retired''''' in '''f42'''
* people who needs those packages are provided by `adoptium-temurin-java-repository package` package providing repository, which allows them to install:
** temurin-8-jdk
** temurin-8-jre
** temurin-11-jdk
** temurin-11-jre
** temurin-17-jdk
** temurin-17-jre
** temurin-21-jdk
** temurin-21-jre
 
Note the: https://fedoraproject.org/wiki/Changes/ThirdPartyLegacyJdks#Known_issues
 
* adoptium-temurin-java-repository is '''available''' since f39 onward
* adoptium-temurin-java-repository since f42 '''obsolete''' `java-1.8.0-openjdk`, j`ava-11-openjdk` and `java-17-openjdk`

Latest revision as of 11:26, 13 November 2024

Adjust java/java-devel requires to multi-vendor JDK world and replace legacy JDKs by third party Eclipse Temurin repositories

Summary

Adjust java/java-devel provides/requires to multivendor world and obsolete all non-system LTS JDKs (java-1.8.0-openjdk, java-11-openjdk, java-17-openjdk in time of writing) by appropriate, properly integrating, RPMs from Eclipse Adoptium repositories.

Owner


Current status

  • Targeted release: Fedora Linux 42
  • Last updated: 2024-11-13
  • done
  • Announced
  • Discussion thread
  • FESCo issue: #3277
  • FESCo exception/denial to enable temurin repos by default: todo by maintainer once appropriate
  • Tracker bug: #2319402
  • Release notes tracker: <will be assigned by the Wrangler>

Expected schedule

As 'Change Checkpoint: Proposal submission deadline (System Wide Changes) Tue 2024-12-24' and 'Branch Fedora Linux 42 from Rawhide Tue 2025-02-04' is in reasonable time, we hope to finish all peacefully (as all initial tests are already finished).

Detailed Description

Fedora currently ships:

  • java-1.8.0-openjdk (LTS)
  • java-11-openjdk (LTS)
  • java-17-openjdk (LTS)
  • java-21-openjdk (LTS), system JDK
  • java-latest-openjdk (STS) - currently JDK22, soon JDK23, in time of finish JDK24
  • In future, java-25-openjdk (LTS) will fork from java-latest-openjdk, and will become system jdk, as jdk21 before (https://fedoraproject.org/wiki/Changes/Java21#java-21-openjdk_as_the_system_JDK_in_F40) and jdk17 before that and so on...
    • java-21-openjdk will then follow the fate of java-17-openjdk, 11 and 1.8.0 as written lower.

We, OpenJDK maintainers in Fedora, would like to orphan/retire non system JDKs in favor of Temurin JDKs. Adoptium Temurin (https://adoptium.net/temurin/releases/) is de-facto standard build of JDK, with huge support and compatibility, and all current Fedora JDK contributors are long term members and contributors to Temrun JDK (and its RPMs). Adoptium is dedicated, to keep Temurin RPMs well integrated and healthy for Fedora. Adoptium efforts are tracked in https://github.com/adoptium/installer/issues/848 . Adoptium is maintaining theirs repos (https://adoptium.net/installation/linux/#_centosrhelfedora_instructions) for ages, and they're heavily used.

Practically We see several approaches:

  1. simply orphan jdk 8,11 and 17 (in time of f42 the only system JDK will be 21 over all live fedoras)
    1. However past (orphaning of jdk 6 and 7 ) had learned us a lesson that avarage packager (despite being experienced java/C programmer) is unable to maintain OpenJDK packages
    2. note that it means, that the packages would be orphaned also in older fedoras
  2. orphan (including the orphaning in f40+f41) or retire in f42++
    1. enhance https://docs.fedoraproject.org/en-US/quick-docs/installing-java/ that non system JDK can be installed after enabling the adoptium repos (https://adoptium.net/installation/linux/#_centosrhelfedora_instructions)
  3. orphan (including the orphaning in f40+f41) or retire in f42++
    1. provide rpm which will contain the 3d party repository
    2. enhance https://docs.fedoraproject.org/en-US/quick-docs/installing-java/ informing about that
  4. orphan (including the orphaning in f40+f41) or retire in f42++
    1. provide rpm which will contain the 3d party repository\
    2. enhance https://docs.fedoraproject.org/en-US/quick-docs/
  5. orphan (including the orphaning in f40+f41) or retire in f42++
    1. provide rpm which will contain the 3d party repository
    2. obsolate will be handled via the above repository rpm
    3. integrate it with gnome software and and fedora setup of 3rd party repos
    4. we would like try to do an fluent transition - so the current 8,11 and 17 packages will also install the rpm wiht repository files and thus once we remove jdk8-17 (or future) from distribution, they will be smoothly updated by temurin jdk (with check if other 3rd party repos are enabled)
      1. not sure if this technically possible nor correct

I'm voting for option 5, without the hard 5.4 requirement (so worthy to try, but not not invasivly nor mandatory)

java-latest-openjdk remain also maintained in Koji, as it is necessary testing ground for future system JDK.

It was never an intention to repack a binary Temurin blob in Koji (just in case anybody will think about it). It is not an intention to get rid of maintaining System JDK. However once JDK will no longer be System jdk in any live Fedora, it will be orphaned/closed in favor of Temurin JDK. So once f42 will go out we will continue to maintain only jdk 23+21. In some short time, we will maintain 25+21, a bit alter 26+25+21... And once 25 will become system JDK in all live fedoras, we will ditch 21 in favor of Temurins

java packages requires mass change

The javastack (via javapackages-tools) will be reworked to:

  • encapsulate dependencies on system jdk (or any other koji-based jdk) to javapackages tools
  • allow any application to work on any, even 3rd party java

This should be achieved via following chnages to reqires changes and generated changes:

  • javapackages-local for packages with ant or no build - requires java-%{system}-openjdk-devel (%jpackage_script)
    • javapavckages-local%VERSIONED for older ones
    • For slower transitions to newer jdks
  • javapackages-tools
    • requires java-%{system}-openjdk-headless
    • javapackages-tools%VERSIONED for older ones
    • Do not requires java-%{system}-openjdk
      • Will not be added - satisfied by Javapackages-tools with java || java-xyz-openjdk requires
  • Requires generator which crawls through launchers of packages (including jpackage_script ) which source java_functions
    • will be pointing to used jre headless
    • %jpackage_script is implicitly affected by generator and will generate requires to corresponding %{build_time_sdk's}-headless jre (which is currently system jdk, which is jdl 21, unless specified differently)
  • Other packages will need to manually adjust from java-%{system}-openjdk-/headless/devel to java-(system+1)-openjdk-/headless/devel
    • This affects mass rebuilds (instead of just release++ a java-xy-openjdk must do xy++). Positive si that there is more time to do that
    • Indirectly this is not enforcing new system jdk when new LTS is promoted in Fedora
      • Otherwise generic java-devel will no longer satisfy new systemjdk after system bump
  • JAVA_HOME remains main override (rpm generated requires are not affected (maybe todo?))


https://docs.fedoraproject.org/en-US/packaging-guidelines/Java/ will be adjusted accordingly

the packages built by pure javac or jsut build requires java without any javapackages tools will be adjsuted manually

Note, that this is much smaller effort then it looks like. 99% of packages are living with generated provides, and will get the change automagically. The remaining - aprox 10 - packages will be handled manually

adoptium-temurin-java-repository

sudo dnf install  adoptium-temurin-java-repository

Known issues

list of known regressions is:

It may be beter to report bugs here rather then in fedora bugzilla

Feedback

The feedback from devel thread was moreover positive. Many things needed to be clarified, but all was clarified at the end.

Benefit to Fedora

The number of legacy JDKs have grown, and hand in hand with that the number of theirs usages dropped to minimum. It seems there is no longer any need to maintain them, as theirs usage is only highly specialized. By providing 3rd party repo, we allow the specialized use-cases to continue to exist. By discontinuing theirs build in koji we well untie or hands to move forward and focus on future JDKs. Also we will enable fedora to provide highly stable, often updated, secure, 100% integrate-able and passionately maintained builds of legacy JDKs, which will serve as proper replacement if really needed. As a side effect of the changes in provides/requires, we will allow every JDK, from any vendor, which follows unofficial packaging JEP (which covers java and javac alternatives master and java/java-devel provides) to be effectively part of system if wanted, and not just silent companion.

More time for pacakges to react to new LTS

Another positive is more time for packages to adapt and/or die faster. Currently, if package was unable to adjsut to new system JDK, the package was moved to require exactly one, versioned, known newest java it worked with. And so it very often went rotten. Now, if new LTS is introduced, the package will still work with the previous one, until the owner decides to really move on. If not, then this package will die by its own in *one year*, when "it's" jdk will be removed from fedora

Scope

  • Proposal owners:
    • will provide and maintain the 3rd party repo - https://bugzilla.redhat.com/show_bug.cgi?id=2313339
    • will help to integrate it with gnome-software and other 3rd party repos units
    • will orphan or replace (based on agreement on details
    • will update java packages documentation
    • we will fix all the direct requires java/java-devel (aprox 14 only)
    • we will communicate with packagers of known, remainingm packages which do not run with system jdk (aprox 5 )
  • Other developers:
    • javapackages-tools, maven and ant maintainers are already on board to to totally decuple system jdk from installed java
  • Policies and guidelines: N/A (not needed for this Change)
    • java packaging guidelines will be updated
  • Trademark approval: N/A (not needed for this Change)
  • Alignment with the Fedora Strategy:
    • This proposal is aligned with Fedora mission - to be on top of technology. We want to focus on newer JDKs, and still provide comfortable access to legacy ones,

Upgrade/compatibility impact

No meter what approach will be selected at the end, there will be upgrade impact.

  • if user had legacy JDKs, after update the jdks will be gone and users will get just disabled 3rd party repo and information what to install

In all cases system jdk will remain on machine


Early Testing (Optional)

Do you require 'QA Blueprint' support? Y

How To Test

No JDK on system

  1. get system without java
  2. update to next fedora
  3. no JDK should be there

Only system JDK on system and future STS jdk

  1. get system with system jdk only
  2. update to next fedora
  3. JDK should be there

Only legacy JDK

  1. get system without any JDK
  2. manually install any of legacy LTS jdks
  3. update to next fedora
  4. the legacy jdk should not be there, should be gone
  5. temurin repository should be there
  6. you should be able to install legacy temurin jdks

System JDK and legacy JDK

  1. get system with system jdk only
  2. manually install any of legacy LTS jdks
  3. update to next fedora
  4. system JDK should be there
  5. the legacy jdk should not be there, should be gone
  6. temurin repository should be there
  7. you should be able to install legacy temurin jdks

Minecraft

There were concerns in discussion thread, that Minecraft may have issues to run, or to be modded. This usecase is valuable, and I would like to prevent any loses on fedora Minecraft community.

User Experience

As already described, basic users should not notice change. Advanced users should not lost.

Dependencies

Several (less then 10) packages will lost theirs main dependencies. Those list will be enumerated. Those packages will need to orphan and move to different kind of distribution or update. Main java stack - the packages depending on system java/java-devel/java-headless/java-packages-tools and similar, should not notice change.

Contingency Plan

  • Contingency mechanism: If we fails to introduce Eclipse Temurin JDKs repo, we will simply orphan legacy JDKs as written earlier
  • Contingency deadline: 1. December 2024
  • Blocks release? Yes


Documentation

Please use https://fedoraproject.org/wiki/Changes/ThirdPartyLegacyJdks#Release_Notes

Release Notes

  • java-1.8.0-openjdk, java-11-openjdk and java-17-openjdk are now deprecated, in f39, f40 and f41
    • they print laud and clear message out
  • java-1.8.0-openjdk, java-11-openjdk and java-17-openjdk are retired in f42
  • people who needs those packages are provided by adoptium-temurin-java-repository package package providing repository, which allows them to install:
    • temurin-8-jdk
    • temurin-8-jre
    • temurin-11-jdk
    • temurin-11-jre
    • temurin-17-jdk
    • temurin-17-jre
    • temurin-21-jdk
    • temurin-21-jre

Note the: https://fedoraproject.org/wiki/Changes/ThirdPartyLegacyJdks#Known_issues

  • adoptium-temurin-java-repository is available since f39 onward
  • adoptium-temurin-java-repository since f42 obsolete java-1.8.0-openjdk, java-11-openjdk and java-17-openjdk