我们在做企业集成项目的时候,经常会用到很多开源中间件,比如企业服务总线,消息中间件,服务框架等。在使用这些开源中间件的时候,我们也趟过了很多的坑,EnjoyingSoft,就是享受这些软件,其中积累的经验分享给大家,希望为开源事业做一份贡献。这篇系列主要说的是企业服务总线Mule ESB。

Mule ESB在众多开源的ESB中处于领先者的地位,MuleSoft公司也作为独角兽,2017年在纽交所上市。我们作为MuleSoft的合作伙伴也有幸参与其中,在六年多的时间里,我们使用Mule ESB企业版实施,或者在社区版基础上扩展,使用Mule ESB社区版实施,帮助国内众多的企业成功上线SOA项目。

使用Mule ESB的过程中,体会到其快速的开发效率,以及优秀的架构设计。同时也深感国内这块资料非常稀少,所以计划使用8篇文章来写Mule ESB的基础课程系列。

1. Mule ESB基本介绍

Mule ESB是世界上使用最广泛的开源企业服务总线(ESB)产品,已拥有超过数百万的下载量,以及来自世界各地数十万个开发人员,很多世界五百强企业选择Mule ESB作为企业集成平台。通过Mule,企业可以在短时间内轻松地创建并集成应用服务,Mule ESB消除了系统集成的复杂度,使开发人员能够在异构系统和服务之间,轻松地构建出高性能的集成应用。

和传统的ESB不一样,Mule ESB是一个轻量级的ESB,内核基于SEDA模型和Spring框架构建。基于Spring,意味有着非常灵活的扩展性。同时Mule ESB不仅仅是一个ESB,它也是流行的微服务体系中的一部分。这个系列我们着重介绍它的ESB功能,后续我们再着重介绍它的API管理等功能。

2. Mule ESB社区版和企业版

和很多开源软件一样,Mule ESB分成两个版本,社区版和企业版。其中社区版是免费使用的。而企业版则需要付费订阅使用,功能更强大。如果企业预算充足,则可以选择企业版。或者使用Mule ESB社区版,在社区版基础上做扩展,在有技术支持的情况下,同样可以收到良好的效果。

关于社区版和企业版的主要区别,可以参照下表。如何选择可以参考具体的业务场景和企业情况。Anyway,由于Mule ESB是开源的,我们在社区版上可以有很多的灵活扩展。

3. Mule ESB常用场景

我们来说一下Mule ESB的常见应用场景,可以更好的理解Mule ESB到底可以帮助我们解决什么问题。

  1. 旧系统改造,开放系统的服务能力。举个例子,我们有一个电商系统,需要调用SAP ERP的订单接口来创建订单。这个时候就需要将SAP的订单服务暴露成我们流行的Rest Service接口,以方便电商系统调用。当然电商系统可以直接使用SAP的JCO包来调用SAP的BAPI Function,但显然暴露一个通用的Rest Service更易于调用。使用Mule ESB实现如下:

  2. 系统集成。举个例子,很多系统之间数据交互可能还是用FTP目录。尤其是企业跟企业之间的数据交互,比如,A企业丢一个EDI 文件到B企业的FTP目录,然后B企业会从FTP目录下载解析并放置到数据库。这个场景用Mule ESB实现就很方便。

  3. ETL。市面上有很多开源的ETL软件,其实Mule ESB也有ETL的功能,通过Flow设定ETL的数据转换和数据流向。下图就演示了Mule的ETL和数据分发功能。

4. Mule ESB软件安装

用一个相对宽泛的标准来划分,Mule ESB软件可以分成两部分。

一部分是客户端,也就是基于Eclipse的Anypoint Studio,客户端就是用来开发集成应用的,通常面向的用户就是我们的开发人员。由于是基于Eclipse环境,所以Java开发人员会很熟悉,同时Anypoint Studio也可以集成Git,SVN,Maven,Junit,Jenkins等一系列生态工具。

当然作为其他语言的开发人员也不用担心,Anypoint Studio是一个可视化的拖拽的开发环境,大部分的工作只需要使用鼠标拖拽组件,配置属性即可。

还要一部分是服务端,也就是Mule Runtime,也可以称作Container,容器,注意不要跟Docker的概念混淆。这里的Container指的是Java Container,你可以大概想象成Tomcat类似的东西。客户端开发的应用就部署运行在Mule Runtime中。

需要注意的是,Mule Runtime是一个独立的Container,只依赖JDK,并不依赖其他第三方的容器。服务器中只需要安装JDK和Mule Runtime,即可运行Mule应用。还有一种不太常见的做法,就是把Mule App跑在第三方的容器里(比如Tomcat等),通过对容器的扩展来支持Mule App。不过我们不推荐这种做法,还是推荐使用独立的Mule Runtime,也就是官方说的Standalone版本。

