-
-
Notifications
You must be signed in to change notification settings - Fork 429
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Drop Java 8 support and start using Java 11 only features #1287
Comments
I'd be all for it. The only thing that may hinder us is if there are still Java8 dependencies in any add-ons or the distro. |
There may be a problem with this if we move to the new rule engine and promote Jython for use with scripted automation. Jython 2.7.2b2 is available in Maven Central, but I have not tested it with Java 11. However, I did find some issues testing it with Java 8... #1252. I also ran into issues when using 2.7.2b2 in the Jython bundle... #1253. |
So there can also be similar issues with other add-ons where in the worst case native libraries crash the JVM and some Java code may need some tweaking for Java 11 compatibility. I think a lot of this can be fixed before there is a final OH3. |
I also think it's definitely time to switch - also because we removed guava and need some of the API improvements to make things easier here and there. End of 2020, Java 8 JVM support will end for most users anyway. |
I'd agree. So it seems to make a lot of sense to move to Java11 right away for 3.x. |
Another reason for moving to Java 11 together with OH3 is that the namespace change (#1290) will prevent issues when JARs compiled using Java 11 are used on Java 8 (OH2). Can we continue with this @openhab/core-maintainers or do we want to wait for more input? The next steps would be:
|
Add to that:
|
I didn't hear anybody asking to keep Java 8, so imho no need to wait any longer. |
Jython scripts used in scripted automation will break. Jython support for Java 11 was introduced with 2.7.1, but there are currently issues when using anything other than 2.7.0. I haven't checked the most recent builds of 2.7.2. If we are moving over to the new rule engine and focusing on Jython, then moving to Java 11 throws a wrench into things. |
For me the issue raised by @openhab-5iver is a show-stopper. |
It might be a show-stopper for Jython scripts, but not for Java 11. We cannot say that we can't support Java 11 by the end of 2020... |
Jython is probably the most used scripting engine for the new rule engine. |
Since we're changing things anyway. Can't we adopt Graal instead of Nashorn or is that not yet feasible? There is a pr to add Graal as add-on. So some work has already been done. Is something to consider to use Graal? |
Agreed, but if there is no rush, I'd like to at least get the answers needed to move #1253 forward while Jython still works with OH! I have not tested a recent build of Jython, but I'll go take a look now. The one issue may already be resolved, but it looked like we did something else in core that also caused some problems.
IMO, GraalVM is definitely something to consider in the future, but it will be a while before the graal languages, like graalpython, will be mature enough. Graaljs is the most advanced and it also includes a legacy javax.script.ScriptEngineFactory, which is what is used in the PR that you mention. Unfortunately, none of the other graal languages have included these yet, but I've considered working on one for graalpython. |
As you may have noticed I've created a couple of PRs for this and updated the first post with links to all of them and a small to do list. |
I've finished and tested my changes so these are ready to be merged. There are only 2 remaining items:
|
Hey @wborn, sorry for the delayed answer, it has been a busy week...
You are admin on Jenkins, so I would claim you have access to everything.
Hm, I so far thought that we should start right away with working on OH3 docs as there'll be a lot that needs to be changed (due to new UI, rules, etc.). But I see your point about merge conflicts with 2.5.x updates and we are probably not keen on having to manually resolve a lot of them. So yes, maybe we should do it similarly to the code repos: Only start working on OH3 docs in summer, when the 2.5.x docs should be more or less final. By then, we should also have some stability wrt the new UI so that screenshots might make sense then. Entering issues in openhab-docs for things to change makes sense. @Confectrician Wdyt? Does @wborn's suggestion make sense to you? |
I'd suggest to go ahead and merge them. If there are issues with Jython on Java 11, we can still sort them out. We do not need a working distro with scripting right now as we anyhow have work in progress on UI, persistence and other topics. |
I can help updating the other builds similarly. The only issue might be that the 2.5.x PR builds would then also start building code with Java 11. Which may give issues when users download Java 11 artifacts from the build server or the 2.5.x PR repo (also commonly used by Eclipse IoT marketplace add-ons). Do you also want to create additional 2.5.x PR builds that use Java 8? It will probably require additional webhooks. Another approach could be to keep the existing PR jobs but configure the compiler to cross compile to Java 8 on the 2.5.x branches (see: https://www.baeldung.com/maven-java-version#java9). |
Yes, this probably makes sense. We should keep the current ones for 2.5.x and create new ones for master that use Java 11. |
Do you think we should already start using Java 11 only functionality in openhab-core 3.x and thus drop Java 8 support?
It would simplify builds and dependency management. But there is a very significant downside because there may not be a Java 11 JVM for all embedded platforms on which OHC is used.
Currently I don't have a very strong preference myself on this subject. Perhaps the other @openhab/add-ons-maintainers have a recollection of the criteria used for embracing Java 8 and dropping Java 7 support in openHAB?
There are now some WIP PRs for this change:
What still needs to be done is:
The text was updated successfully, but these errors were encountered: