英文参考地址

https://docs.jboss.org/author/display/AS71/Remote+EJB+invocations+via+JNDI+-+EJB+client+API+or+remote-naming+project

要解决的问题

公司的底层架构中的Ejb的远程调用通过Controller调用的Bean,所有现在存在的问题就是业务逻辑都写到了Controller,有一些业务得不到复用,方法得不到复用、分布式事务无法控制等等,所以咱们急需把业务写到Bean的实现里面,因为咱们是Bean调用Bean,Bean是在Jboss的容器内部,所以咱们是可以理解为服务器调用服务器的Bean,以前是客户端调用服务器的远程调用方式。

此方案解决的问题

1:原先远程调用的写到代码中写死的代码和端口,用户名等信息,不利于系统变动

2:分布式事务的解决

3:所有系统的统一管理(stonlone.xml的内容)

需要改的的地方不是很多,为了统一咱们这种服务器调用服务器(Bean调Bean方式)

Jboss服务器需要的修改

找到自己的Jboss的D:\jboss\jboss-eap-6.2\standalone\configuration中的standalone.xml

1:<security-realms>节点下添加如下代码

<span style="font-size:18px;"><management>
<security-realms>
...
<security-realm name="ejb-security-realm">
<server-identities>
<secret value="IWFkbWluMTIz"/>
</server-identities>
</security-realm>
</security-realms>
... </span>

为了统一管理和配置(以下value的值密码为(!admin123)是根据Base64编码加密之后得到,大家现在可以先不用管)

添加完后本借点的全视图

<span style="font-size:18px;"><security-realms>
<security-realm name="ManagementRealm">
<authentication>
<local default-user="$local"/>
<properties path="mgmt-users.properties" relative-to="jboss.server.config.dir"/>
</authentication>
<authorization map-groups-to-roles="false">
<properties path="mgmt-groups.properties" relative-to="jboss.server.config.dir"/>
</authorization>
</security-realm>
<security-realm name="ApplicationRealm">
<authentication>
<local default-user="$local" allowed-users="*"/>
<properties path="application-users.properties" relative-to="jboss.server.config.dir"/>
</authentication>
<authorization>
<properties path="application-roles.properties" relative-to="jboss.server.config.dir"/>
</authorization>
</security-realm>
<span style="color:#FF6666;"><security-realm name="ejb-security-realm">
<server-identities>
<secret value="IWFkbWluMTIz"/>
</server-identities>
</security-realm></span>
</security-realms>
</span>

2:在<socket-binding-group>节点下添加如下代码意思为所要调用的jboss服务器的ip和远程端口号(如果你需要调用多个)

<span style="font-size:18px;"><outbound-socket-binding name="remote-ejb">
<remote-destination host="192.168.*.*" port="4444"/>
</outbound-socket-binding>
</span>

添加完后的这个节点下的代码

<span style="font-size:18px;"><socket-binding-group name="standard-sockets" default-interface="any" port-offset="${jboss.socket.binding.port-offset:0}">
<socket-binding name="management-native" interface="management" port="${jboss.management.native.port:9999}"/>
<socket-binding name="management-http" interface="management" port="${jboss.management.http.port:9991}"/>
<socket-binding name="management-https" interface="management" port="${jboss.management.https.port:9443}"/>
<socket-binding name="ajp" port="8009"/>
<socket-binding name="http" port="8080"/>
<socket-binding name="https" port="8443"/>
<socket-binding name="remoting" port="4447"/>
<socket-binding name="txn-recovery-environment" port="4712"/>
<socket-binding name="txn-status-manager" port="4713"/>
<outbound-socket-binding name="mail-smtp">
<remote-destination host="localhost" port="25"/>
</outbound-socket-binding>
<outbound-socket-binding name="remote-ejb">
<remote-destination host="192.168.*.*" port="4444"/>
</outbound-socket-binding>
<outbound-socket-binding name="remote-ejb2">
<remote-destination host="192.168.*.*" port="4447"/>
</outbound-socket-binding>
</socket-binding-group>
</span>

如果是需要远程调用多个系统的Jboss服务器,配置

3:在<subsystem xmlns="urn:jboss:domain:remoting:1.1">

