`
<>++<
  • 浏览: 16418 次
  • 性别: Icon_minigender_1
  • 来自: 大连
社区版块
存档分类
最新评论

Weblogic中关于缓存和钝化有状态会话EJB

阅读更多

在前些天的项目里,发现一个关于WebLogic 缓存和钝化有状态会话EJB 的问题。

简单描述下:

===========================================

cache-type 设置为NRU 的时候,按照官方文档上的描述:

 

Lazy Passivation ( NRU )

When lazy passivation is configured by setting cache-type to NRU , the container avoids passivating beans, because of the associated systems overhead—pressure on the cache is the only event that causes passivation or eager removal of beans.

The container:

  • Removes a bean instance from cache when idle-timeout-seconds expires, and does not passivate it to disk. This is referred to as a eager remove . An eager remove ensures that an inactive instance does not consume memory or disk resources.
  • Passivates instances to disk when max-beans-in-cache is reached, even though idle-timeout-seconds has not expired.
懒 钝化 (NRU )

cache-type 被配置为NRU 的时候,容器会回避钝化Bean,因为关系到关联的系统的缓存开销,导致钝化或渴望删除Beans。

The container:

  • 当经过idle-timeout-seconds (闲置时间)时从Cache里直接删除bean,而不是钝化到硬盘上。这被作为一个渴望删除。 一个渴望删除保证了不会耗尽内存和硬盘资源。
  • 当达到max-beans-in-cache 时 钝化硬盘上的bean实例,即使没有超过idle-timeout-seconds (闲置时间)

 

 

详见:摸我5-2 之后

=============================================================

也就是说设置成NRU时 如果超过idle-timeout-seconds 时间就会把Cache中的Bean直接干掉。图5-2 也是这么画的。

但项目中始终没有验证出这个结论----即使经过闲置时间,不管超没超过max-beans-in-cache ,也不会从Cache中删除-------开始以为项目本身的框架有一些特殊的实现导致的,后来就做了一个纯净版的ejb sample(见附件)。发现结果还是这样。

 

难道是Oracle的文档的问题 还是Bug,还是自己在验证中出现了什么差错? 不解!!!

 

后来添附上Sample 问了一下Oracle。一个月过去了,还是没有答复。

想请教一下大家,原因是什么?

为什么超过 idle-timeout-seconds 时间后没有像官方文档上描述的"直接从内存中删除Bean"?

 

 

****************************************************************************

附上相关文档说明:

cache-type

功能

指定从缓存中删除 EJB 的顺序。值包括:

  • 最近最少使用(Least recently used,简称 LRU)
  • 最近未使用(Not recently used,简称 NRU)
  • NRU 缓存大小的最小值为 8。如果 max-beans-in-cache 小于 3,WebLogic Server 会对 max-beans-in-cache 使用 8 这个值。

示例

<stateful-session-cache>
    <cache-type>NRU</cache-type>
</stateful-session-cache>

 

Controlling Passivation

The rules that govern the passivation of stateful session beans vary, based on the value of the beans cache-type element, which can be:

  • LRU —least recently used, or eager passivation.
  • NRU —not recently used, or as lazy passivation
****************************************************************************
分享到:
评论
3 楼 <>++< 2011-11-07  
remove idle bean only when pressure on cache
也就是说 NRU时只有当缓存有压力的情况下,才会直接从Cache里删除闲置Bean。
这个说明的比较详细:
http://www.oracle.com/us/products/database/perf-tune-session-beans-093360.html

另外还有关于NRU和LRU的选择 上边的文章里也写了。
首先Ejb的钝化和激活是很耗性能的,因为调用了昂贵的序列化和反序列化操作。
为了造成不必要的钝化和激活的开销。
当内存资源是稀缺的时候,还是使用LRU策略比较好。
因为此时此刻NRU的状态下,还会始终对有状态的EJB调用ejbRemove()
2 楼 <>++< 2011-11-01  
补充: 这个问题在weblogic培训的时候问了一下王超www.beansoft.biz 他不建议用10g3版本的weblogic 说在这版本发布的期间 正是oracle对其收购的时候,但是此问题的具体原因还是没有完全解决。
1 楼 <>++< 2011-10-27  
Oracle公司终于给出回答了。
说在NRU的场合,EJB经过idle-timeout-seconds之后也可能不会从cache中直接删除,原因是从cache直接删除的时机话,还要看Cache的剩余容量;而关于EJB的缓存管理有复杂的内部运算和行为。这个操作是很难的部分。
=========================================
说白了,等于没回答一样,坑爹的回答。。。再次对Oracle失望。。。

所以官方文档上的描述也未必是正确的,实践是检验真理的唯一标准啊。。。

相关推荐

    Weblogic Ejb 学习笔记

    WebLogic EJB学习笔记主要涵盖了企业级Java Bean(Enterprise JavaBeans,简称EJB)在Oracle WebLogic Server中的应用和管理。EJB是Java EE(Java Platform, Enterprise Edition)平台的核心组件,用于构建可扩展、...

    EJB 和WEBLOGIC 结合例子

    通过对这些文件的解压和研究,我们可以更直观地了解EJB在WebLogic中的实际应用和客户端如何与EJB通信。 总结起来,EJB和WebLogic的结合是构建大型企业系统的关键技术,它允许开发者专注于业务逻辑,同时享受Java EE...

    MyEclipse开发会话EJB详细步骤

    在向导中,为bean命名,选择bean的接口类型(无状态或有状态),并提供接口和实现类的名字。点击`Finish`。 ### 5. 编写bean逻辑 在生成的接口和实现类中,编写业务逻辑。无状态bean通常用于处理独立的请求,而有...

    Weblogic下ejb配置

    WebLogic Server是Oracle公司的一款...总结,WebLogic Server中的EJB配置涉及多个层面,包括EJB组件的编写、打包、部署以及性能优化。理解并熟练掌握这些步骤和最佳实践,有助于开发出高效、可靠的Java EE企业级应用。

    weblogic+ejb3.0例子

    【Weblogic + EJB3.0】:这是一个关于在Weblogic服务器上使用EJB3.0版本进行开发的教程。EJB(Enterprise JavaBeans)是Java EE平台的一部分,用于构建可部署在企业级服务器上的组件化应用程序。EJB3.0引入了许多...

    weblogic清缓存的shell

    weblogic清缓存的shell

    EJB3.0+weblogic操作文档

    在本教程中,我们将关注如何在WebLogic 11g服务器上发布和使用EJB3.0项目。 1. **无状态会话Bean(Stateless Session Bean)**: - 无状态会话Bean是最简单的EJB类型,它不维护任何会话状态,每个请求都独立于其他...

    Weblogic EJB 学习笔记

    Weblogic EJB 学习笔记主要涵盖了EJB(Enterprise JavaBeans)的基础知识,包括无状态会话bean、有状态会话bean和实体bean这三种主要的EJB类型,以及EJB在Weblogic服务器中的配置和事务管理。 1. **无状态会话bean*...

    Weblogic 创建一个简单的EJB项目

    WebLogic Server 是一款由 Oracle 公司提供的企业级 Java 应用服务器,它支持Java EE...通过这个过程,你可以掌握在WebLogic中开发和管理EJB的基础知识,为进一步深入学习Java EE和WebLogic的高级特性奠定基础。

    Weblogic11g+EJB3的小例子

    - `@Stateless` 和 `@Stateful`:声明无状态和有状态会话Bean。 - `@Local` 和 `@Remote`:定义Bean接口,区分本地和远程调用。 3. **Weblogic 11g集成EJB3**: - 部署EJB3应用到Weblogic 11g通常涉及创建一个...

    使用eclipse通过weblogic开发简单的ejb应用(weblogic 10.x & ejb3.x)

    在WebLogic 10.x中,EJB 3.0的性能和稳定性已经得到了显著提升,支持了诸如依赖注入、事务管理、安全性和持久化等功能。然而,开发过程中需要注意的一些常见问题包括:内存泄漏、线程安全问题、性能优化(如缓存策略...

    WebLogic v9.2 EJB和JNDI Demo

    WebLogic v9.2 EJB和JNDI Demo

    Weblogic10 + EJB3入门教程

    ### Weblogic10 + EJB3入门教程 #### 一、引言 随着企业级应用的发展,Java EE标准成为构建复杂应用系统的重要...掌握了这些基本步骤后,你可以进一步探索更复杂的场景和技术,例如有状态会话Bean、消息驱动Bean等。

    weblogic 10 ejb3 入门教程 + 调试通过的源代码

    【标题】"weblogic 10 ejb3 ...以上就是关于“weblogic 10 ejb3 入门教程 + 调试通过的源代码”这个主题的主要知识点,深入理解和掌握这些内容,将有助于开发者构建和管理在 WebLogic Server 上运行的 EJB 3.0 应用。

    weblogic部署EJB2.0 实现本地接口的SessionBean

    它定义了三种主要类型的Bean:Stateless Session Beans(无状态会话bean)、Stateful Session Beans(有状态会话bean)和Message Driven Beans(消息驱动bean)。我们关注的是Session Bean,它们通常代表业务逻辑,...

    struts_ejb.rar_EJB weblogic_ejb_ejb struts _ejb+struts_weblogic

    Struts、EJB(Enterprise JavaBeans)和WebLogic是Java企业级开发中的三大核心组件,它们在构建可扩展且复杂的Web应用程序中起着至关重要的作用。这个名为"struts_ejb.rar"的压缩包文件,显然是为了教授初学者如何将...

    Eclipse中weblogic和EJB的配置

    帮助初学这在Eclipse中配置开发EJB的容器这里以weblogic的配置来说明

    weblogic+Myeclipse+EJB

    - 有状态会句Bean:保存客户端状态直到会话结束。 - **实体Bean**:表示持久化数据的对象。 - **消息驱动Bean**:处理异步消息。 ##### 3.3 EJB部署描述符 - **ejb-jar.xml**:定义了EJB组件的部署元数据。 - **...

Global site tag (gtag.js) - Google Analytics