写点什么

JDK17 Groovy Caffeine 模块化报错分享

作者:FunTester
  • 2024-01-31
    河北
  • 本文字数:1215 字

    阅读完需:约 4 分钟

最近在升级各种依赖包的过程之总是能遇到一些 Java 模块化的问题。Java 模块化是 Java 9 引入的一种新的特性,它将 Java 类库划分为若干个模块,每个模块都具有自己的包和类。模块化可以提高 Java 程序的安全性、可维护性和可移植性。


虽说如此,但是在升级 JDK 版本的过程中,总是会遇到各类相关的程序报错。已经完成模块化改造的依赖,无法兼容旧的项目,需要添加配置或者增加 JVM 启动参数。


今天在使用 Caffeine 异步缓存的过程中遇到一个无法访问匿名模块的问题。


Caused by: java.lang.IllegalAccessException: module jdk.proxy2 does not open jdk.proxy2 to unnamed module @6107227e
复制代码


下面发生问题的脚本内容:


static void main(String[] args) {      LoadingCache<String, String> cache = Caffeine.newBuilder()              .build(key -> {                  return "FunTester";              });      String value = cache.get("FunTester");        System.out.println("缓存: " + value);  }
复制代码


详细的报错信息如下:


Caused by: java.lang.reflect.InvocationTargetException  at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)  at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:77)  at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)  at java.base/java.lang.reflect.Method.invoke(Method.java:568)  at org.codehaus.groovy.vmplugin.v9.Java9.of(Java9.java:160)  ... 23 moreCaused by: java.lang.IllegalAccessException: module jdk.proxy2 does not open jdk.proxy2 to unnamed module @6107227e  at java.base/java.lang.invoke.MethodHandles.privateLookupIn(MethodHandles.java:259)  ... 28 more
复制代码


按照报错信息找到的解决方案是要么进行模块化改造,增加模块配置信息,要么增加 JVM 启动参数类似:--add-opens jdk.proxy2/java.lang=ALL-UNNAMED 但是已经是匿名的了,实在找不到启动命令改增加什么。


然后就是升级依赖包,但当我把 ==Caffeine== 升级到最新版之后发现依旧无用。然后就利用排除法锁定了 ==Groovy== 的版本,由于上次的 ==BUG== 缘故,我停留在了 3.0.9 ,搜了一圈资料,决定升级新版本:


        <dependency>            <groupId>org.apache.groovy</groupId>            <artifactId>groovy</artifactId>            <version>5.0.0-alpha-3</version>        </dependency>
复制代码


直接一步到位,升级到最新版本,没想到都已经是 5.x 了。


真是虐我千百遍。Groovy 多适合用来作为脚本语言,真写项目还是 Java 稳定。


去搜官网资料确认的时候发现,其实这个问题很早就被发现了,官方给的缺钱命名是非法方法动态代理(# [JDK16] Illegal access to dynamic proxy):https://issues.apache.org/jira/browse/GROOVY-10137

发布于: 刚刚阅读数: 4
用户头像

FunTester

关注

公众号:FunTester,800篇原创,欢迎关注 2020-10-20 加入

Fun·BUG挖掘机·性能征服者·头顶锅盖·Tester

评论

发布
暂无评论
JDK17 Groovy Caffeine 模块化报错分享_FunTester_InfoQ写作社区