[ 
https://issues.apache.org/jira/browse/CASSANDRA-9608?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=15404262#comment-15404262
 ] 

Robert Stupp commented on CASSANDRA-9608:
-----------------------------------------

There's a potential blocker for us in Java9:
We rely on {{sun.nio.ch.DirectBuffer.cleaner().clean()}} to free memory mapped 
files (and also off heap memory, but that's handled in a different ticket).
{{DirectBuffer.cleaner()}} before Java 9 is returns a {{sun.misc.Cleaner}}, but 
Java 9 returns {{jdk.internal.ref.Cleaner}} - this makes it very hard to 
maintain Java 8 and Java 9 compatibility. We have to use this ugly thing, 
because we do not want to want for some garbage collection to occur to free 
mmap'd regions or free off heap memory.

> Support Java 9
> --------------
>
>                 Key: CASSANDRA-9608
>                 URL: https://issues.apache.org/jira/browse/CASSANDRA-9608
>             Project: Cassandra
>          Issue Type: Task
>            Reporter: Robert Stupp
>            Priority: Minor
>
> This ticket is intended to group all issues found to support Java 9 in the 
> future.
> From what I've found out so far:
> * Maven dependency {{com.sun:tools:jar:0}} via cobertura cannot be resolved. 
> It can be easily solved using this patch:
> {code}
> -        <dependency groupId="net.sourceforge.cobertura" 
> artifactId="cobertura"/>
> +        <dependency groupId="net.sourceforge.cobertura" 
> artifactId="cobertura">
> +          <exclusion groupId="com.sun" artifactId="tools"/>
> +        </dependency>
> {code}
> * Another issue is that {{sun.misc.Unsafe}} no longer contains the methods 
> {{monitorEnter}} + {{monitorExit}}. These methods are used by 
> {{o.a.c.utils.concurrent.Locks}} which is only used by 
> {{o.a.c.db.AtomicBTreeColumns}}.
> I don't mind to start working on this yet since Java 9 is in a too early 
> development phase.



--
This message was sent by Atlassian JIRA
(v6.3.4#6332)

Reply via email to