客户端安装

Anypoint Studio是基于Eclipse构建的,你可以在这里下载到(Windows 64BitMac 64Bit)。请根据你的客户端的操作系统选择对应的版本。我们只要在Windows或者Mac电脑上安装好JDK8之后,解压缩Zip包,双击即可打开。打开的界面如下:

由于Anypoint Studio默认只内嵌了Mule ESB企业版运行时,如果你想使用社区版的话,我们还需要安装Mule ESB社区版运行时。为什么客户端也需要Runtime?这很容易理解,我们开发调试都需要使用Runtime,难道你编写代码后,不运行和调试吗-:)

安装社区版运行时,可以使用下列步骤。

  1. 点击Help/Install New Software...菜单

  2. 在Work with下拉框中选择Mule Runtimes for Anypoint Studio

  3. 选中Mule ESB Server Runtime 3.9.0 CE,CE就是Community Edition,社区版的意思。然后点击Next一直到完成。

服务端安装

服务端不区分操作系统,你可以从这里下载到3.9.0版本的社区版Runtime。Mule ESB Runtime可以运行在Windows,Linux,Mac等操作系统上,我们推荐在生产环境使用Linux部署Mule ESB Runtime。服务端的安装也很简单,只要在服务器上安装好JDK8之后,解压缩Runtime即可。

5. 第一个Mule ESB应用- Hello world

我们学习新的语言和框架都会使用经典的Hello world程序,这里也不例外。我们要做的就是,使用Mule ESB建立一个HTTP服务,当用户访问HTTP端口后,返回Hello world。开发步骤很简单:

  1. 点击File/New/Mule Project,新建Mule工程,这里选择使用CE版,也就是社区版,然后一步步Next直到完成。

  2. 拖入HTTP组件到空白的画布中。

  3. 选择画布上的Http组件,在属性页面新增Connector Configuration,在弹出窗口设定侦听的端口,注意不要和你本机的端口冲突。

  4. 拖入Set Payload组件,在属性页面,设定Value值,Hello word。

  5. 在工程项目上右击弹出菜单,Run As/Mule Application。稍等片刻,Console窗口会出现"Mule is up and kicking",表示Mule已经开始工作了!

  6. 使用Postman访问HTTP端口,返回Hello world,Mule。恭喜你,你是一个Mule开发者了 -:)

使用Mule ESB上手非常简单,我们后续会介绍更多的组件,比如你需要从数据库获取数据,那么就使用Database,还有更多组件等待挖掘。

6. 部署Mule ESB应用

我们已经在客户端开发完成了Hello world,也顺利跑起来了。但是如何部署到服务端呢。和常见的Java开发一样,我们也需要打包应用。这里我们用的是普通工程,我们通过一个Export操作,即可导出Mule App(当然Mule App也支持Maven工程,可以通过Maven打包)。在工程项目上右击弹出菜单,Export...,然后在对话框中选择Anypoint Studio Project to Mule Deployable Archive。注意这里不要选中Attach project sources。

将导出的Zip包放入到Mule Runtime的apps目录下,然后启动Mule Runtime。如果是Linux或者mac,那么在Mule Runtime的bin目录下执行./mule启动命令。如果是Windows,双击执行bin目录mule.bat即可启动。

然后使用Postman访问服务器,你会得到和Studio一样的效果。

本文同步发文于EnjoyingSoft BlogsCSDN简书

访问EnjoyingSoft 网站,获取更多Mule ESB 社区版 实施帮助。

欢迎转载,但必须保留原文和此段声明,且在文章页面明显位置给出原文链接,否则保留追究法律责任的权利。

