首页 > 其他分享 >SBB Local Interface 详解

SBB Local Interface 详解

时间:2024-10-13 21:53:31浏览次数:9  
标签:调用 对象 实体 SBB 本地 Interface Local

SBB Local Interface 详解

SBB Local Interface 的基本原理

SBB(Service Building Block)实体可以通过目标SBB的本地接口(SBB Local Interface)以同步的方式调用其他SBB实体。这种调用仅限于同一个JVM(Java虚拟机)内部的SBB对象之间,因为它们必须在同一个JVM内驻留。因此,称之为“SBB本地接口”。为了能够被同步调用,一个SBB需要声明SBB本地接口,该接口声明可以同步调用的方法。SBB本地对象(SBB Local Object)是SLEE实现的类的实例,这些类实现了SBB本地接口。

如何获取 SBB Local Object

SBB可以通过以下几种机制获取代表SBB实体的SBB本地对象:

  1. 通过ChildRelation对象的create方法: 当SBB通过create方法创建子SBB实体时,返回的对象是实现了子SBB实体的SBB本地接口的对象。
  2. 通过SbbContext的getSbbLocalObject方法: 通过SbbContext对象调用getSbbLocalObject方法获取。
  3. 方法调用的返回值: 当一个SBB本地对象的方法调用时,SBB实体可以通过方法的返回值或者参数获得其他SBB本地对象。
  4. 从CMP字段中获取: 可以从CMP(容器管理持久化)字段中检索到SBB本地对象。
  5. 通过实现java.util.Collection接口的ChildRelation对象: ChildRelation对象及其迭代器可以访问SBB本地对象。
SBB Local Object 的功能

持有SBB本地对象的SBB对象可以执行以下操作:

  1. 测试是否为相同的SBB实体: 通过SBB Local Object判断两个SBB Local Object是否代表相同的SBB实体。
  2. 删除SBB实体: 删除SBB Local Object代表的SBB实体及其子实体。
  3. 设置和获取事件的传递优先级: 可以设置和获取SBB实体的事件传递优先级。
  4. 调用自定义方法: 可以调用SBB开发者定义的SBB本地对象的方法。
  5. 在方法调用中传递SBB本地对象: SBB本地对象可以作为方法参数或返回值。
  6. 存储在CMP字段中: SBB本地对象可以存储在CMP字段中以便持久化使用。
使用场景

典型场景:

  1. 父SBB实体通过ChildRelation对象创建一个子SBB实体,create方法返回代表子SBB实体的SBB本地对象。
  2. 父SBB或其他SBB可以通过SBB Local Object同步调用子SBB实体的自定义方法,SLEE系统会管理SBB实体的状态及其对象池。
  3. 如果目标SBB实体已经删除,调用SBB本地对象的方法会抛出TransactionRolledbackLocalException异常。

Pass-by-reference 语义:
SBB本地接口的方法参数是以引用传递的,这意味着调用方和被调用方可能会引用相同的Java对象。因此,开发者需要注意同一对象的共享和修改。调用方如果不希望被调用方修改数据,应该在传递之前复制数据。

SbbLocalObject 接口详解

SbbLocalObject接口是所有SBB本地接口的基接口,SLEE提供其实现,具体方法包括:

  1. isIdentical 方法: 判断两个SBB本地对象是否代表同一个SBB实体。必须在事务上下文中调用。
  2. setSbbPrioritygetSbbPriority 方法: 设置或获取SBB实体的事件传递优先级,优先级范围为-128到127。
  3. remove 方法: 删除SBB实体及其子树,进行级联删除。
使用SBB Local Interface的场景示例
代码示例
  1. 获取SBB本地对象:
public class ParentSbb implements Sbb {
    // 获取子SBB本地对象
    public ChildSbbLocalObject createChildSbb() throws Exception {
        ChildRelation childRelation = getChildRelation();  // 假设已有ChildRelation对象
        ChildSbbLocalObject child = (ChildSbbLocalObject) childRelation.create();
        return child;
    }
}
  1. 调用SBB本地对象方法:
public class ParentSbb implements Sbb {
    public void invokeChildMethod() throws Exception {
        ChildSbbLocalObject child = createChildSbb();
        child.customMethod();  // 调用子SBB的自定义方法
    }
}
  1. 设置SBB优先级:
public void setPriority(ChildSbbLocalObject child) {
    child.setSbbPriority((byte) 10);  // 设置优先级
}
配置示例
  1. SBB XML配置:
