最近项目中方法用到了一些新的东西,由于之前没有用到过,现在总结一下,方便以后查阅,本篇文章介绍ultraESB,接下来的文章会介绍JsonSchema,JsonSchamaValidator,JsonPath以及如何在spring项目中更方便地使用反射机制

ultraESB是我们项目中采用的一个开源的ESB实现,主要目的是为了依据数据库表提供一些REST查询接口,以及代理和整合其他的一些webservice和REST接口,ultraESB的主要优点是开源,配置简单,功能比较丰富,同时还提供了一个基于JMX的管理控制台,可以动态地启动和停止某些服务而不影响其他的服务。

由于官网下载编译好的包会有问题(点击了按钮之后没有任何反应),所以下边提供了源码的托管地址,可以直接下载源代码,然后用maven来进行编译

源码地址:https://bitbucket.org/adroitlogic/ultraesb/src

与项目的集成:ultraESB可以作为一个web项目进行单独部署(在web.xml里边配置spring的相关Listener等,在spring配置文件里定义各个Rest接口,代理的webservice接口等等),或是与我们的项目集成在一起(要求项目支持spring,各个rest接口和代理的webservice等还是在spring的配置文件中进行定义,需要将ultraESB依赖的jar包引入项目中)

下边是一个demo的配置(我们选择将ultraESB的相关配置放在一个独立的spring配置文件里),包括了数据源配置和基于数据库表提供的REST接口

以及对webservice接口进行proxy

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:u="http://www.adroitlogic.org/ultraesb"
xsi:schemaLocation="
http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.1.xsd
http://www.adroitlogic.org/ultraesb http://schemas.ultraesb.org/ultraesb-2.0.xsd">
<bean id="ultra-config" class="org.adroitlogic.ultraesb.core.ConfigurationImpl">
<property name="environment">
<bean class="org.adroitlogic.ultraesb.api.Environment">
<constructor-arg name="name" value="path"/>
</bean>
</property>
</bean>
<bean id="fileCache" class="org.adroitlogic.ultraesb.core.PooledMessageFileCache">
<constructor-arg type="int" value="20"/>
</bean> <bean id="http-8280" class="org.adroitlogic.ultraesb.transport.http.HttpNIOListener">
<constructor-arg ref="fileCache"/>
<property name="port" value="8280"/>
<!--配置默认路径-->
<property name="defaultContextPath" value="/service/"/>
<property name="requestFilters">
<list>
<bean class="org.adroitlogic.ultraesb.transport.http.ServiceResourceRequestFilter">
<property name="resourcePrefix" value="http://localhost:8280"/>
</bean>
</list>
</property>
</bean>
<!-- proxy其他接口的时候用来发送http请求,若不加上则不会向所proxy的接口发送请求-->
<bean id="http-sender" class="org.adroitlogic.ultraesb.transport.http.HttpNIOSender">
<constructor-arg ref="fileCache"/>
</bean> <!--Demonstrates a basic query-only JSON data service. This only supports GET method, and is able to return one
or all rows from a table using the specified queries-->
<!-- pds数据表对应的接口proxy -->
<u:proxy id="pdsRestService">
<u:transport id="http-8280">
<u:property name="ultra.transport.url" value="path*"/>
</u:transport>
<u:target>
<u:inSequence>
<u:java><![CDATA[
mediation.getJSONSupport().processBasicJSONDataServiceRequest(msg, "pdsJsonSvc", "dataSource_rest");
]]></u:java>
</u:inSequence>
</u:target>
</u:proxy>
<!-- 数据表对应接口的查询条件定义-->
<bean id="jsonSvc" class="org.adroitlogic.ultraesb.core.helper.BasicJSONDataService" init-method="init">
<property name="queryMap">
<map>
<!--注意,若前缀相同,更长的URL应该写在前边-->
<entry key="/contract/{code:VARCHAR}/reports" value="SELECT * from t1 where code =:code"/>
<entry key="/contract/{code:VARCHAR}" value="SELECT * from t2 where code= :code"/>
</map> </property>
</bean> <!--这里proxy的id对应最终提供的接口的URL中/service/之后的部分-->
<!-- 代理webservice-->
<u:proxy id="webServiceURL">
<u:transport id="http-8280">
<u:property name="ultra.http.wsdl_url"
value="http://192.168.1.1:7780/orabpel/sc/SB_SC_CMS_InquiryContractApprovalInfoSrv/1.0?wsdl"/>
</u:transport> <u:target>
<u:inDestination>
<!-- 实际URL-->
<u:address>http://192.168.1.1:7780/orabpel/sc/SB_SC_CMS_InquiryContractApprovalInfoSrv/1.0</u:address>
</u:inDestination>
<u:outDestination>
<u:address type="response"/>
</u:outDestination>
</u:target>
</u:proxy> <!--数据源配置(名称无所谓)-->
<bean id="dataSource_rest" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
<property name="driverClassName" value="${jdbc.data.driverClassName}"/>
<property name="url" value="${jdbc.data.url}"/>
<property name="username" value="${jdbc.data.username}"/>
<property name="password" value="${jdbc.data.password}"/>
<property name="maxActive" value="${jdbc.data.maxActive}"/>
<property name="minIdle" value="${jdbc.data.minIdle}"/>
<property name="maxIdle" value="${jdbc.data.maxIdle}"/>
</bean>
<!-- JMX监控-->
<bean id="serverConnector" class="org.springframework.jmx.support.ConnectorServerFactoryBean" depends-on="registry">
<property name="objectName" value="connector:name=iiop"/>
<property name="serviceUrl" value="${esb.jmx.url}"/>
<property name="threaded" value="true"/>
<property name="daemon" value="true"/>
</bean>
<bean id="registry" class="org.springframework.remoting.rmi.RmiRegistryFactoryBean">
<property name="port" value="1099"/>
</bean>
</beans>

