ServiceMix是Apache的一个顶级开源项目,是一个ESB实现。在个人看来,它最大的特色就是从核心到应用全面支持OSGI。
ServiceMix是以Karaf为内核,而Karaf也是从早期ServiceMix的内核部分独立出来而成的一个Apache顶级项目。Karaf是整合OSGI framework及一些周边基础功能实现而成的OSGI运行时环境,所以,可以说ServiceMix就是在OSGI环境下运行的ESB系统。
除此之外,ServiceMix集成了ActiveMQ、Camel、Aries Blueprint等相关项目,而且可以通过Karaf的features不断扩展它所具备的功能,加上Camel本身所具有的大量Component......。所以无论单从哪个功能去看待ServiceMix,都会有管中窥豹的感觉。
我们先从一个简单的例子入手,来看看ServiceMix是怎么样的一个项目:
首先,我们需要在电脑上安装好JDK,然后到
http://servicemix.apache.org/downloads.html下载最新版()的Servicemix,解压后,我们可以看到这样的目录结构:
其中,运行servicemix的脚本命令在bin文件夹下,我们运行bin/servicemix.bat即可启动ServiceMix。
etc文件夹是配置文件所在;
deploy是我们自行开发的osgi bundle或blueprint xml文档等可加载的模块部署的地方,只要我们将bundle(或其它Servicemix支持的文件)放在这里,ServiceMix就能自动加载(这是基于fileinstall的bundle部署方式);
data文件夹是工作目录。
ServiceMix运行后,就会出现以下Console:
在console里就可以输入命令和Servicemix交互了(这属于Karaf提供的功能,日后有必要时就会提及这些命令)。
试下输入list命令,就可以列出在Karaf上已安装的Bundle(或其他类型的模块,因为有些可能不是bundle,后面提及的bundle都代表这种广义的模块):
在上图中,每行都对应一个bundle,第一列代表的是Bundle的ID,第二列是Bundle的状态(如:Active),第三类代表bundle的Blueprint容器的状态,第四列大概是Spring容器的状态吧(我没用过,不是很了解),第五列Level是指bundle的启动级别,也就是启动的优先级,数值越小,就越优先启动,在list命令里,Level低于某个设定值的Bundle是不显示出来的。Level对我来说并不是那么重要,所以我会选择性地忽略了它。最后一列就是Bundle的SymblicName和版本(即在Manifest.mf里指定的Bundle-SymblicName和Bundle-Version项。
可以看到,全新的ServiceMix就已经安装了很多Bundle,这些Bundle就是实现Servicemix的各项功能的-----可以简单地、抽象地将Servicemix看成是一个微内核(Karaf+OSGI framework)+很多OSGI bundle(广义的),以及一些在etc下的配置文件构成平台。
我们做应用时开发的Bundle,也是同样的方式安装到这个OSGI framework上的。所以可以说ServiceMix本身就是应用的一部分,它和应用是一体的。
下节,我们就试试做个最简单的模块放在ServiceMix上跑一下。
- 大小: 5.1 KB
- 大小: 3.8 KB
- 大小: 9.9 KB
分享到:
相关推荐
Apache ServiceMix快速入门指南旨在帮助用户在20分钟内熟悉并开始使用这款开源企业服务总线(ESB)。ServiceMix是基于OSGi的Java应用程序,它提供了集成多种不同技术和服务的能力,如Java消息服务(JMS)、Web服务、...
ServiceMix是由Apache基金会维护的一个开源项目,它是一个用于构建企业级集成解决方案和服务导向架构(SOA)的平台。ServiceMix基于OSGi规范实现,能够很好地支持诸如Apache Camel、Apache ActiveMQ等组件,使得...
如命令`mvn archetype:create -DarchetypeArtifactId=servicemix-service-unit -DarchetypeGroupId=org.apache.servicemix.tooling -DartifactId=tutorial-file-su`,此命令会创建一个ServiceMix服务单元的模板项目...
#### 一、ServiceMix安装及入门 - **ServiceMix简介**:ServiceMix是一款开源的企业服务总线(ESB),基于Java Business Integration (JBI) 规范构建,用于实现企业级应用和服务的集成。它是Apache软件基金会的一个...
总的来说,JBI开发指南(ServiceMix开发指南)是一份珍贵的资源,为开发者提供了一条学习JBI和ServiceMix的入门之路。通过这份指南,开发者可以掌握JBI规范的核心概念,包括JBI定义的消息交换模式和应用程序接口。而...
7. **适用于多个项目:** 可以作为路由和中介引擎用于 Apache ServiceMix(最流行和强大的分布式开源企业服务总线和 JBI 容器)、Apache ActiveMQ(最流行和强大的开源消息代理)、Apache CXF(智能 Web 服务套件)...
- **Apache ServiceMix**:最流行和强大的分布式开源ESB(企业服务总线)和JBI(Java Business Integration)容器。 - **Apache ActiveMQ**:最受欢迎和强大的开源消息代理。 - **Apache CXF**:一个智能的Web服务...
- **Apache ServiceMix**:最流行且功能强大的分布式开源企业服务总线(ESB)和JBI容器之一。 #### 二、架构与特性 Apache Camel的设计旨在提供一种灵活且强大的集成解决方案。其核心架构特点包括: 1. **URI驱动**...
- Apache ServiceMix:最流行且强大的分布式开源企业服务总线(ESB)和 JBI 容器。 - Apache ActiveMQ:最受欢迎的开源消息代理。 - Apache CXF:一套智能 Web 服务套件(JAX-WS)。 - Apache MINA:网络框架。 ###...
- Apache ServiceMix:一个流行的分布式开源ESB和JBI。 - Apache ActiveMQ:一个成熟且广泛使用的开源消息代理。 - Apache CXF:一个智能的Web服务套件(包括JAX-WS和JAX-RS)。 - Apache Karaf:一个小型的基于OSGi...
Apache CXF 是一个流行的开源框架,它源自 ObjectWeb Celtix 和 CodeHaus XFire 的合并,这两个项目分别由 IONA 公司和业界知名SOAP堆栈支持。CXF 提供了实现服务导向架构(SOA)所需的核心功能,如服务创建、服务...
- **Apache ServiceMix**:这是一个流行的分布式开源ESB(Enterprise Service Bus)和JBI(Java Business Integration)容器。 - **Apache ActiveMQ**:这是一个成熟的、广泛使用的开源消息代理。 - **Apache CXF...
- **Apache ServiceMix**:这是最受欢迎且功能强大的分布式开源 ESB 和 JBI 容器。 - **Apache ActiveMQ**:这是最受欢迎且功能强大的开源消息代理。 - **Apache CXF**:这是一个智能 Web 服务套件(JAX-WS)。 - **...
- 企业级应用服务器:许多Java EE应用服务器,如Apache Karaf和Apache ServiceMix,都是基于OSGI技术构建的。 - 插件系统:OSGI常用于实现应用程序的插件系统,如Eclipse IDE和Jetty Web服务器都使用OSGI来实现其...
CXF(Apache CXF)是一款基于 Java 的WebService 框架,提供了一个灵活、可扩展、可配置的WebService解决方案。下面是 CXF 开发指南的相关知识点: 一、CXF WebService 准备工作 1. CXF 官方网址:...
- `org.apache.servicemix.bundles.commons-dbcp-1.2.2_3.jar` - `commons-pool-1.4.jar` - `subethasmtp-wiser-1.2.jar` - `slf4j-nop-1.5.8.jar` - 数据库驱动(例如`mysql.jar`) - `btm-1.3.jar` - JBPM运行时的...
**HelloWorldService** 是一个经典的入门示例,展示了如何创建和发布一个简单的Web服务。 1. **服务器端代码**: - 使用了JDK5的注解(Annotation),如`@WebService`和`@SOAPBinding`。 - `@SOAPBinding(style =...
【WebService CXF详解与入门】 WebService是一种允许不同系统之间进行通信和交互的标准协议,它基于HTTP协议,使得应用程序可以无视具体实现细节地调用互联网上的服务。这种技术使得分布式应用程序的发展成为可能,...
- **集成能力**:CXF能够很好地与各种应用服务器集成,比如内置的Jetty应用服务器,同时还支持通过Yoko实现CORBA的支持,通过Tuscany支持SCA,通过ServiceMix支持JBI。 #### 二、CXF环境搭建与配置 CXF的安装非常...