<sbb>
    <sbb-name>ParentSbb</sbb-name>
    <sbb-vendor>com.example</sbb-vendor>
    <sbb-version>1.0</sbb-version>
    <sbb-alias>parent</sbb-alias>

    <sbb-classes>
        <sbb-class>com.example.sbb.ParentSbb</sbb-class>
    </sbb-classes>

    <sbb-child-relations>
        <child-relation>
            <name>childRelation</name>
            <sbb-ref>
                <sbb-name>ChildSbb</sbb-name>
                <sbb-vendor>com.example</sbb-vendor>
                <sbb-version>1.0</sbb-version>
            </sbb-ref>
        </child-relation>
    </sbb-child-relations>
</sbb>
小结

SBB Local Interface允许同一JVM中的SBB实体通过同步方式调用其他SBB实体。通过该机制,开发者可以创建更高效的服务块协作模型,同时提供事务处理和异常控制。

标签:调用,对象,实体,SBB,本地,Interface,Local
From: https://blog.csdn.net/pumpkin84514/article/details/142890985

相关文章

  • ThreadLocal和连接池
    ThreadLocal线程隔离工具用来存储一些只有线程才可以访问的内容。你可能会想,既然我只想本线程才能访问,那么我使用局部变量不就行了吗?局部变量的问题在于它只能存在于本方法内部,没有办法让本线程内的其他方法访问使用。publicstaticvoidmain(String[]args){Run......
  • 【Kubernets】容器网络基础二:通讲CNI(Container Network Interface)容器网络接口实现方
    文章目录背景知识Underlay网络Overlay网络一、基本概念二、工作原理三、实现方案四、应用场景两者对比示意图CNI实现有哪些?FlannelFlannel的工作原理Flannel的主要组件数据传输机制总结Calico一、架构基础二、核心组件与功能三、路由与数据包转发四、安全策略五、数......
  • SBB Jar 文件
    SBBJar文件1.什么是SBBJar文件?SBB(ServiceBuildingBlock)Jar文件是用于打包一个或多个SBB的标准格式,广泛应用于JAINSLEE(JavaIntegratedNetworksSLEE)环境。SBBJar文件包含了所有必要的类文件、描述符和配置,便于部署和管理服务组件。2.SBBJar文件的结构......
  • 解决方案:java.lang.IllegalArgumentException: 为此cookie指定的域[localhost:xxxx]无
    转载:https://blog.csdn.net/weixin_43724845/article/details/116198741问题原因:Tomcat 8更换默认的CookieProcessor实现为Rfc6265CookieProcessor,之前的实现为LegacyCookieProcessor。前者是基于RFC6265,而后者基于RFC6265、RFC2109、RFC2616。解决方式:修改tomcat......
  • JavaScript Number研究03_实例方法_toExponential_toFixed_toPrecision_toString_valu
    JavaScriptNumber研究03:实例方法——toExponential、toFixed、toPrecision、toString、valueOf、toLocaleString在JavaScript中,Number对象不仅包含了许多有用的静态属性,还提供了一系列实例方法,帮助我们在不同场景下处理和转换数值。这些方法包括:toExponential()toFixed()......
  • ECE4016 A simple Local DNS Server
    ECE4016Assignment1Inthisassignment,youarerequiredtoimplementasimpleLocalDNSServer.IntroductionTheDomainNameSystem(DNS)isthehierarchicalanddecentralizednamingsystemusedtoidentifycomputersreachablethroughtheInternetor......
  • Chromium 中Window.localStorage对象c++实现分析
    一、前端定义Window.localStorage只读的localStorage 属性允许你访问一个Document 源(origin)的对象 Storage;存储的数据将保存在浏览器会话中。localStorage 类似 sessionStorage,但其区别在于:存储在 localStorage 的数据可以长期保留;而当页面会话结束——也就是说,当页面......
  • 错误消息:#2002 - Can't connect to local MySQL server through socket '/tmp/mysql.s
    错误消息:#2002-Can'tconnecttolocalMySQLserverthroughsocket'/tmp/mysql.sock'(2)原因:数据库服务未启动。连接参数错误。解决方法:检查数据库服务:确认MySQL服务是否正常运行。sudoservicemysqlstatus检查连接参数:确认连接参数(主机名、用......
  • android开发Execution failed for task ':bundleDebugAar'...Direct local .aar file
    1.问题描述[+103ms]FAILURE:Buildfailedwithanexception.[]*Whatwentwrong:[]Executionfailedfortask':jpush_flutter:bundleDebugAar'.[]>Errorwhileevaluatingproperty'hasLocalAarDeps'oftask......
  • Link-local地址是IPv6中一种特殊类型的地址,用于在同一链路(网络段)内进行通信。这些地址
    IPv6的link-local地址定义:Link-local地址是IPv6中一种特殊类型的地址,用于在同一链路(网络段)内进行通信。这些地址的前缀是FE80::/64,并且每个IPv6设备在其网络接口上都会自动生成一个link-local地址。来源:Link-local地址的设计目的是为了支持IPv6设备之间的本地通信,而不需要依......