关于sentinel:解决Sentinel-module-javabase-does-not-opens-javalang-问题

3次阅读

共计 1511 个字符,预计需要花费 4 分钟才能阅读完成。

1 环境

  • Sentinel 1.8.3
  • OpenJDK 17.0.2
  • Manjaro

2 问题形容

依据官网 Github Wiki 应用如下命令启动Sentinel

java -Dserver.port=8080 -Dcsp.sentinel.dashboard.server=localhost:8080 -Dproject.name=sentinel-dashboard -jar sentinel-dashboard.jar

报错截图如下:

摘要如下:

java.lang.IllegalStateException: Cannot load configuration class: com.alibaba.csp.sentinel.dashboard.DashboardApplication
Caused by: org.springframework.cglib.core.CodeGenerationException: java.lang.reflect.InaccessibleObjectException-->Unable to make protected final java.lang.Class java.lang.ClassLoader.defineClass(java.lang.String,byte[],int,int,java.security.ProtectionDomain) throws java.lang.ClassFormatError accessible: module java.base does not "opens java.lang" to unnamed module @74fdb593
Caused by: java.lang.reflect.InaccessibleObjectException: Unable to make protected final java.lang.Class java.lang.ClassLoader.defineClass(java.lang.String,byte[],int,int,java.security.ProtectionDomain) throws java.lang.ClassFormatError accessible: module java.base does not "opens java.lang" to unnamed module @74fdb593

能够看到异样来自于InaccessibleObjectException,报错信息为module java.base does not "opens java.lang" to unnamed module @74fdb593

3 问题解决

其实笔者之前写过一篇文章是对于解决 JDK9 非法反射拜访正告的,这种问题不会在 JDK8 呈现,也是模块化的问题,因而解决形式相似,凋谢模块即可。

须要增加如下两个启动参数:

  • --add-opens java.base/java.lang=ALL-UNNAMED
  • --add-opens java.base/sun.net.util=ALL-UNNAMED

即可,残缺命令如下:

java -Dserver.port=8080 -Dcsp.sentinel.dashboard.server=localhost:8080 -Dproject.name=sentinel-dashboard --add-opens java.base/java.lang=ALL-UNNAMED --add-opens java.base/sun.net.util=ALL-UNNAMED -jar sentinel-dashboard-1.8.3.jar

更换一下端口以及 Sentinel 版本即可。

正文完
 0