FunTester JDK17 Groovy Caffeine 模块化报错分享

FunTester · 2024年01月31日 · 1772 次阅读

最近在升级各种依赖包的过程之总是能遇到一些 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 more
Caused 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

如果觉得我的文章对您有用,请随意打赏。您的支持将鼓励我继续创作!
暂无回复。
需要 登录 后方可回复, 如果你还没有账号请点击这里 注册