节点下添加如下代码(注意红色的ejb-security-realm和第一步的名称相对应的),username为提供服务的Jboss服务器添加的把b类型用户的名称,密码默认为(!admin123),这个节点配置的是SSL的一种安全协议机制,咱们现在把它改成false,即不采取这种安全策略

<span style="font-size:18px;"> <outbound-connections>
<remote-outbound-connection name="remote-ejb-connection" outbound-socket-binding-ref="remote-ejb" security-realm="ejb-security-realm" username="adminjc">
<properties>
<property name="SASL_POLICY_NOANONYMOUS" value="false"/>
<property name="SSL_ENABLED" value="false"/>
</properties>
</remote-outbound-connection>
</outbound-connections> </span>

基础:adminjc  权限adminqx 考试:adminks  评教:adminpj  新生:adminxs

密码通知都为(!admin123)

代码中需要修改的地方

1:大家只需要在自己的ear如下图所示添加一个jboss-ejb-client.xml,把下面的附件拷过去即可,不用做任何修改

jboss-ejb-client.xml中的内容

<span style="font-size:18px;"><?xml version="1.0" encoding="UTF-8"?>
<jboss-ejb-client xmlns="urn:jboss:ejb-client:1.0">
<client-context>
<ejb-receivers>
<remoting-ejb-receiver outbound-connection-ref="remote-ejb-connection"/>
</ejb-receivers>
</client-context>
</jboss-ejb-client></span>

2:咱们底层修封装了关于远程调用的方法(Bean调用Bean),架构底层中封装了lookup查找相应远程bean的接口的方法

在自己一条线的Bean的实现方法里面需要调用其他系统或者其他模块的Bean在自己的方法如下写即可

QuestionTypesBeanaa= (QuestionTypesBean)this.lookupRemoteBean("itoo-exam-systemmanage-questiontypes-ear/itoo-exam-systemmanage-questiontypes-core-0.0.1-SNAPSHOT/questionTypesBeanImpl!com.tgb.itoo.exam.service.QuestionTypesBean");

今后新线的开发和现有系统的注意事项

1:现有已经开发好的线,如果是增删改是调用其他系统的,而现在是在Controller调用的,是不受EJB分布式事务(JTA)控制的,会出现数据的不准确性,所以为了提高数据的正确性,大家需要把此种方法的调用在自己的Bean的实现里面调用

2:系统内部有把其他Core打包到自己的ear里面,不利于后期的维护

3:远程调用的用户名和密码以前咱们都是在xml里面,等项目开发部署后如果改变服务器不利于项目的迁移

4:分布式事务的解决

总结

        我们四个小伙伴整个过程中参考了英文的文档,时间长花费在了看英文文档上面,对有些专业名词和环境下刚开始理解的不深刻,绕了点弯,总结重要的一句“学好英语是腾飞的翅膀”,继续努力啊。

