最近项目中用到hibernate搭配ehcache做二级缓存。部署到weblogic,如果weblogic不挺下来。直接在weblogic console 中stop-->update-->start 做重新部署操作。用jconsole观察到Thread数量会随部署次数稳定增长。
研究了下ehcache。ehcache如果缓存到硬盘。对应每个table,ehcache都会起一对线程来维护这些table cache。一对如下线程:
private final class SpoolAndExpiryThread extends Thread {
public SpoolAndExpiryThread() {
super("Store " + name + " Spool Thread");
setDaemon(true);
setPriority(Thread.NORM_PRIORITY);
spoolAndExpiryThreadActive = true;
}
/**
* RemoteDebugger thread method.
*/
@Override
public final void run() {
spoolAndExpiryThreadMain();
}
}
这些线程都设置为后台线程 setDeamon(true);
这些后台线程只有在把weblogic关了之后才会停下来,所以weblogic不重启,直接update war 然后start。ehcache会重新 new 很多新的线程。
这个问题不知道有什么解法
分享到:
相关推荐
WebLogic Server是一款由BEA Systems(现已被Oracle收购)开发的企业级Java应用服务器,常用于构建、部署和管理企业级Java应用程序。本篇内容主要聚焦于WebLogic Server的性能调优,包括多个层面的优化策略。 1. **...
WebLogic是Oracle公司的一款企业级Java应用服务器,它在企业级软件系统中广泛用于部署和管理Java应用程序。WebLogic的性能管理是确保其高效、稳定运行的关键环节。本讲解将深入探讨WebLogic性能管理的核心概念、重要...
- **案例二**:一家金融企业在进行大规模交易处理时遇到性能瓶颈,通过引入分布式缓存技术优化数据访问模式,并结合负载均衡技术实现了性能大幅提升。 #### 八、总结 - 通过对WebLogic Server进行全面深入地性能...
WebLogic Server是一款由Oracle公司提供的企业级Java应用服务器,它为构建、部署和管理企业级Java应用程序提供了全面的平台。随着WebLogic在各种业务场景中的广泛应用,性能优化成为了管理员和开发人员关注的重点。...
2. **Cache策略**:对象级缓存如HashMap在单机环境下可能无法适应集群环境,需要采用分布式缓存如Ehcache、JBossCache、OSCache,或者集中式缓存如Memcached。选择哪种取决于项目需求。 3. **线程和定时器**:在...
在集群环境中,线程安全主要关注数据的一致性和同步问题。 #### 方法区垃圾回收 方法区(永久代)可以进行垃圾回收,主要回收无用的类和常量池。 #### Redis命令线程安全性 Redis命令一般线程安全,但多命令组合...
在旧版本JDK中,可以使用第三方库来实现类似功能,以避免过度使用线程导致的资源消耗。 3. **谨慎使用异常**: 异常处理应仅用于错误处理,而不是作为正常程序流程的一部分。抛出异常会创建新的对象并填充堆栈轨迹...
3. 缓存技术,如 Ehcache 或 Redis,减少数据库访问,提高响应速度。 四、数据持久化 数据持久化是指将内存中的对象状态保存到持久存储介质,如关系型数据库。模拟网上银行系统通常使用Oracle、MySQL等关系数据库...
- 非阻塞I/O在高并发环境下可显著提升性能,避免线程阻塞。JDK 1.4引入了`java.nio`包,提供了非阻塞I/O的支持。对于旧版本的JDK,可以通过第三方库实现这一功能。 3. **慎用异常** - 异常处理不应作为常规控制...
7. **Distributed Cache**: 如Hazelcast或 Ehcache,这些Java库可以实现分布式缓存,提高系统的响应速度和可扩展性。 8. **Message Brokers**: 如Apache ActiveMQ或RabbitMQ,它们在分布式系统中作为消息传递的中介...