续上篇介绍了第三个ESB应用,本文介绍第四个ESB应用——Hello World File Action。
说明:本文及后续文章虽非百分百的原创,但毕竟包含本人的努力和付出,所以希望大家转载时务请注明出处:http://yarafa.iteye.com,谢谢合作。
1 概述
本实例演示了JBoss ESB的File Gateway的使用及特性,当ESB所监听的特定目录下具有特定扩展名的文件发生变化时,将发送一个JMS消息到消息队列,然后由ESB处理该消息。最后根据ESB的配置将输出一个具有特定扩展名的文件到输出目录。
2 新建ESB工程
操作过程略。
3 ESB配置
3.1 创建消息队列
本例中只用到了一个消息队列,如下所示:
<?xml version="1.0" encoding="UTF-8"?>
<server>
<mbean code="org.jboss.jms.server.destination.QueueService" name="jboss.esb.helloworld.destination:service=Queue,name=helloworldfile" xmbean-dd="xmdesc/Queue-xmbean.xml">
<depends optional-attribute-name="ServerPeer">jboss.messaging:service=ServerPeer
</depends>
</mbean>
</server>
3.2 定义Provider
这里将定义一个fs-provider和一个JMS Provider,分别用于监听文件系统的变化和监听ESB消息。内容如下:
<fs-provider name="FSprovider1">
<fs-bus busid="helloFileChannel">
<fs-message-filter
directory="F:\Workspace\Eclipse-JEE\helloworldfile\file\input"
error-delete="false"
error-directory="F:\Workspace\Eclipse-JEE\helloworldfile\file\error"
error-suffix=".IN_ERROR" input-suffix=".txt" post-delete="false"
post-directory="F:\Workspace\Eclipse-JEE\helloworldfile\file\output"
post-suffix=".sentToEsb"
work-suffix=".esbWorking" />
</fs-bus>
</fs-provider>
<jms-provider connection-factory="ConnectionFactory"
name="JBossMessaging">
<jms-bus busid="quickstartEsbChannel">
<jms-message-filter dest-name="queue/helloworldfile"
dest-type="QUEUE"
selector="type='fromHelloworldFileAction'" />
</jms-bus>
</jms-provider>
fs-provider配置说明:
directory:ESB的监听目录
input-suffix:监听文件的扩展名,不是指定扩展名的文件将被忽略
error-delete:如果发生内部错误或者ESB无法加载文件,该属性决定是否删除文件
error-directory:在文件加载或者处理失败时的文件存放目录
error-suffix:发生错误时的文件扩展名
post-directory:当post-delete属性设置为false且未发生错误的情况下,该目录用于存放处理后的文件
post-suffix:处理后的文件扩展名
work-suffix:正在被处理时的文件扩展名,“被处理”指的是文件已通过gateway并已被传输到ESB listener/service。
3.3 定义Service
<service category="myCategory" description="Hello World File Action
(esb listener)" name="myFileListener">
<listeners />
<actions /
</service>
3.4 定义Listener
这里定义两个listener,分别用于监听文件通道和消息队列,内容如下:
<fs-listener busidref="helloFileChannel" is-gateway="true"
name="FileGateway" poll-frequency-seconds="10" />
<jms-listener busidref="quickstartEsbChannel"
name="helloWorldFileAction" />
3.5 定义Action类
这里使用自定义的action类,因此需要扩展AbstractActionLifecycle类。类的全部代码如下:
/***********************************************************************
* <p>Project Name: helloworldfile</p>
* <p>File Name: com.thu.afa.esb.jbossesb.action.HelloWorldFileAction.java</p>
* <p>Copyright: Copyright (c) 2010</p>
* <p>Company: <a href="http://afa.thu.com">http://afa.thu.com</a></p>
***********************************************************************/
package com.thu.afa.esb.jbossesb.action;
import org.jboss.soa.esb.actions.AbstractActionLifecycle;
import org.jboss.soa.esb.helpers.ConfigTree;
import org.jboss.soa.esb.message.Body;
import org.jboss.soa.esb.message.Message;
/**
* <p>Class Name: HelloWorldFileAction</p>
* <p>Description: </p>
* @author Afa
* @date 2010-9-8
* @version 1.0
*/
public class HelloWorldFileAction extends AbstractActionLifecycle
{
protected ConfigTree configTree;
public HelloWorldFileAction(ConfigTree configTree)
{
this.configTree = configTree;
}
public Message noOperation(Message message) { return message; }
public Message displayMessage(Message message) throws Exception
{
System.out.println("Body: " + new String((byte[])message.getBody().get()));
return message;
}
public Message playWithMessage(Message message) throws Exception
{
Body body = message.getBody();
String content = new String((byte[])body.get());
StringBuffer buffer = new StringBuffer();
buffer.append("Before------------------");
buffer.append(content);
buffer.append("After-------------------");
body.add(buffer.toString());
return message;
}
}
类方法说明:
displayMessage方法用于在控制台打印输出消息的内容
playWithMessage方法用于处理消息
3.6 配置Action
由于使用了自定义的action类,因此在说明action配置之前介绍了action类的定义。下面将说明action的配置。
<actions mep="OneWay">
<action
class="com.thu.afa.esb.jbossesb.action.HelloWorldFileAction"
name="myAction" process="displayMessage,playWithMessage" />
<action class="org.jboss.soa.esb.actions.SystemPrintln"
name="dump">
<property name="message" />
<property name="printfull" value="true" />
</action>
</actions>
配置说明:这里定义了两个action,分别用自定义的action类显示文件内容并做相应的处理后,再由ESB本身提供的SystemPrintln类在控制台输出经处理后的消息内容。
3.7 配置部署文件
部署依赖文件deployment.xml内容如下:
<jbossesb-deployment>
<depends>jboss.esb.helloworld.destination:service=Queue,name=helloworldfile
</depends>
</jbossesb-deployment>
3.8 部署ESB
将整个工程导出成一个ESB文件,并保存至JBoss ESB Server的部署目录下,启动JBoss ESB Server即可。
4 ESB客户端
4.1 新建Java工程
这里略去操作过程以及添加所需要的Jar包,具体操作过程可参考第一个ESB实例说明。
4.2 客户端实现
这里的客户端生成一个文本文件,并保存在ESB的监听目录下,之后可看到ESB的处理操作。
/***********************************************************************
* <p>Project Name: helloworldclient</p>
* <p>File Name: com.thu.afa.esb.jbossesb.client.HelloWorldFileClient.java</p>
* <p>Copyright: Copyright (c) 2010</p>
* <p>Company: <a href="http://afa.thu.com">http://afa.thu.com</a></p>
***********************************************************************/
package com.thu.afa.esb.jbossesb.client;
import java.io.BufferedWriter;
import java.io.File;
import java.io.FileWriter;
/**
* <p>Class Name: HelloWorldFileClient</p>
* <p>Description: </p>
* @author Afa
* @date 2010-9-9
* @version 1.0
*/
public class HelloWorldFileClient
{
/**
* <p>Title: </p>
* <p>Method Name: main</p>
* <p>Description: </p>
* @author: Afa
* @date: 2010-9-9
* @param args
*/
public static void main(String[] args) throws Exception
{
File file = new File("F:/Workspace/Eclipse-JEE/helloworldfile/file/input/test.txt");
BufferedWriter out = new BufferedWriter(new FileWriter(file));
out.write("Llu, miss you, afa");
out.close();
}
}
运行该程序可看到如下输出结果:
处理中的文件:
处理后的输出文件:
ESB的SystemPrintln类在控制台输出结果:
上述便是ESB第四个应用实例。如有问题,欢迎指正。
-----------------------------------------------------
Stay Hungry, Stay Foolish!
http://yarafa.iteye.com
Afa
Jan 8th, 2011
-----------------------------------------------------
分享到:
相关推荐
1. **基础入门**:如《JBoss_ESB学习笔记5——第四个ESB应用Hello World File Action.doc》所示,初学者通常从“Hello World”程序开始,了解如何创建并运行一个简单的ESB服务。这一阶段会介绍ESB的基本概念,如服务...
#### 五、第四个ESB应用Hello World File Action - **重点**:了解如何使用File Action处理文件相关的消息。 - **实现**:实现读取文件内容作为消息的一部分,并能够处理这些文件数据。 #### 六、第五个ESB应用...
本篇学习笔记主要围绕 JBoss ESB 的一个基础应用——“Hello World File Action”进行讲解,这个例子展示了如何利用 JBoss ESB 的 File Gateway 功能来监控文件系统变化,并通过 JMS(Java Message Service)消息...
qt 一个基于Qt Creator(qt,C++)实现中国象棋人机对战.
热带雨林自驾游自然奇观探索
冰川湖自驾游冰雪交融景象
C51 单片机数码管使用 Keil项目C语言源码
1.版本:matlab2014/2019a/2024a 2.附赠案例数据可直接运行matlab程序。 3.代码特点:参数化编程、参数可方便更改、代码编程思路清晰、注释明细。 4.适用对象:计算机,电子信息工程、数学等专业的大学生课程设计、期末大作业和毕业设计。
前端分析-2023071100789s12
Laz_制作了一些窗体和对话框样式.7z
1、文件内容:ocaml-docs-4.05.0-6.el7.rpm以及相关依赖 2、文件形式:tar.gz压缩包 3、安装指令: #Step1、解压 tar -zxvf /mnt/data/output/ocaml-docs-4.05.0-6.el7.tar.gz #Step2、进入解压后的目录,执行安装 sudo rpm -ivh *.rpm 4、更多资源/技术支持:公众号禅静编程坊
学习笔记-沁恒第六讲-米醋
工业机器人技术讲解【36页】
内容概要:本文档详细介绍了在 CentOS 7 上利用 Docker 容器化环境来部署和配置 Elasticsearch 数据库的过程。首先概述了 Elasticsearch 的特点及其主要应用场景如全文检索、日志和数据分析等,并强调了其分布式架构带来的高性能与可扩展性。之后针对具体的安装流程进行了讲解,涉及创建所需的工作目录,准备docker-compose.yml文件以及通过docker-compose工具自动化完成镜像下载和服务启动的一系列命令;同时对可能出现的问题提供了应对策略并附带解决了分词功能出现的问题。 适合人群:从事IT运维工作的技术人员或对NoSQL数据库感兴趣的开发者。 使用场景及目标:该教程旨在帮助读者掌握如何在一个Linux系统中使用现代化的应用交付方式搭建企业级搜索引擎解决方案,特别适用于希望深入了解Elastic Stack生态体系的个人研究与团队项目实践中。 阅读建议:建议按照文中给出的具体步骤进行实验验证,尤其是要注意调整相关参数配置适配自身环境。对于初次接触此话题的朋友来说,应该提前熟悉一下Linux操作系统的基础命令行知识和Docker的相关基础知识
1.版本:matlab2014/2019a/2024a 2.附赠案例数据可直接运行matlab程序。 3.代码特点:参数化编程、参数可方便更改、代码编程思路清晰、注释明细。 4.适用对象:计算机,电子信息工程、数学等专业的大学生课程设计、期末大作业和毕业设计。
网络小说的类型创新、情节设计与角色塑造
毕业设计_基于springboot+vue开发的学生考勤管理系统【源码+sql+可运行】【50311】.zip 全部代码均可运行,亲测可用,尽我所能,为你服务; 1.代码压缩包内容 代码:springboo后端代码+vue前端页面代码 脚本:数据库SQL脚本 效果图:运行结果请看资源详情效果图 2.环境准备: - JDK1.8+ - maven3.6+ - nodejs14+ - mysql5.6+ - redis 3.技术栈 - 后台:springboot+mybatisPlus+Shiro - 前台:vue+iview+Vuex+Axios - 开发工具: idea、navicate 4.功能列表 - 系统设置:用户管理、角色管理、资源管理、系统日志 - 业务管理:班级信息、学生信息、课程信息、考勤记录、假期信息、公告信息 3.运行步骤: 步骤一:修改数据库连接信息(ip、port修改) 步骤二:找到启动类xxxApplication启动 4.若不会,可私信博主!!!
在智慧城市建设的大潮中,智慧园区作为其中的璀璨明珠,正以其独特的魅力引领着产业园区的新一轮变革。想象一下,一个集绿色、高端、智能、创新于一体的未来园区,它不仅融合了科技研发、商业居住、办公文创等多种功能,更通过深度应用信息技术,实现了从传统到智慧的华丽转身。 智慧园区通过“四化”建设——即园区运营精细化、园区体验智能化、园区服务专业化和园区设施信息化,彻底颠覆了传统园区的管理模式。在这里,基础设施的数据收集与分析让管理变得更加主动和高效,从温湿度监控到烟雾报警,从消防水箱液位监测到消防栓防盗水装置,每一处细节都彰显着智能的力量。而远程抄表、空调和变配电的智能化管控,更是在节能降耗的同时,极大地提升了园区的运维效率。更令人兴奋的是,通过智慧监控、人流统计和自动访客系统等高科技手段,园区的安全防范能力得到了质的飞跃,让每一位入驻企业和个人都能享受到“拎包入住”般的便捷与安心。 更令人瞩目的是,智慧园区还构建了集信息服务、企业服务、物业服务于一体的综合服务体系。无论是通过园区门户进行信息查询、投诉反馈,还是享受便捷的电商服务、法律咨询和融资支持,亦或是利用云ERP和云OA系统提升企业的管理水平和运营效率,智慧园区都以其全面、专业、高效的服务,为企业的发展插上了腾飞的翅膀。而这一切的背后,是大数据、云计算、人工智能等前沿技术的深度融合与应用,它们如同智慧的大脑,让园区的管理和服务变得更加聪明、更加贴心。走进智慧园区,就像踏入了一个充满无限可能的未来世界,这里不仅有科技的魅力,更有生活的温度,让人不禁对未来充满了无限的憧憬与期待。
1.版本:matlab2014/2019a/2024a 2.附赠案例数据可直接运行matlab程序。 3.代码特点:参数化编程、参数可方便更改、代码编程思路清晰、注释明细。 4.适用对象:计算机,电子信息工程、数学等专业的大学生课程设计、期末大作业和毕业设计。
内容概要:本文介绍了使用 Matlab 实现基于 BO(贝叶斯优化)的 Transformer 结合 GRU 门控循环单元时间序列预测的具体项目案例。文章首先介绍了时间序列预测的重要性及其现有方法存在的限制,随后深入阐述了该项目的目标、挑战与特色。重点描述了项目中采用的技术手段——结合 Transformer 和 GRU 模型的优点,通过贝叶斯优化进行超参数调整。文中给出了模型的具体实现步骤、代码示例以及完整的项目流程。同时强调了数据预处理、特征提取、窗口化分割、超参数搜索等关键技术点,并讨论了系统的设计部署细节、可视化界面制作等内容。 适合人群:具有一定机器学习基础,尤其是熟悉时间序列预测与深度学习的科研工作者或从业者。 使用场景及目标:适用于金融、医疗、能源等多个行业的高精度时间序列预测。该模型可通过捕捉长时间跨度下的复杂模式,提供更为精准的趋势预判,辅助相关机构作出合理的前瞻规划。 其他说明:此项目还涵盖了从数据采集到模型发布的全流程讲解,以及GUI图形用户界面的设计实现,有助于用户友好性提升和技术应用落地。此外,文档包含了详尽的操作指南和丰富的附录资料,包括完整的程序清单、性能评价指标等,便于读者动手实践。