访问,在地址栏输入:

http://localhost:8280/service/path/contract/参数

http://localhost:8280/service/path/contract/参数/reports

即可访问配置的两个rest接口

访问代理的webservice 的地址:

http://localhost:8280/service/path/webServiceURL

总结一下最近用到的技术(1)--ultraESB的更多相关文章

  1. 关于解决python线上问题的几种有效技术

    工作后好久没上博客园了,虽然不是很忙,但也没学生时代闲了.今天上博客园,发现好多的文章都是年终总结,想想是不是自己也应该总结下,不过现在还没想好,等想好了再写吧.今天写写自己在工作后用到的技术干货,争 ...

  2. SQL Server技术内幕笔记合集

    SQL Server技术内幕笔记合集 发这一篇文章主要是方便大家找到我的笔记入口,方便大家o(∩_∩)o Microsoft SQL Server 6.5 技术内幕 笔记http://www.cnbl ...

  3. 本人提供微软系.NET技术顾问服务,欢迎企业咨询!

    背景: 1:目前微软系.NET技术高端人才缺少. 2:企业很难直接招到高端技术人才. 3:本人提供.NET技术顾问,保障你的产品或项目在正确的技术方向. 技术顾问服务 硬服务项: 1:提供技术.决策. ...

  4. 分布式锁1 Java常用技术方案

    前言:       由于在平时的工作中,线上服务器是分布式多台部署的,经常会面临解决分布式场景下数据一致性的问题,那么就要利用分布式锁来解决这些问题.所以自己结合实际工作中的一些经验和网上看到的一些资 ...

  5. 【大型网站技术实践】初级篇:借助LVS+Keepalived实现负载均衡

    一.负载均衡:必不可少的基础手段 1.1 找更多的牛来拉车吧 当前大多数的互联网系统都使用了服务器集群技术,集群即将相同服务部署在多台服务器上构成一个集群整体对外提供服务,这些集群可以是Web应用服务 ...

  6. 探真无阻塞加载javascript脚本技术,我们会发现很多意想不到的秘密

    下面的图片是我使用firefox和chrome浏览百度首页时候记录的http请求 下面是firefox: 下面是chrome: 在浏览百度首页前我都将浏览器的缓存全部清理掉,让这个场景最接近第一次访问 ...

  7. 关于如何提高Web服务端并发效率的异步编程技术

    最近我研究技术的一个重点是java的多线程开发,在我早期学习java的时候,很多书上把java的多线程开发标榜为简单易用,这个简单易用是以C语言作为参照的,不过我也没有使用过C语言开发过多线程,我只知 ...

  8. 架构设计:远程调用服务架构设计及zookeeper技术详解(下篇)

    一.下篇开头的废话 终于开写下篇了,这也是我写远程调用框架的第三篇文章,前两篇都被博客园作为[编辑推荐]的文章,很兴奋哦,嘿嘿~~~~,本人是个很臭美的人,一定得要截图为证: 今天是2014年的第一天 ...

  9. Java数据库连接技术——JDBC

    大家好,今天我们学习了Java如何连接数据库.之前学过.net语言的数据库操作,感觉就是一通百通,大同小异. JDBC是Java数据库连接技术的简称,提供连接各种常用数据库的能力. JDBC API ...

随机推荐

  1. storm学习之七-storm UI页面参数详解

    http://lbxc.iteye.com/blog/1522318 --参考文章 http://blog.csdn.net/rong_89/article/details/39473917 --参考 ...

  2. php解析mpp文件中的前置任务

    获取层级的project任务  参考 启动javabridge java -jar JavaBridge.jar SERVLET_LOCAL:8089 1.读取mpp文件 $file_path = & ...

  3. php解析mpp文件

    php没有找到相应的包 Java的mpxj可以实现 所以借助JavaBridge.jar 1.安装jdk,设置环境变量(我的版本jdk1.8.0_131) 2.下载mpjx 在http://www.m ...

  4. 如果你的eclipse在每次run或debug时都莫名其妙的做一件事

    新项目,使用Ant打war包.结果写完了Ant以后,包是打好了,却使eclipse以后每次run或debug时都莫名其妙地自动先执行这个Ant, 让人十分苦恼. 其实,是你的eclipse设置出了问题 ...

  5. zabbix-agents客户端安装

    Windows下zabbix客户端的安装 记得关windows上的防火墙 1.首先需要下载zabbix_agents.rar文件 点击这里进行下载 当然也可以在www.zabbix.com进行下载 2 ...

  6. linux proc目录介绍

    https://www.cnblogs.com/DswCnblog/p/5780389.html

  7. Hash冲突的解决方法

    虽然我们不希望发生冲突,但实际上发生冲突的可能性仍是存在的.当关键字值域远大于哈希表的长度,而且事先并不知道关键字的具体取值时.冲突就难免会发 生.另外,当关键字的实际取值大于哈希表的长度时,而且表中 ...

  8. 高可用(HA)架构

    http://aokunsang.iteye.com/blog/2053719   浅谈web应用的负载均衡.集群.高可用(HA)解决方案 http://zhuanlan.51cto.com/art/ ...

  9. Python中的类(上)

    在Python中,可以通过class关键字定义自己的类,然后通过自定义的类对象类创建实例对象. 例如,下面创建了一个Student的类,并且实现了这个类的初始化函数"__init__&quo ...

  10. 从Gallery中获取图片示例

    一.MainActivity类 package com.example.gallerydemo; import android.net.Uri; import android.os.Bundle; i ...