0

0

Jess 规则引擎在 Java 13+ 中的性能退化原因与解决方案

霞舞

霞舞

发布时间:2026-02-05 12:50:55

|

669人浏览过

|

来源于php中文网

原创

Jess 规则引擎在 Java 13+ 中的性能退化原因与解决方案

java 11 升级至 java 17 后 jess 运行变慢 30–40%,主因是 jdk 15 起默认禁用偏向锁(biased locking),而 jess 大量使用 synchronized 方法(如 findvariable、getvariables)严重依赖该机制,导致锁膨胀为重量级锁,引发显著性能下降。

Jess 是一款历史悠久的 Java 规则引擎,其核心代码基于 Java 1.5 编写,广泛采用 synchronized 关键字实现线程安全——例如您提供的 findVariable() 和 getVariables() 方法,均被声明为 synchronized,且在执行链中高频调用(如上下文逐层回溯、变量哈希表懒加载等)。这类细粒度同步在早期 JVM(Java 8/11)中通常由偏向锁(Biased Locking) 高效支撑:当一个线程首次获取锁时,JVM 会将对象头标记为“偏向该线程”,后续同一线程重入无需原子操作,开销近乎为零。

然而,从 JDK 15 开始(JEP 374),偏向锁被默认禁用(-XX:+UseBiasedLocking 已失效),并在 JDK 16 中彻底移除。尽管 Java 13–14 已开始逐步弱化其默认启用状态(部分发行版默认关闭),但 Oracle、Eclipse Temurin、Azul Zulu 等主流 JDK 在 13+ 版本中普遍已不再启用偏向锁。这意味着:

  • 所有原本可偏向的对象锁,现直接升级为轻量级锁甚至重量级锁(OS Mutex);
  • 每次 synchronized 进入/退出均需 CAS 操作或内核态切换;
  • 对于 Jess 这类存在深度嵌套调用、高频率短临界区(如每次规则匹配都触发多次 findVariable)的场景,锁争用成本呈数量级上升。

? 验证方法
在 Java 17+ 启动参数中显式启用(若支持)或禁用偏向锁,对比性能:

# 尝试恢复(仅适用于 JDK 15–16,JDK 17+ 不再支持)
-XX:+UseBiasedLocking -XX:BiasedLockingStartupDelay=0

# 或强制禁用以确认影响(Java 11 下也适用作基线对照)
-XX:-UseBiasedLocking

若 Java 11 下添加 -XX:-UseBiasedLocking 后性能骤降,而 Java 17 下添加 -XX:+UseBiasedLocking 无效(报 Unrecognized VM option),即可确认问题根源。

推荐解决方案

超能文献
超能文献

超能文献是一款革命性的AI驱动医学文献搜索引擎。

下载

立即学习Java免费学习笔记(深入)”;

  1. 短期兼容:降级至 JDK 11 LTS(长期支持、偏向锁默认启用且稳定);
  2. 中期优化:对 Jess 关键路径进行轻量改造,消除不必要同步:
    • getVariables() 可改用 ConcurrentHashMap + computeIfAbsent 替代 Collections.synchronizedMap(new HashMap());
    • findVariable() 中的 synchronized 可移至更粗粒度作用域,或结合 ThreadLocal 缓存常用上下文;
  3. 长期替代:评估现代规则引擎迁移(如 Drools、Easy Rules),其原生支持 Java 17+ 并采用无锁/分段并发设计。

⚠️ 注意:勿盲目添加 -XX:BiasedLockingStartupDelay=0 或其他过时参数——JDK 17+ 已完全移除相关逻辑,强行配置将导致启动失败。性能调优应以实际 profiler(如 JFR、Async Profiler)数据为准,重点关注 ObjectSynchronizer::fast_enter、Mutex::lock 等锁相关热点

总结而言,这不是 JVM 的“bug”,而是旧代码与新 JVM 优化策略演进之间的典型适配断层。理解锁机制变迁,比单纯回滚 JDK 更具可持续性。

相关文章

数码产品性能查询
数码产品性能查询

该软件包括了市面上所有手机CPU,手机跑分情况,电脑CPU,电脑产品信息等等,方便需要大家查阅数码产品最新情况,了解产品特性,能够进行对比选择最具性价比的商品。

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
eclipse教程
eclipse教程

php中文网为大家带来eclipse教程合集,eclipse是一个开放源代码的、基于Java的可扩展开发平台。就其本身而言,它只是一个框架和一组服务,用于通过插件组件构建开发环境。php中文网还为大家带来eclipse的相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

191

2023.06.14

eclipse怎么设置中文
eclipse怎么设置中文

eclipse设置中文的方法:除了设置界面为中文外,你还可以为Eclipse添加中文插件,以便更好地支持中文编程。例如,你可以安装EBNF插件来支持中文变量名,或安装Chinese Helper来提供中文帮助文档。本专题为大家提供eclipse设置中文相关的各种文章、以及下载和课程。

798

2023.07.24

c语言编程软件有哪些
c语言编程软件有哪些

c语言编程软件有GCC、Clang、Microsoft Visual Studio、Eclipse、NetBeans、Dev-C++、Code::Blocks、KDevelop、Sublime Text和Atom。更多关于c语言编程软件的问题详情请看本专题的文章。php中文网欢迎大家前来学习。

606

2023.11.02

Eclipse版本号有哪些区别
Eclipse版本号有哪些区别

区别:1、Eclipse 3.x系列:Eclipse的早期版本,包括3.0、3.1、3.2等;2、Eclipse 4.x系列:Eclipse的最新版本,包括4.0、4.1、4.2等;3、Eclipse IDE for Java Developers等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

168

2024.02.23

eclipse和idea有什么区别
eclipse和idea有什么区别

eclipse和idea的区别:1、平台支持;2、内存占用;3、插件系统;4、智能代码提示;5、界面设计;6、调试功能;7、学习曲线。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

145

2024.02.23

eclipse设置中文全教程
eclipse设置中文全教程

本专题整合了eclipse设置中文相关教程,阅读专题下面的文章了解更多详细操作。

109

2025.10.10

eclipse字体放大教程
eclipse字体放大教程

本专题整合了eclipse字体放大教程,阅读专题下面的文章了解更多详细内容。

137

2025.10.10

eclipse左边栏不见了解决方法
eclipse左边栏不见了解决方法

本专题整合了eclipse左边栏相关教程,阅读专题下面的文章了解更多详细内容。

111

2025.10.15

java中fail含义
java中fail含义

本专题整合了java中fail的含义、作用相关内容,阅读专题下面的文章了解更多详细内容。

0

2026.02.05

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
SQL 教程
SQL 教程

共61课时 | 3.7万人学习

Java 教程
Java 教程

共578课时 | 57.8万人学习

oracle知识库
oracle知识库

共0课时 | 0人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号