(Created page with "{{admon/important | Comments and Explanations | The page source contains comments providing guidance to fill out each section. They are invisible when viewing this page. To read it, choose the "view source" link.<br/> '''Copy the source to a ''new page'' before making changes! DO NOT EDIT THIS TEMPLATE FOR YOUR CHANGE PROPOSAL.'''}} {{admon/tip | Guidance | For details on how to fill out this form, see the [https://docs.fedoraproject.org/en-US/program_management/change...") |
(initial load) |
||
Line 7: | Line 7: | ||
<!-- 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 --> | <!-- 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 --> | ||
= | = Replace legacy JDKs by 3rd party Eclipse Temurin repositories = | ||
{{Change_Proposal_Banner}} | {{Change_Proposal_Banner}} | ||
Line 13: | Line 13: | ||
== Summary == | == Summary == | ||
<!-- A sentence or two summarizing what this change is and what it will do. This information is used for the overall changeset summary page for each release. Note that motivation for the change should be in the Benefit to Fedora section below, and this part should answer the question "What?" rather than "Why?". --> | <!-- A sentence or two summarizing what this change is and what it will do. This information is used for the overall changeset summary page for each release. Note that motivation for the change should be in the Benefit to Fedora section below, and this part should answer the question "What?" rather than "Why?". --> | ||
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 == | == Owner == | ||
* Name: [[User:jvanek| Jiri Vanek]] | |||
* Email: <jvanek@redhat.com> | |||
* Product: java and java stack | |||
* Responsible WG: java-sig (java and java-maint)(which no longer exists) | |||
* Name: [[User: | * rcm ticket: https://pagure.io/releng/issue/TODO | ||
< | * named side tag ticket: tbd | ||
* | |||
* FESCo shepherd: [[User:FASAccountName| Shehperd name]] <email address> | * FESCo shepherd: [[User:FASAccountName| Shehperd name]] <email address> | ||
Line 33: | Line 31: | ||
<!-- The Wrangler announces the Change to the devel-announce list and changes the category to Category:ChangeAnnounced (no action required) --> | <!-- The Wrangler announces the Change to the devel-announce list and changes the category to Category:ChangeAnnounced (no action required) --> | ||
<!-- After review, the Wrangler will move your page to Category:ChangeReadyForFesco... if it still needs more work it will move back to Category:ChangePageIncomplete--> | <!-- After review, the Wrangler will move your page to Category:ChangeReadyForFesco... if it still needs more work it will move back to Category:ChangePageIncomplete--> | ||
<!-- Select proper category, default is Self Contained Change --> | <!-- Select proper category, default is Self Contained Change --> | ||
[[Category:SelfContainedChange]] | <!-- [[Category:SelfContainedChange]] --> | ||
[[Category:SystemWideChange]] | |||
* Targeted release: [https://docs.fedoraproject.org/en-US/releases/ | * Targeted release: [https://docs.fedoraproject.org/en-US/releases/f42/ Fedora Linux 42] | ||
* Last updated: <!-- this is an automatic macro — you don't need to change this line --> {{REVISIONYEAR}}-{{REVISIONMONTH}}-{{REVISIONDAY2}} | * Last updated: <!-- this is an automatic macro — you don't need to change this line --> {{REVISIONYEAR}}-{{REVISIONMONTH}}-{{REVISIONDAY2}} | ||
<!-- After the change proposal is accepted by FESCo, tracking bug is created in Bugzilla and linked to this page | <!-- After the change proposal is accepted by FESCo, tracking bug is created in Bugzilla and linked to this page | ||
Line 46: | Line 43: | ||
ON_QA -> change is fully code complete | ON_QA -> change is fully code complete | ||
--> | --> | ||
* [Announced] | * Writing in progress <!-- [Announced] --> | ||
* [<will be assigned by the Wrangler> Discussion thread] | * [<will be assigned by the Wrangler> Discussion thread] | ||
* FESCo issue: <will be assigned by the Wrangler> | * FESCo issue: <will be assigned by the Wrangler> | ||
* Tracker bug: <will be assigned by the Wrangler> | * Tracker bug: <will be assigned by the Wrangler> | ||
* Release notes tracker: <will be assigned by the Wrangler> | * Release notes tracker: <will be assigned by the Wrangler> | ||
<!-- Expand on the summary, if appropriate. A couple sentences suffices to explain the goal, but the more details you can provide the better. --> | |||
=== Expected schedule === | |||
* Eclipse Temurin repositories already exists: https://adoptium.net/installation/linux/#_centosrhelfedora_instructions | |||
* 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 | |||
* repos will be shifted from f42 onwards only | |||
* to keep en system-jdk idea as it is, the requires of "java", "java-devel" and "java-headless" will be 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) | |||
** 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/) | |||
* 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). | |||
== 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}} | |||
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 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/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). | |||
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: | |||
* simply orphan jdk 8,11 and 17 (in f42 the only system JDK will be 21) | |||
** 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) | |||
* provide rpm which will contain the 3d party repository\ | |||
** 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) | |||
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 === | |||
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, Redhat, 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. | |||
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. | |||
== 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 | |||
== Benefit to Fedora == | == Benefit to Fedora == | ||
Line 86: | Line 131: | ||
https://fedoraproject.org/wiki/Changes/perl5.26 (major upgrade to a popular software stack, visible to users of that stack) | https://fedoraproject.org/wiki/Changes/perl5.26 (major upgrade to a popular software stack, visible to users of that stack) | ||
--> | --> | ||
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. | |||
== Scope == | == Scope == | ||
* Proposal owners: | * Proposal owners: | ||
<!-- What work do the feature owners 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 the feature owners 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?--> | ||
** will provide and maintain the 3rd party repo | |||
** 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: <!-- 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 | |||
* 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 --> | ||
<!-- Does this feature require coordination with release engineering (e.g. changes to installer image generation or update package delivery)? Is a mass rebuild required? include a link to the releng issue. | <!-- Does this feature require coordination with release engineering (e.g. changes to installer image generation or update package delivery)? Is a mass rebuild required? include a link to the releng issue. | ||
The issue is required to be filed prior to feature submission, to ensure that someone is on board to do any process development work and testing and that all changes make it into the pipeline; a bullet point in a change is not sufficient communication --> | The issue is required to be filed prior to feature submission, to ensure that someone is on board to do any process development work and testing and that all changes make it into the pipeline; a bullet point in a change is not sufficient communication --> | ||
** I think the mass rebuild will not be needed | |||
* Policies and guidelines: N/A (not needed for this Change) <!-- REQUIRED FOR SYSTEM WIDE CHANGES --> | * Policies and guidelines: N/A (not needed for this Change) <!-- REQUIRED FOR SYSTEM WIDE CHANGES --> | ||
<!-- Do the packaging guidelines or other documents need to be updated for this feature? If so, does it need to happen before or after the implementation is done? If a FPC ticket exists, add a link here. Please submit a pull request with the proposed changes before submitting your Change proposal. --> | <!-- Do the packaging guidelines or other documents need to be updated for this feature? If so, does it need to happen before or after the implementation is done? If a FPC ticket exists, add a link here. Please submit a pull request with the proposed changes before submitting your Change proposal. --> | ||
** java packaging guidelines will be updated | |||
* Trademark approval: N/A (not needed for this Change) | * Trademark approval: N/A (not needed for this Change) | ||
Line 106: | Line 162: | ||
* Alignment with the Fedora Strategy: | * Alignment with the Fedora Strategy: | ||
<!-- Does your proposal align with the current Fedora Strategy: https://discussion.fedoraproject.org/t/fedora-strategy-2028-february-march-planning-work-and-roadmap-til-flock/43618 ? It's okay if it doesn't, but it's something to consider --> | <!-- Does your proposal align with the current Fedora Strategy: https://discussion.fedoraproject.org/t/fedora-strategy-2028-february-march-planning-work-and-roadmap-til-flock/43618 ? It's okay if it doesn't, but it's something to consider --> | ||
** 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 == | == Upgrade/compatibility impact == | ||
<!-- 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. | |||
* in ideal usecase, the JDKs from koji simply replaces themselves by those from Eclipse Temurin | |||
* 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. | |||
<!-- REQUIRED FOR SYSTEM WIDE CHANGES --> | <!-- REQUIRED FOR SYSTEM WIDE CHANGES --> | ||
Line 115: | Line 177: | ||
<!-- This is an optional step for system-wide changes to avail of. If you would like to build an initial proof of concept of your change and have a member of Fedora QA help you write and/or run some initial basic tests on your code, please email tests@fedoraproject.org and include the link to your change proposal. This step is *optional*. --> | <!-- This is an optional step for system-wide changes to avail of. If you would like to build an initial proof of concept of your change and have a member of Fedora QA help you write and/or run some initial basic tests on your code, please email tests@fedoraproject.org and include the link to your change proposal. This step is *optional*. --> | ||
Do you require 'QA Blueprint' support? Y | Do you require 'QA Blueprint' support? Y <!-- Optional Step for System-Wide Changes only --> | ||
== How To Test == | == How To Test == | ||
Line 131: | Line 193: | ||
3. What are the expected results of those actions? | 3. What are the expected results of those actions? | ||
--> | --> | ||
No JDK on system | |||
1. get system without java, update to next fedora, no JDK should be there | |||
Only system JDK on system and future STS jdk | |||
1. get system with system jdk only, update to next fedora, JDK should be there | |||
Only legacy JDK | |||
1. get system withotu any JDK | |||
2. manually install any of legacy LTS jdks | |||
3 update to next fedora | |||
4. the legacy jdk should not be there or should be gone | |||
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 or should be gone | |||
<!-- REQUIRED FOR SYSTEM WIDE CHANGES --> | <!-- REQUIRED FOR SYSTEM WIDE CHANGES --> | ||
Line 145: | Line 222: | ||
- Green has been scientifically proven to be the most relaxing color. The move to a default background color of green with green text will result in Fedora users being the most relaxed users of any operating system. | - Green has been scientifically proven to be the most relaxing color. The move to a default background color of green with green text will result in Fedora users being the most relaxed users of any operating system. | ||
--> | --> | ||
As already described, basic users should not notice change. Advanced users should not lost. | |||
== Dependencies == | == Dependencies == | ||
<!-- What other packages (RPMs) depend on this package? Are there changes outside the developers' control on which completion of this change depends? In other words, completion of another change owned by someone else and might cause you to not be able to finish on time or that you would need to coordinate? Other upstream projects like the kernel (if this is not a kernel change)? --> | <!-- What other packages (RPMs) depend on this package? Are there changes outside the developers' control on which completion of this change depends? In other words, completion of another change owned by someone else and might cause you to not be able to finish on time or that you would need to coordinate? Other upstream projects like the kernel (if this is not a kernel change)? --> | ||
<!-- REQUIRED FOR SYSTEM WIDE CHANGES --> | <!-- REQUIRED FOR SYSTEM WIDE CHANGES --> | ||
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 Plan == | ||
<!-- If you cannot complete your feature by the final development freeze, what is the backup plan? This might be as simple as "Revert the shipped configuration". Or it might not (e.g. rebuilding a number of dependent packages). If you feature is not completed in time we want to assure others that other parts of Fedora will not be in jeopardy. --> | <!-- If you cannot complete your feature by the final development freeze, what is the backup plan? This might be as simple as "Revert the shipped configuration". Or it might not (e.g. rebuilding a number of dependent packages). If you feature is not completed in time we want to assure others that other parts of Fedora will not be in jeopardy. --> | ||
* Contingency mechanism: | * Contingency mechanism: If we fails to introduce Eclipse Temurin JDKs repo, we will simply orphan legacy JDKs as written earlier | ||
<!-- When is the last time the contingency mechanism can be put in place? This will typically be the beta freeze. --> | <!-- When is the last time the contingency mechanism can be put in place? This will typically be the beta freeze. --> | ||
* Contingency deadline: | * Contingency deadline: 1. December 2024 | ||
<!-- Does finishing this feature block the release, or can we ship with the feature in incomplete state? --> | <!-- Does finishing this feature block the release, or can we ship with the feature in incomplete state? --> | ||
* Blocks release? | * Blocks release? Yes <!-- REQUIRED FOR SYSTEM WIDE CHANGES --> | ||
== 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 | |||
* todo link2 | |||
== Release Notes == | == Release Notes == |
Revision as of 19:38, 28 August 2024
Replace legacy JDKs by 3rd party Eclipse Temurin repositories
Summary
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
- Name: Jiri Vanek
- Email: <jvanek@redhat.com>
- Product: java and java stack
- Responsible WG: java-sig (java and java-maint)(which no longer exists)
- rcm ticket: https://pagure.io/releng/issue/TODO
- named side tag ticket: tbd
- FESCo shepherd: Shehperd name <email address>
Current status
- Targeted release: Fedora Linux 42
- Last updated: 2024-08-28
- Writing in progress
- [<will be assigned by the Wrangler> Discussion thread]
- FESCo issue: <will be assigned by the Wrangler>
- Tracker bug: <will be assigned by the Wrangler>
- Release notes tracker: <will be assigned by the Wrangler>
Expected schedule
- Eclipse Temurin repositories already exists: https://adoptium.net/installation/linux/#_centosrhelfedora_instructions
- 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
- repos will be shifted from f42 onwards only
- to keep en system-jdk idea as it is, the requires of "java", "java-devel" and "java-headless" will be 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)
- 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/)
- 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).
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 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/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). 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:
- simply orphan jdk 8,11 and 17 (in f42 the only system JDK will be 21)
- 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)
- provide rpm which will contain the 3d party repository\
- 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)
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
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, Redhat, 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.
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.
Feedback
todo
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.
Scope
- Proposal owners:
- will provide and maintain the 3rd party repo
- 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:
- we will need help from javapackages-tools, maven and ant maintainers, to totally decuple system jdk from installed java
- Release engineering: #Releng issue number
- I think the mass rebuild will not be needed
- 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.
- in ideal usecase, the JDKs from koji simply replaces themselves by those from Eclipse Temurin
- 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.
Early Testing (Optional)
Do you require 'QA Blueprint' support? Y
How To Test
No JDK on system 1. get system without java, update to next fedora, no JDK should be there Only system JDK on system and future STS jdk 1. get system with system jdk only, update to next fedora, JDK should be there Only legacy JDK 1. get system withotu any JDK 2. manually install any of legacy LTS jdks 3 update to next fedora 4. the legacy jdk should not be there or should be gone 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 or should be gone
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
Only eclipse temurin install pages and java packages guidelines
- todo link1
- todo link2