`

JBoss ESB学习笔记2——第一个ESB应用Hello World

阅读更多

续上文搭建好开发环境后就可以开发ESB应用了。本文介绍第一个ESB应用——Hello, World。


说明:本文及后续文章虽非百分百的原创,但毕竟包含本人的努力和付出,所以希望大家转载时务请注明出处:http://yarafa.iteye.com,谢谢合作。

 

 

1. 新建ESB工程
如下两图所示,输入项目名称,选中JBoss ESB Runtime。

JBoss ESB

JBoss ESB

 

 

2. 基本概念介绍
在进行下面的操作之前有必要介绍JBoss ESB的一些基本概念,如果没有这些概念作基础,而仅仅是机械的操作,那是没有意义的。
2.1 Provider
在JBoss ESB中,使用Provider定义来提供ESB对外的入口,常用的Provider有:jms-provider,fs-provider,ftp-provider,schedule-provider,sql-provider,http-provider,jms-jca-provider,jbr-provider等。

2.1.1 jms-provider
用户定义JMS的接口入口,对外发布的接口可以通过JMS的形式提供出去,通过在jboss-esb.xml文件中定义JMS 的Provider,同时定义JMS监听器,就可以从监听器接收到来自客户端的JMS请求。


2.1.2 fs-provider
文件系统的接口入口,可以定义接入的文件目录,文件扩展名等信息,当特定的文件被透过任意途径放到接入目录后,监听fs-provider的监听器就可以接收到消息,并可以读取到文件的内容,文件被处理后,还可以被移动到特定的目录下,也可以修改文件的后缀名以标识文件已经被接口程序处理过了。

 

2.1.3 ftp-provider
FTP入口,可以定义入口FTP服务器的IP,用户名,密码,目录路径等信息。当有文件被上传到定义好的FTP服务器目录时,接口入口对应的监听器就可以监听到文件,并将文件内容通过Message的形式传递给接口程序。这个接口适合于通过FTP和我们系统进行通讯的接口。


2.1.4 sql-provider
数据库表接口。这个Provider适合于表接口程序。外部系统对某一个表的数据库操作可以被对这个Provider进行监听的监听器捕捉到,并调用相关的Action进行处理。

 

2.1.5 http-provider
HTTP方式的接口接入定义,通过http-provider,可以向外提供HTTP形式的接口,并接收来自这个接口的HTTP请求,可以通过请求获取到请求参数。除了通过HTTP接口提供对外接口以外,也可以通过这个接口方式来提供服务集成,我们可以在门户上指定ESB上的HTTP-Provider接口,并通过这个接口去访问外部接口,再将外部接口返回的数据封装成HTML能识别的格式,发送给门户上的Portal,从而实现服务集成。


2.1.6 jbr-provider
通过jbr-provider,可以实现Web Service的接口中介功能。

2.2 Service
Service是JBoss ESB对外发布的服务,一个Service一般包括两个部分,一个是Listener,一个是Action。Listener负责监听客户端接口发起者发送过来的消息,Action负责处理接口请求。一个Service可以有多个Listener,对多个接口入口请求;一个Service也可以有多个Action,不同的Action可以有不同的处理逻辑,也可以通过Router将多个Service组装起来,形成服务链条的形式提供服务。

 

2.3 Listener
Listener是JBoss ESB提供的各类形式的provider的监听器,通过Listener,可以获取客户端发送到Provider上的各类消息。
2.3.1 jms-listener
JMS的监听器,通过jms-listener来监听通过jms-provider进来的消息。


2.3.2 fs-listener
文件系统的监听器,通过fs-listener来监听通过fs-provider进来的消息。


2.3.3 ftp-listener
ftp监听器,通过ftp-listener来监听通过ftp-provider进来的消息。


2.3.4 sql-listener
sql监听器,通过sql-listener监听通过sql-provider进来的消息。


2.3.5 http-gateway
http监听器,监听来自http-provider的消息。
 

2.3.6 udp-listener
udp-listener用来监听指定端口的socket请求,udp-listener相对其他listener比较特殊,他无需定义provider,可以直接通过listener配置来监听指定端口的socket消息。
 

2.4 Action
Action是在Service节点下面配置的,用于相应接口请求。Action可以是我们开发人员开发的继承了AbstractActionLifecycle类的java class,可以在配置中指定process属性,表明这个Action要执行的方法名称,也可以指定exceptionMethod属性,标明当异常出现的时候,要执行的方法名称。除了可以开发Action来处理业务逻辑以外,还可以通过Action来做数据转换,服务路由等。JBoss ESB提供了若干自带的Action。
 

3 Provider定义
在JBoss ESB Editor中,新建JMS Provider,输入名称和连接工厂名称,分别是:JBossMQ和ConnectionFactory。点击下一步,输入通道ID:helloworldChanel。

JBoss ESB

JBoss ESB

 

 

4 定义消息队列
在JBoss ESB Editor中,选中Filter节点,输入目的地名称:queue/helloworld选中目的地类型为QUEUE(队列),之后保存。

JBoss ESB

 

 

5 创建服务
在JBoss ESB Editor中,选中Service节点,新建服务,输入服务名称,类别以及描述信息,Finish即可。回到JBoss ESB Editor,设置invmScope属性为GLOBAL。该这只的具体含义以后会做介绍,这里不做说明。

JBoss ESB

 

 

6 创建JMS Listener
在JBoss ESB Editor中,选中Listener节点,新建JMS Listener,输入监听器的名称,同时选中之前创建的通道的ID。最后在JBoss ESB Editor中设置该监听器的is-gateway属性为true。这使得ESB可以直接处理JMS消息。

 

If you send a message directly to another service internally, it must be an EsbMessage! Only Gateways are capable of receiving real JMS messages..  ——某网友语

 

JBoss ESB

JBoss ESB

 

 

7 Action类定义
由于这里使用的是自定义的action,所以在配置action之前需要编写一个扩展了AbstractActionLifecycle类的action类,类定义如下:

JBoss ESB

 

/***********************************************************************
 * <p>Project Name: helloworld</p>
 * <p>File Name: com.thu.afa.esb.jbossesb.action.HelloWorldAction.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.Message;

/**
 * <p>Class Name: HelloWorldAction</p>
 * <p>Description: </p>
 * @author Afa
 * @date 2010-9-6
 * @version 1.0
 */
public class HelloWorldAction extends AbstractActionLifecycle
{
	protected ConfigTree configTree;
	
	public HelloWorldAction(ConfigTree configTree)
	{
		this.configTree = configTree;
	}
	
	public Message doPrintMessage(Message message) throws Exception
	{
		System.out.println(message.getBody().get());
		
		return message;
	}
}

 

Action类说明:在action类中必须有一个ConfigTree类型的属性以及一个包含ConfigTree类型参数的构造方法,而逻辑处理方法(这里是doPrintMessage)的参数和返回值都必须是Message。

 

8 Action配置
在JBoss ESB Editor中,选中Action节点,新建Custom Action,如下图所示,输入名称,类路径,并指定处理方法。到此,ESB工程的配置基本完成,下面可以进行部署了。

JBoss ESB

 

 

9 ESB部署
首先在esbcontent文件夹下新建jbm-queue-service.xml文件,内容如下:

<?xml version="1.0" encoding="UTF-8"?>
<server>
	<mbean code="org.jboss.jms.server.destination.QueueService"
		name="jboss.esb.helloworld.destination:service=Queue,name=helloworld"
		xmbean-dd="xmdesc/Queue-xmbean.xml">
		<depends optional-attribute-name="ServerPeer">
			jboss.messaging:service=ServerPeer
		</depends>
		<depends>jboss.messaging:service=PostOffice</depends>
	</mbean>
</server>

 

然后在esbcontent/META-INF目录下新建deployment.xml文件,内容如下:

<jbossesb-deployment>
	<depends>	jboss.esb.helloworld.destination:service=Queue,name=helloworld
	</depends>
</jbossesb-deployment>

 

将整个工程导出成ESB文件,并将其保存至%JBOSSESB_SERVER_HOME%\server\default\deploy目录下,然后启动ESB服务器。工程文件目录结构如下图所示。

JBoss ESB

 

 

 

10 ESB客户端
新建Java工程,并将以下Jar包添加到classpath(注:所有的Jar包都可以在jboss-esb-server中找到),客户端测试代码如下所示。

JBoss ESB

 

/***********************************************************************
 * <p>Project Name: helloworldclient</p>
 * <p>File Name: com.thu.afa.esb.jbossesb.client.HelloWorldClient.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.util.Properties;

import javax.jms.Message;
import javax.jms.Queue;
import javax.jms.QueueConnection;
import javax.jms.QueueConnectionFactory;
import javax.jms.QueueSender;
import javax.jms.QueueSession;
import javax.naming.Context;
import javax.naming.InitialContext;

/**
 * <p>Class Name: HelloWorldClient</p>
 * <p>Description: </p>
 * @author Afa
 * @date 2010-9-6
 * @version 1.0
 */
public class HelloWorldClient
{
	private QueueConnection connection;
	private QueueSession session;
	private Queue queue;
	
	public void setupConnection() throws Exception
	{
		System.out.println("Connection Starting...");
		
		Properties properties = new Properties();
		properties.put(Context.INITIAL_CONTEXT_FACTORY, "org.jnp.interfaces.NamingContextFactory");   
		properties.put(Context.URL_PKG_PREFIXES, "org.jboss.naming:org.jnp.interfaces");   
		properties.put(Context.PROVIDER_URL, "jnp://127.0.0.1:1099");
		InitialContext context = new InitialContext(properties);
		
		QueueConnectionFactory factory = (QueueConnectionFactory) context.lookup("ConnectionFactory");
		connection = factory.createQueueConnection();
		queue = (Queue) context.lookup("queue/helloworld");
		session = connection.createQueueSession(false, QueueSession.AUTO_ACKNOWLEDGE);
		connection.start();
		
		System.out.println("Connection Started");
	}
	
	public void stop() throws Exception
	{
		if(connection != null) connection.stop();
		if(session != null) session.close();
		if(connection != null) connection.close();
	}
	
	public void sendMessage(String text) throws Exception
	{
		QueueSender sender = session.createSender(queue);
		Message message = session.createTextMessage(text);
		sender.send(message);
		sender.close();
	}
	
	/**
	 * <p>Title: </p>
	 * <p>Method Name: main</p>
	 * <p>Description: </p>
	 * @author: Afa
	 * @date: 2010-9-6
	 * @param args
	 */
	public static void main(String[] args) throws Exception
	{
		HelloWorldClient main = new HelloWorldClient();
		main.setupConnection();
		main.sendMessage("Llu, miss you");
		main.stop();
	}
}

 

运行客户端即可在控制台窗口看到如下信息(下图控制台窗口中最后一行信息):

JBoss ESB

 

 

综上,第一个JBoss ESB实例到此全部完成,包括服务端和客户端。

 

11 注意事项
11.1 JMS Provider配置
在JMS Provider配置中,上述示例中的name属性是JBossMQ, 但是对于JBoss ESB Server来说,是默认使用JBoss Messaging的。如果是把JBoss ESB安装在JBoss AS 4.x的服务器,那么就是用JBoss MQ,因为JBoss AS 4.x默认是使用JBoss MQ。


11.2 Listener的Gateway属性
在listener里,我们通过busidref来关联到我们定义在provider里面的bus。在上述示例中,我们定义了一个listener,并且做为Gateway,只负责从外界获取到JMS消息,然后转成ESB内部所需要的Message。

 

11.3 自定义的Action类
一般来说每个Action都要继承AbstractActionLifecycle类,输入/输出参数都必须是ESB的Message,方法名可以随便定义。你只需要在jboss-esb.xml的action的process属性中写对应的方法名即可。如果不写,默认是process方法。
ConfigTree是个很重要的属性,我们很经常会在Action配置其他的信息,那么,所有的信息都可以通过ConfigTree来获取,比如在某个Action中配置静态路由信息。也正是由于在Action中可以随意的配置自己的信息,这增加了很多的灵活性和扩展性。

 

 

 

-----------------------------------------------------
Stay Hungry, Stay Foolish!
http://yarafa.iteye.com

Afa
Dec 13rd, 2010
-----------------------------------------------------

 

 

分享到:
评论
20 楼 qianyang 2013-05-01  
ligenhang 写道
我部署也报
java.lang.RuntimeException: org.jboss.soa.esb.ConfigurationException: The base Listener config [helloworldListener] must reference a base Bus config type (<bus>).
错误


我找到原因了,在配置Listener时没有选择jms Listener,正确的应该是这样:
<jms-listener busidref="helloworldChanel" is-gateway="true" name="helloListener"/>
各位可以查一下
19 楼 hone033 2012-11-13  
已找到原因了
18 楼 hone033 2012-11-13  
DEPLOYMENTS IN ERROR:
  Deployment "jboss.esb.vfszip:/opt/jboss-5.1.0.GA/server/all/deploy/HelloWorld.esb/" is in error due to the following reason(s): javax.jms.JMSException: There is no administratively defined queue with name:queue/helloworld

at org.jboss.deployers.plugins.deployers.DeployersImpl.checkComplete(DeployersImpl.java:993)
at org.jboss.deployers.plugins.deployers.DeployersImpl.checkComplete(DeployersImpl.java:939)
at org.jboss.deployers.plugins.main.MainDeployerImpl.checkComplete(MainDeployerImpl.java:873)
at org.jboss.system.server.profileservice.repository.MainDeployerAdapter.checkComplete(MainDeployerAdapter.java:128)
at org.jboss.system.server.profileservice.hotdeploy.HDScanner.scan(HDScanner.java:369)
at org.jboss.system.server.profileservice.hotdeploy.HDScanner.run(HDScanner.java:255)
at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:441)
at java.util.concurrent.FutureTask$Sync.innerRunAndReset(FutureTask.java:317)
at java.util.concurrent.FutureTask.runAndReset(FutureTask.java:150)
at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.access$101(ScheduledThreadPoolExecutor.java:98)
at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.runPeriodic(ScheduledThreadPoolExecutor.java:180)
at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.run(ScheduledThreadPoolExecutor.java:204)
at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:886)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:908)
at java.lang.Thread.run(Thread.java:662)

这个是怎么回事?为啥会报这个错的,请求帮助
谢谢
17 楼 yarafa 2012-10-27  
feng888918 写道
求一个 jboss esb学习笔记中 客户端 所需 jar  包  非常感谢
邮箱1024784402@qq.com

我在文章中已经说清楚了,所有的jar包都可以在jboss-esb-server中找到,不知道你还需要什么,如果真找不到,你可以从网上下的
16 楼 feng888918 2012-10-13  
求一个 jboss esb学习笔记中 客户端 所需 jar  包  非常感谢
邮箱1024784402@qq.com
15 楼 feng888918 2012-10-12  
求一个 客户端 的 所需 jar   哥哥们  我的 邮箱1024784402@qq.com
14 楼 xiao_2008 2012-07-30  
very good.
13 楼 huangpoyuan 2012-03-09  
Exception in thread "main" javax.naming.NameNotFoundException: helloworld not bound
at org.jnp.server.NamingServer.getBinding(NamingServer.java:771)
at org.jnp.server.NamingServer.getBinding(NamingServer.java:779)
at org.jnp.server.NamingServer.getObject(NamingServer.java:785)
at org.jnp.server.NamingServer.lookup(NamingServer.java:443)
at org.jnp.server.NamingServer.lookup(NamingServer.java:399)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
at java.lang.reflect.Method.invoke(Method.java:597)
at sun.rmi.server.UnicastServerRef.dispatch(UnicastServerRef.java:305)
at sun.rmi.transport.Transport$1.run(Transport.java:159)
at java.security.AccessController.doPrivileged(Native Method)
at sun.rmi.transport.Transport.serviceCall(Transport.java:155)
at sun.rmi.transport.tcp.TCPTransport.handleMessages(TCPTransport.java:535)
at sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.run0(TCPTransport.java:790)
at sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.run(TCPTransport.java:649)
at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:886)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:908)
at java.lang.Thread.run(Thread.java:619)
at sun.rmi.transport.StreamRemoteCall.exceptionReceivedFromServer(StreamRemoteCall.java:255)
at sun.rmi.transport.StreamRemoteCall.executeCall(StreamRemoteCall.java:233)
at sun.rmi.server.UnicastRef.invoke(UnicastRef.java:142)
at org.jnp.server.NamingServer_Stub.lookup(Unknown Source)
at org.jnp.interfaces.NamingContext.lookup(NamingContext.java:728)
at org.jnp.interfaces.NamingContext.lookup(NamingContext.java:688)
at javax.naming.InitialContext.lookup(InitialContext.java:392)
at com.thu.afa.esb.jbossesb.client.HelloWorldClient.setupConnection(HelloWorldClient.java:32)
at com.thu.afa.esb.jbossesb.client.HelloWorldClient.main(HelloWorldClient.java:58)

我按例子做的,提示helloworld not bound,这是什么原因?
12 楼 nitian123ok 2011-12-01  
java.lang.RuntimeException: org.jboss.soa.esb.ConfigurationException: The base Listener config [helloworldListener] must reference a base Bus config type (<bus>).
Exception in thread "main" org.jboss.jms.exception.MessagingJMSException: Failed to invoke
at org.jboss.jms.client.delegate.DelegateSupport.handleThrowable(DelegateSupport.java:271)
at org.jboss.jms.client.delegate.ClientConnectionFactoryDelegate.org$jboss$jms$client$delegate$ClientConnectionFactoryDelegate$createConnectionDelegate$aop(ClientConnectionFactoryDelegate.java:198)
at org.jboss.jms.client.delegate.ClientConnectionFactoryDelegate$createConnectionDelegate_N3019492359065420858.invokeNext(ClientConnectionFactoryDelegate$createConnectionDelegate_N3019492359065420858.java)
at org.jboss.jms.client.container.StateCreationAspect.handleCreateConnectionDelegate(StateCreationAspect.java:80)
at org.jboss.aop.advice.org.jboss.jms.client.container.StateCreationAspect0.invoke(StateCreationAspect0.java)

运行客户端时报的异常。还请楼主帮忙!
at org.jboss.jms.client.delegate.ClientConnectionFactoryDelegate$createConnectionDelegate_N3019492359065420858.invokeNext(ClientConnectionFactoryDelegate$createConnectionDelegate_N3019492359065420858.java)
at org.jboss.jms.client.delegate.ClientConnectionFactoryDelegate.createConnectionDelegate(ClientConnectionFactoryDelegate.java)
at org.jboss.jms.client.JBossConnectionFactory.createConnectionInternal(JBossConnectionFactory.java:205)
at org.jboss.jms.client.JBossConnectionFactory.createQueueConnection(JBossConnectionFactory.java:101)
at org.jboss.jms.client.JBossConnectionFactory.createQueueConnection(JBossConnectionFactory.java:95)
at com.thu.afa.esb.jbossesb.client.HelloWorldClient.setupConnection(HelloWorldClient.java:50)
at com.thu.afa.esb.jbossesb.client.HelloWorldClient.main(HelloWorldClient.java:92)
Caused by: java.lang.NoSuchMethodError: org.jboss.remoting.Client.connect(Lorg/jboss/remoting/ConnectionListener;Ljava/util/Map;)V
at org.jboss.jms.client.remoting.JMSRemotingConnection$1.run(JMSRemotingConnection.java:374)
at java.security.AccessController.doPrivileged(Native Method)
at org.jboss.jms.client.remoting.JMSRemotingConnection.start(JMSRemotingConnection.java:368)
at org.jboss.jms.client.delegate.ClientConnectionFactoryDelegate.org$jboss$jms$client$delegate$ClientConnectionFactoryDelegate$createConnectionDelegate$aop(ClientConnectionFactoryDelegate.java:165)
... 10 more
11 楼 ligenhang 2011-10-13  
我部署也报
java.lang.RuntimeException: org.jboss.soa.esb.ConfigurationException: The base Listener config [helloworldListener] must reference a base Bus config type (<bus>).
错误
10 楼 wh3577 2011-09-28  
部署helloworld发生错误:
引用
java.lang.RuntimeException: org.jboss.soa.esb.ConfigurationException: The base Listener config [helloworldListener] must reference a base Bus config type (<bus>).

求版主解释!先谢谢了啊!我邮箱是wh3577@163.com,求交流!哈哈
9 楼 wh3577 2011-09-28  
部署helloworld发生错误:
引用
java.lang.RuntimeException: org.jboss.soa.esb.ConfigurationException: The base Listener config [helloworldListener] must reference a base Bus config type (<bus>).

求版主解释!先谢谢了啊!
8 楼 yarafa 2011-08-30  
deployment.xml是一个依赖文件,即启动本esb工程需要依赖的一些服务或者消息队列
7 楼 hesihua 2011-08-11  
还有就是deployment.xml这个是干什么用的?
6 楼 crabboy 2011-04-29  
终于通了:s-gateway属性为true
service的invmScope属性为GLOBAL

至于为什么,就不得而知了。留着以后再消化
5 楼 yarafa 2011-04-25  
这句话说的很清楚,
Service configuration for Service 'HelloWorld:HelloWorldService' doesn't define a Message-Aware Listener
你没有设置一个is-gateway属性为false的listener,用于传递经ESB封装后的消息,此时需要设置service的invmScope属性为GLOBAL
4 楼 yarafa 2011-04-25  
你的service是否设置了invmScope属性为GLOBAL
3 楼 crabboy 2011-04-24  
引用

--- MBeans waiting for other MBeans ---
ObjectName: jboss.esb:deployment=helloworld.esb
  State: FAILED
  Reason: java.lang.RuntimeException: org.jboss.soa.esb.ConfigurationException: Service configuration for Service 'HelloWorld:HelloWorldService' doesn't define a Message-Aware Listener (i.e. is-gateway='false').
  I Depend On:
    jboss.esb:deployment=jbossesb.esb
    jboss.esb.helloworld.destination:service=Queue,name=helloworld

--- MBEANS THAT ARE THE ROOT CAUSE OF THE PROBLEM ---
ObjectName: jboss.esb:deployment=helloworld.esb
  State: FAILED
  Reason: java.lang.RuntimeException: org.jboss.soa.esb.ConfigurationException: Service configuration for Service 'HelloWorld:HelloWorldService' doesn't define a Message-Aware Listener (i.e. is-gateway='false').
  I Depend On:
    jboss.esb:deployment=jbossesb.esb
    jboss.esb.helloworld.destination:service=Queue,name=helloworld

照着做了几遍还是这样的错误,求解!
2 楼 crabboy 2011-04-24  
部署helloworld发生错误:
引用
java.lang.RuntimeException: org.jboss.soa.esb.ConfigurationException: The base Listener config [helloworldListener] must reference a base Bus config type (<bus>).
1 楼 crabboy 2011-04-24  
奇怪了,我在
引用
6 创建JMS Listener
的时候,没有看到
引用
设置该监听器的is-gateway属性
这个按钮啊?版本不对?

相关推荐

    JBOSS_Esb学习资料

    4. **Spring整合**:《JBoss_ESB学习笔记13——第十个ESB应用Spring_AOP.doc》和《JBoss_ESB学习笔记12——第十个ESB应用Spring_helloworld.doc》涉及到Spring框架与ESB的结合,Spring AOP(面向切面编程)在ESB中的...

    JBoss ESB 学习笔记

    #### 二、第一个ESB应用Hello World - **目标**:通过简单的示例熟悉JBoss ESB的基本组件和工作流程。 - **实现**:创建一个基本的服务组件,实现简单的消息传递功能。 #### 三、第二个ESB应用Hello World Action ...

    Jboss-ESB学习笔记.doc

    本篇学习笔记主要围绕 JBoss ESB 的一个基础应用——“Hello World File Action”进行讲解,这个例子展示了如何利用 JBoss ESB 的 File Gateway 功能来监控文件系统变化,并通过 JMS(Java Message Service)消息...

    一个基于Qt Creator(qt,C++)实现中国象棋人机对战

    qt 一个基于Qt Creator(qt,C++)实现中国象棋人机对战.

    热带雨林自驾游自然奇观探索.doc

    热带雨林自驾游自然奇观探索

    冰川湖自驾游冰雪交融景象.doc

    冰川湖自驾游冰雪交融景象

    C51 单片机数码管使用 Keil项目C语言源码

    C51 单片机数码管使用 Keil项目C语言源码

    基于智能算法的无人机路径规划研究 附Matlab代码.rar

    1.版本:matlab2014/2019a/2024a 2.附赠案例数据可直接运行matlab程序。 3.代码特点:参数化编程、参数可方便更改、代码编程思路清晰、注释明细。 4.适用对象:计算机,电子信息工程、数学等专业的大学生课程设计、期末大作业和毕业设计。

    前端分析-2023071100789s12

    前端分析-2023071100789s12

    Delphi 12.3控件之Laz-制作了一些窗体和对话框样式.7z

    Laz_制作了一些窗体和对话框样式.7z

    ocaml-docs-4.05.0-6.el7.x64-86.rpm.tar.gz

    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页】.pptx

    工业机器人技术讲解【36页】

    基于CentOS 7和Docker环境下安装和配置Elasticsearch数据库

    内容概要:本文档详细介绍了在 CentOS 7 上利用 Docker 容器化环境来部署和配置 Elasticsearch 数据库的过程。首先概述了 Elasticsearch 的特点及其主要应用场景如全文检索、日志和数据分析等,并强调了其分布式架构带来的高性能与可扩展性。之后针对具体的安装流程进行了讲解,涉及创建所需的工作目录,准备docker-compose.yml文件以及通过docker-compose工具自动化完成镜像下载和服务启动的一系列命令;同时对可能出现的问题提供了应对策略并附带解决了分词功能出现的问题。 适合人群:从事IT运维工作的技术人员或对NoSQL数据库感兴趣的开发者。 使用场景及目标:该教程旨在帮助读者掌握如何在一个Linux系统中使用现代化的应用交付方式搭建企业级搜索引擎解决方案,特别适用于希望深入了解Elastic Stack生态体系的个人研究与团队项目实践中。 阅读建议:建议按照文中给出的具体步骤进行实验验证,尤其是要注意调整相关参数配置适配自身环境。对于初次接触此话题的朋友来说,应该提前熟悉一下Linux操作系统的基础命令行知识和Docker的相关基础知识

    基于CNN和FNN的进化神经元模型的快速响应尖峰神经网络 附Matlab代码.rar

    1.版本:matlab2014/2019a/2024a 2.附赠案例数据可直接运行matlab程序。 3.代码特点:参数化编程、参数可方便更改、代码编程思路清晰、注释明细。 4.适用对象:计算机,电子信息工程、数学等专业的大学生课程设计、期末大作业和毕业设计。

    网络小说的类型创新、情节设计与角色塑造.doc

    网络小说的类型创新、情节设计与角色塑造

    毕业设计-基于springboot+vue开发的学生考勤管理系统【源码+sql+可运行】50311.zip

    毕业设计_基于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.若不会,可私信博主!!!

    57页-智慧办公园区智能化设计方案.pdf

    在智慧城市建设的大潮中,智慧园区作为其中的璀璨明珠,正以其独特的魅力引领着产业园区的新一轮变革。想象一下,一个集绿色、高端、智能、创新于一体的未来园区,它不仅融合了科技研发、商业居住、办公文创等多种功能,更通过深度应用信息技术,实现了从传统到智慧的华丽转身。 智慧园区通过“四化”建设——即园区运营精细化、园区体验智能化、园区服务专业化和园区设施信息化,彻底颠覆了传统园区的管理模式。在这里,基础设施的数据收集与分析让管理变得更加主动和高效,从温湿度监控到烟雾报警,从消防水箱液位监测到消防栓防盗水装置,每一处细节都彰显着智能的力量。而远程抄表、空调和变配电的智能化管控,更是在节能降耗的同时,极大地提升了园区的运维效率。更令人兴奋的是,通过智慧监控、人流统计和自动访客系统等高科技手段,园区的安全防范能力得到了质的飞跃,让每一位入驻企业和个人都能享受到“拎包入住”般的便捷与安心。 更令人瞩目的是,智慧园区还构建了集信息服务、企业服务、物业服务于一体的综合服务体系。无论是通过园区门户进行信息查询、投诉反馈,还是享受便捷的电商服务、法律咨询和融资支持,亦或是利用云ERP和云OA系统提升企业的管理水平和运营效率,智慧园区都以其全面、专业、高效的服务,为企业的发展插上了腾飞的翅膀。而这一切的背后,是大数据、云计算、人工智能等前沿技术的深度融合与应用,它们如同智慧的大脑,让园区的管理和服务变得更加聪明、更加贴心。走进智慧园区,就像踏入了一个充满无限可能的未来世界,这里不仅有科技的魅力,更有生活的温度,让人不禁对未来充满了无限的憧憬与期待。

    一种欠定盲源分离方法及其在模态识别中的应用 附Matlab代码.rar

    1.版本:matlab2014/2019a/2024a 2.附赠案例数据可直接运行matlab程序。 3.代码特点:参数化编程、参数可方便更改、代码编程思路清晰、注释明细。 4.适用对象:计算机,电子信息工程、数学等专业的大学生课程设计、期末大作业和毕业设计。

    Matlab实现基于BO贝叶斯优化Transformer结合GRU门控循环单元时间序列预测的详细项目实例(含完整的程序,GUI设计和代码详解)

    内容概要:本文介绍了使用 Matlab 实现基于 BO(贝叶斯优化)的 Transformer 结合 GRU 门控循环单元时间序列预测的具体项目案例。文章首先介绍了时间序列预测的重要性及其现有方法存在的限制,随后深入阐述了该项目的目标、挑战与特色。重点描述了项目中采用的技术手段——结合 Transformer 和 GRU 模型的优点,通过贝叶斯优化进行超参数调整。文中给出了模型的具体实现步骤、代码示例以及完整的项目流程。同时强调了数据预处理、特征提取、窗口化分割、超参数搜索等关键技术点,并讨论了系统的设计部署细节、可视化界面制作等内容。 适合人群:具有一定机器学习基础,尤其是熟悉时间序列预测与深度学习的科研工作者或从业者。 使用场景及目标:适用于金融、医疗、能源等多个行业的高精度时间序列预测。该模型可通过捕捉长时间跨度下的复杂模式,提供更为精准的趋势预判,辅助相关机构作出合理的前瞻规划。 其他说明:此项目还涵盖了从数据采集到模型发布的全流程讲解,以及GUI图形用户界面的设计实现,有助于用户友好性提升和技术应用落地。此外,文档包含了详尽的操作指南和丰富的附录资料,包括完整的程序清单、性能评价指标等,便于读者动手实践。

Global site tag (gtag.js) - Google Analytics