EnjoyingSoft之Mule ESB开发教程第一篇:初识Mule ESB的更多相关文章

  1. EnjoyingSoft之Mule ESB开发教程第二篇:Mule ESB基本概念

    目录 1. 使用Anypoint Studio开发 2. Mule ESB Application Structure - Mule ESB应用程序结构 3. Mule ESB Application ...

  2. EnjoyingSoft之Mule ESB开发教程系列第五篇:控制消息的流向-数据路由

    目录 1. 使用场景 2. 基于消息头的路由 2.1 使用JSON提交订单的消息 2.2 使用XML提交订单的消息 2.3 使用Choice组件判断订单格式 3. 基于消息内容的路由 4. 其他控制流 ...

  3. EnjoyingSoft之Mule ESB开发教程第三篇:Mule message structure - Mule message结构

    目录 1. 探索Mule Message结构 2. Mule Message的Payload 3. Mule Message的Property 4. Mule Message的Attachment 5 ...

  4. EnjoyingSoft之Mule ESB开发教程第四篇:Mule Expression Language - MEL表达式

    目录 1. MEL的优势 2. MEL的使用场景 3. MEL的示例 4. MEL的上下文对象 5. MEL的Variable 6. MEL访问属性 7. MEL操作符 本篇主要介绍Mule表达式语言 ...

  5. EnjoyingSoft之Mule ESB开发教程第六篇:Data Transform - 数据转换

    目录 1. 数据转换概念 2. 数据智能感知 - DataSense 3. 简单数据转换组件 3.1 Object to JSON 3.2 JSON to XML 3.3 JSON to Object ...

  6. .Net魔法堂:史上最全的ActiveX开发教程——发布篇

    一. 前言 接着上一篇<.Net魔法堂:史上最全的ActiveX开发教程——开发篇>,本篇讲述如何发布我们的ActiveX. 二.废话少讲,马上看步骤! 1. 打包  C#开发的Activ ...

  7. Winform常用开发模式第一篇

    Winform常用开发模式第一篇 上一篇博客最后我提到“异步编程模型”(APM),之后本来打算整理一下这方面的材料然后总结一下写篇文章与诸位分享,后来在整理的过程中不断的延伸不断地扩展,发现完全偏离了 ...

  8. (转) 史上最简单的 SpringCloud 教程 | 第一篇: 服务的注册与发现(Eureka)

    一.spring cloud简介 spring cloud 为开发人员提供了快速构建分布式系统的一些工具,包括配置管理.服务发现.断路器.路由.微代理.事件总线.全局锁.决策竞选.分布式会话等等.它运 ...

  9. spring cloud系列教程第一篇-介绍

    spring cloud系列教程第一篇-介绍 前言: 现在Java招聘中最常见的是会微服务开发,微服务已经在国内火了几年了,而且也成了趋势了.那么,微服务只是指spring boot吗?当然不是了,微 ...

随机推荐

  1. 增加收入的 6 种方式(很多公司的模型是:一份时间卖多次。比如网易、腾讯。个人赚取收入的本质是:出售时间)good

    个人赚取收入的本质是:出售时间.从这个角度出发,下面的公式可以描述个人收入: 个人收入 = 每天可售时间数量 * 单位时间价格 * 单位时间出售次数 在这个公式里,有三个要素: 每天可出售的时间数量 ...

  2. volatile变量理解 via《Java并发编程实战》

    第3章:对象的共享 volatile关键字的理解 volatile变量,用来确保将变量的更行操作通知到其他线程.当变量申明为volatile类型后,编译器与运行时都会注意带这个变量时共享的,因此不会将 ...

  3. Redaht7/Oracle Linux7 + ORA11g : ohasd fails to start(Doc ID 1959008.1)

    APPLIES TO: Oracle Database - Standard Edition - Version 11.2.0.4 to 12.1.0.1 [Release 11.2 to 12.1] ...

  4. 企业级架构 MVVM 模式指南 (WPF 和 Silverlight 实现) 译(2)

    本书包含的章节内容 第一章:表现模式,以一个例子呈献给读者表现模式的发展历程,我们会用包括MVC和MVP在内的各种方式实现一个收费项目的例子.沿此方向,我们会发现每一种模式的问题所在,这也是触发设计模 ...

  5. 三个臭皮匠,顶上一个诸葛亮——在Google Ideathon上Design Thinking分享

    4月26日很荣幸的被邀请参加Google Ideathon做Design Thinking的分享. 这次主要分享了Design Thinking的基本方法流程,以及在真实项目的运用.现在整理一下当时选 ...

  6. SpringCloud微服务架构升级总结

    一.背景 1.1 应用系统的架构历史 1.2 什么是微服务? 起源:微服务的概念源于 2014 年 3 月 Martin Fowler 所写的一篇文章“Microservices”.文中内容提到:微服 ...

  7. 【Web前端Talk】React-loadable 进行代码分割的基本使用

    随着项目功能的扩充.版本迭代,我们与Webpack捆绑起来的的项目越来越大,大到开始影响加载速度了.这时我们就该考虑如何对代码进行拆分了. 这次我们一起学习一下如何对React项目中的代码进行Code ...

  8. java集合框架collection(6)继承结构图

    根据<java编程思想>里面的说法,java集合又叫容器,按照单槽和双槽分为两类,Collection和Map,这两个都是接口. 一.Collection Collection下面又分了三 ...

  9. 查看linux系统时间和时区

    参考地址:http://lidao.blog.51cto.com/ 一.使用date命令查看系统时间 [root@benbang ~]# date -R Tue, 01 Aug 2017 15:43: ...

  10. selenium2 python 自动化测试实战

    自动化测试,一个现在被炒的火热的词:各大公司都在嚷嚷着要上自动化测试的项目,都在招聘各种自动化测试人员…非常荣幸的受作者邀请来帮忙写这个序,诚惶诚恐,何德何能?不记得何时开始认识的作者了.当初只是作为 ...