You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@cassandra.apache.org by "mck (JIRA)" <ji...@apache.org> on 2019/04/07 11:49:00 UTC

[jira] [Commented] (CASSANDRA-14757) GCInspector "Error accessing field of java.nio.Bits" under java11

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

mck commented on CASSANDRA-14757:
---------------------------------

Re-did this, post CASSANDRA-14607


|| branch || circleci || asf jenkins ||
| [CASSANDRA-14757|https://github.com/thelastpickle/cassandra/commit/54c2f7f0c5e2223f726d2b1e2949f96390a17670]	| [circleci|https://circleci.com/workflow-run/9c42f4d6-c9e4-4905-9b21-009cfd08fe25]	| [!https://builds.apache.org/view/A-D/view/Cassandra/job/Cassandra-devbranch-testall/38//badge/icon!|https://builds.apache.org/view/A-D/view/Cassandra/job/Cassandra-devbranch-testall/38/] |


Let me know what you think [~snazy], [~jjordan].

> GCInspector "Error accessing field of java.nio.Bits" under java11
> -----------------------------------------------------------------
>
>                 Key: CASSANDRA-14757
>                 URL: https://issues.apache.org/jira/browse/CASSANDRA-14757
>             Project: Cassandra
>          Issue Type: Bug
>          Components: Observability/Metrics
>            Reporter: Jason Brown
>            Assignee: Robert Stupp
>            Priority: Low
>              Labels: Java11, pull-request-available
>             Fix For: 4.0
>
>          Time Spent: 20m
>  Remaining Estimate: 0h
>
> Running under java11, {{GCInspector}} throws the following exception:
> {noformat}
> DEBUG [main] 2018-09-18 05:18:25,905 GCInspector.java:78 - Error accessing field of java.nio.Bits
> java.lang.NoSuchFieldException: totalCapacity
>         at java.base/java.lang.Class.getDeclaredField(Class.java:2412)
>         at org.apache.cassandra.service.GCInspector.<clinit>(GCInspector.java:72)
>         at org.apache.cassandra.service.CassandraDaemon.setup(CassandraDaemon.java:308)
>         at org.apache.cassandra.service.CassandraDaemon.activate(CassandraDaemon.java:590)
>         at org.apache.cassandra.service.CassandraDaemon.main(CassandraDaemon.java:679)
> {noformat}
> This is because {{GCInspector}} uses reflection to read the {{totalCapacity}} from {{java.nio.Bits}}. This field was renamed to {{TOTAL_CAPACITY}} somewhere between java8 and java11.
> Note: this is a rather harmless error, as we only look at {{Bits.totalCapacity}} for metrics collection on how much direct memory is being used by {{ByteBuffer}}s. If we fail to read the field, we simply return -1 for the metric value.



--
This message was sent by Atlassian JIRA
(v7.6.3#76005)

---------------------------------------------------------------------
To unsubscribe, e-mail: commits-unsubscribe@cassandra.apache.org
For additional commands, e-mail: commits-help@cassandra.apache.org