Ejb远程调用-jboss服务器调用服务器-Bean调用Bean的更多相关文章

  1. weblogic的ejb远程调用

    这是一篇对EJB远程调用的简单范例.      1.环境:win7  + weblogic 12c + myeclipse8.5      2.目的:实现在myeclispe中对weblogic中EJ ...

  2. 关于WCF报错之调用方未由服务器进行身份验证

    在我们部署好WCF服务以后,调用WCF服务会出现”调用方未由服务器进行身份验证”的错误.这个错误是怎么造成的呢? 通常我们在创建WCF后,用本机调试,一切正常,没有任何问题.其实用本机测试的时候,服务 ...

  3. 意外作出了一个javascript的服务器,可以通过js调用并执行任何java(包括 所有java 内核基本库)及C#类库,并最终由 C# 执行你提交的javascript代码! 不敢藏私,特与大家分

    最近研发BDC 云开发部署平台的数据路由及服务管理器意外作出了一个javascript的服务器,可以通过js调用并执行任何java(包括 所有java 内核基本库)及C#类库,并最终由 C# 执行你提 ...

  4. 解决WCF 调用方未由服务器进行身份验证或消息包含无效或过期的安全上下文令牌

    错误描述: 1. WCF:调用方未由服务器进行身份验证 2. 无法处理消息.这很可能是因为操作“http://tempuri.org/ISCCLSvc/GetCarriersByWareHouse”不 ...

  5. 拦截所有AJAX调用,重点处理服务器异常

    拦截所有AJAX调用,重点处理服务器异常 背景 上篇文章http://www.cnblogs.com/happyframework/p/3241063.html介绍了如何以AOP的形式处理服务器异常, ...

  6. WCF:调用方未由服务器进行身份验证

    错误描述: 1. WCF:调用方未由服务器进行身份验证 2. 无法处理消息.这很可能是因为操作“http://tempuri.org/ISCCLSvc/GetCarriersByWareHouse”不 ...

  7. 使用Navicat远程连接阿里云ECS服务器上的MySQL数据库

    一.必须给服务器的安全组规则设置端口放行规则,在管理控制台中设置: 之后填写配置,授权对象是授权的IP,其中0.0.0.0/0为所有IP授权,之后保存; 二.Navicat使用的配置 在编辑连接处,要 ...

  8. jvisualvm 远程连接jboss

    由于项目中使用jboss 作为web容器,每当项目上线时需要使用loadrunner对项目进行性能压测,这时就需要实时观察JVM的一些参数.想使用jvisualvm借助jstatd远程连接服务器上面的 ...

  9. JAVA与.NET的相互调用——通过Web服务实现相互调用

    JAVA与.NET是现今世界竞争激烈的两大开发媒体,两者语言有很多相似的地方.而在很多大型的开发项目里面,往往需要使用两种语言进行集成开发.而很多的开发人员都会偏向于其中一种语言,在使用集成开发的时候 ...

随机推荐

  1. Java:扩展后的赋值运算符(带强转功能)

    扩展后的赋值运算符,即 +=,-=,*=,/=,%=,&=,|=,^=,<<=,>>=,>>>=. 代码实例一: byte a=5; a=a+5; 此 ...

  2. [ Java学习基础 ] 浅析Java方法调用

     先看一个示例,读者可先自行阅读判断输出结果: public class TestClass { private static void testMethod(){ System.out.printl ...

  3. [NOI2015]品酒大会

    题目描述 一年一度的“幻影阁夏日品酒大会”隆重开幕了.大会包含品尝和趣味挑战 两个环节,分别向优胜者颁发“首席品酒家”和“首席猎手”两个奖项,吸引了众多品酒师参加. 在大会的晚餐上,调酒师 Rainb ...

  4. VK Cup 2017 - Round 2

    FallDream打的AB都FFT了,只剩一个我打的C,没进前一百,之后看看马拉松复活赛有没机会呗. A. Voltage Keepsake 题目大意:n个东西,每个东西一开始有bi能源,每秒消耗ai ...

  5. [Noi2013]书法家

    来自FallDream的博客,未经允许,请勿转载,谢谢. 小E同学非常喜欢书法,他听说NOI2013已经开始了,想题一幅“NOI”的字送给大家. 小E有一张非常神奇的纸,纸可以用一个n 行m 列的二维 ...

  6. C++ 二分法求解方程的解

    二分法是一种求解方程近似根的方法.对于一个函数 f(x)f(x),使用二分法求 f(x)f(x) 近似解的时候,我们先设定一个迭代区间(在这个题目上,我们之后给出了的两个初值决定的区间 [-20,20 ...

  7. 存储单位的换算(KB, MB, GB)

    关于存储单位的换算,大家一般会想到下面的换算方法. 1GB=1024MB 1MB=1024KB 1kb=1024字节 但实际生活中,这种换算方法并不准确. 例如在商家生产销售的硬盘, U盘中就不是这样 ...

  8. Jenkins简明入门(二) -- 利用Jenkins完成Python程序的build、test、deployment

    大家可能还没搞清楚,Jenkins到底能做什么? 本节内容利用Jenkins完成python程序的build.test.deployment,让大家对Jenkins能做的事情有一个直观的了解. 本节内 ...

  9. Java finalize方法使用

    <JAVA编程思想>: Java提供finalize()方法,垃圾回收器准备释放内存的时候,会先调用finalize(). (1).对象不一定会被回收. (2).垃圾回收不是析构函数. ( ...

  10. Linux(centos7)下安装Docker

    近期公司开始推Docker技术.这个系列的文章都是基于CentOS7系统下进行讲解的. Docker简介 Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器 ...