`
wangleifire
  • 浏览: 511302 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

主题:设计一个美好的服务器--MINA、CXF、Mule、JBoss/Geronimo

    博客分类:
  • mule
阅读更多

作者:江南白衣 ,原文地址:http://blog.csdn.net/calvinxiu/archive/2007/04/28/1588852.aspx ,版权所有,转载请保留

假如冬夜,一个旅人,要开发一个美好的Java后台服务器。

所谓美好,就是要高性能,千万级的用户;高可靠性,failover虽死犹生;高扩展性,跟周围那帮Tuxedo,IBM MQ,WebService的邻居要好好打交道。这是个毫无个性,几乎每次都一样的需求。

Java的开源世界为那些心里不安的设计师们,准备了MINA 、CXF、Mule 和JBoss/Geronimo。

1、 MINA

一个优秀的NIO框架。ACE式的NIO和线程模型,filter chains机制,IO层与protocol层的分离,设计师们可以依赖着开发高性能的自定义协议TCP/IP服务器。

其他框架:Grizzly ,脱胎于Glassfish 的NIO框架,性能好像比MINA 还好一点。

2、 CXF

前身就是XFire,一个完整的Web Service Framework:

  • HTTP, JMS, and Jabber 的Transports
  • SOAP, REST and Corba的Binding
  • JAXB 2.0、 XML Beans、Castor and JiBX的DataBinding
  • Support  JAX-WS2.0、CORBA,SCA与JBI

可以部署在:

  • Standalone java server
  • Tomcat or Spring-based 的轻量级容器
  • Weblogic、WebSphere、JBoss的J2EE容器
  • ServiceMix,OpenESB的JBI容器
  • Tuscany的SCA容器

设计师们可以学习它眼花缭乱的机制,从一个Stand alone,ad Hoc协议的服务器,开始支持更多更公共的endpoint,也把自己作为一个Module,部署到更大更稳健的服务器之中。

3、 Mule

     作为Enterprise Service Bus (ESB) and Messaging broker,能力就夸张了:

    面对这样一个诱人的ESB方案,看起来比前面的CXF模式更加合适,那如何应用?和业界一样的踌躇。

4、 JBoss  / Geronimo

     地球人都知道这是两个应用服务器,特别在于,它们都有某种良好的插件机制,将EJB Container,Servlet Container,JMS 模块作为Module部署到服务器中,成为服务器的一种能力。

    JBoss的每个Service就是一个MBean,配合一个service描述文件。Geronimo更是著名的以GBean作为底层架构,跑马圈地的 把开源社区的方案集合在repository目录中,玩票式的组成了一个通过J2EE 1.4认证的应用服务器。

    我们自写的服务,可不可以也通过相同的机制,嵌入到JBoss/Geronimo之中,从而直接拥有了应用服务器的其他一切能力,就像把Tomcat建于 JBoss  MicroKernel之上,拥有JBossJTA,JBoss Cache能力的JBoss Web?   Labourey说:“Microkernel 是JBoss 的心脏。现在有许多电讯公司使用Microkernel ,用作其服务器应用软件的基础”看来自己并没有发明创造:(

其他服务器:Glassfish

5.世界的其他角落

  • Tuscany  SCA 的开源实现,IBM与BEA联手贡献。
  • Esper  Event-Driven Application Servers。
  • GridGain  开源网格计算平台,集成Spring,JBoss。

6.小结

    MINA 提供了工具,Mule /JBoss/Geronimo提供了容器, CXF/Mule 提供了模式,而这些都还仅是Java开源社区的冰山一角,回望那个只有ICE和ACE/TAO的孤寂世界.......

二、Summer Task:

1、入门文档

2、阅读代码
        阅读只是为了发掘文档里没有描述的架构与模式,而其实很多模式在代码里都很显眼,来来去去就那几道斧子,所以有了快速略读的可能,而不是Apache源码阅读式的愚公移山,精卫填海。


 

分享到:
评论
1 楼 elvishehai 2009-10-12  
在没有放到jboss的例子啊! 给我一个啊,

相关推荐

    mina-core-2.0.0-M1.jar/mina-example-1.0.5.jar

    mina-core-2.0.0-M1.jar/mina-example-1.0.5.jar/slf4j-jdk14-1.6.1.jar/slf4j-log4j12-1.6.1.jar mina 所用jar

    mina-webpack:Mina单文件组件符合Webpack

    mina-webpack Mina单文件组件符合Webpack开始使用我们建议您开始使用 : npm i -g saosao mina my-appcd my-appnpm start 并查看如何与一起使用包含包装 mina-entry-webpack-plugin wxs加载器 手动安装npm i --save-...

    Apache Mina核心jar包:mina-core-2.0.7

    Apache MINA是 Apache 组织一个较新的项目,它为开发高性能和高可用性的网络应用程序提供了非常便利的框架。 当前发行的 MINA 版本支持基于 Java NIO 技术的 TCP/UDP 应用程序开发、串口通讯程序(只在最新的预览版...

    apache-mina-2.0.4架包及源码各pdf学习教程

    apache-mina-2.0.4 架包 源码 学习教程.apache mina是Apache 组织一个较新的项目,它为开发高性能和高可用性的网络应用程序提供了非常便利的框架。当前发行的 MINA 版本支持基于 Java NIO 技术的 TCP/UDP 应用程序...

    mina-filter-compression-2.0.7.jar

    mina-filter-compression-2.0.7.jar,mina 过滤器jar包,核心包之一

    深入理解Apache_Mina_(1)----_Mina的几个类

    Mina (Multi-threaded Integrated Network Architecture) 是一个高性能且灵活的网络应用程序框架,它支持多种传输协议,如 TCP、UDP 和串口通信。Mina 的设计目标之一就是简化网络编程的复杂性,让开发者能够更专注...

    apache-mina-2.0.16-jar包-代码.zip

    Apache Mina是一个高性能、异步事件驱动的网络应用程序框架,主要设计用于简化开发服务端的高性能网络应用,如TCP/IP和UDP/IP协议的应用。在Java平台上,Mina提供了一个简单一致的API,使得开发者可以专注于业务逻辑...

    mina2.0 含11个jar包

    mina-core-2.0.0-M6.jar mina-example-2.0.0-M6.jar mina-filter-codec-netty-2.0.0-M6.jar mina-filter-compression-2.0.0-M6.jar mina-integration-beans-2.0.0-M6.jar mina-integration-jmx-2.0.0-M6.jar mina-...

    51fec228845349d2b2474b186b749c1b-Java学习资源1

    这些资源涵盖了广泛的Java学习主题,包括基础、框架、高级技术和实战项目,对于想要深入学习Java技术栈的人来说是非常宝贵的。以下是对各个资源的详细说明: 1. **JAVAEE基础部分**:这部分内容通常涵盖Servlet、...

    mina-graphql-proxy:Mina GraphQL的代理服务器

    您可以定义一个以更改代理服务器的行为。 GRAPHQL_HOST主机,graphql在其中启动,默认为localhost GRAPHQL_PORT -graphql开始的端口,默认为3085 GRAPHQL_PATH -graphql服务的路径,默认为graphql GRAPHQL_PROXY_...

    mina-http-2.0.7.jar.zip_mina_mina 获取POST_mina-http_mina-http-2.0

    MINA的核心设计目标是提供一个与传输协议无关的抽象层,使得开发者可以轻松地构建基于TCP/IP、UDP/IP或其他协议的网络应用。在标题中提到的"mina-http-2.0.7.jar",是MINA框架针对HTTP协议的一个实现,特别强调了对...

    apache-mina-2.0.4.rar_apache mina_mina

    Apache Mina是一个高性能、异步事件驱动的网络应用程序框架,用于快速开发可维护的高性能协议服务器和客户端。这个"apache-mina-2.0.4.rar"压缩包包含的是Apache Mina 2.0.4版本的源代码,是深入理解和定制Mina的...

    cat-tinder-frontend-sarah-mina-1:GitHub Classroom创建的cat-tinder-frontend-sarah-mina-1

    复制了“添加现有代码部分”的第一行 $ git remote add origin $ git checkout -b主 $ git添加。 $ git commit -m'初始提交' $ git push origin main 前端安装卡 用笑话和酶进行测试 要在React应用程序中运行...

    Android-基于ApacheMINA进行封装实现AndroidAPP作为服务器客户端进行通讯

    - **Filter Chain**:MINA采用过滤器链的设计模式,允许开发者插入自定义的处理逻辑,每个过滤器对数据进行处理,然后传递给下一个过滤器。 - **Session**:MINA中的Session代表一个网络连接,它包含了与连接相关...

    cxf(jax-ws)+spring+hibernate整合包

    1.1.jar,log4j-1.2.14.jar,mina-core-2.0.7.jar,mssqlserver2.jar,msv-core-2011.1.jar,neethi-3.0.2.jar,oauth-20100527.jar,oauth-provider-20100527.jar,opensaml-2.5.1-1.jar,openws-1.4.2-1.jar,...

    Spring-mybaits-mina整合,可监听多端口

    1:Spring-mybaits-mina三大框架的整合,mina可以使用Spring的数据库数据库连接池,无需额外定义mybaits连接池。 2:mina可以自定义监听一个或者多个端口,可以从数据库中读取

    mina2.0全部jar包

    mina-transport-apr-2.0.7.jar是MINA对Apache Portable Runtime (APR)的支持,APR是一个库,提供了操作系统级别的接口,如socket和线程,可以提升MINA在某些平台上的性能。 mina-integration-jmx-2.0.7.jar提供了...

    mina-master_mina_

    标题中的"mina-master_mina_"可能指的是一个MINA项目或示例的主分支,可能包含了服务器端的核心代码和配置。描述中提到的"mina 服务端的简单应用,直接部署可以使用"表明这个压缩包包含了一个能够快速运行的MINA...

    mina服务器--实现纯文本和非纯文本的加密通讯

    在这个主题中,“mina服务器--实现纯文本和非纯文本的加密通讯”涉及了如何使用MINA来确保数据传输的安全性。 MINA提供了丰富的API和工具,使得开发者可以方便地创建基于TCP和UDP协议的服务器端和客户端应用。在...

Global site tag (gtag.js) - Google Analytics