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