Apache Camel:Mina组件简单介绍

Apache Camel:Mina组件简单介绍

apache camel mina component是camel支持tcp、udp互通的一个组件。利用它你可以实现客户端与多个通讯服务器及多个通讯服务器之间的互通。但是缺省条件下实现不了这个目的,该插件仅仅默认提供了MinaConsumer和MinaProducer,通过配置camel路由可以实现MinaConsumer到MinaProducer的数据传送,但是对于MinaProducer到MinaConsumer的数据传送则没有代码提供,下面对其实现做一些简单介绍:

首先介绍两个概念

1、MinaConsumer,消费者的代表,它的主要作用是接受来自客户端的连接和负责与客户端的数据传输。当然了,方法是活的,你也可以让一个服务器主动连接过来。

2、MinaProducer,生产者的代表,它的主要作用是连接到通讯服务器并与之进行数据交互。当然了,如果一个客户端有侦听功能,你也可以连接过去。

现在我们介绍下代码上的实现

1、首先在MinaEndpoint类里添加一个MinaConsumer集合:

private static final CopyOnWriteArrayList<DefaultConsumer> consumers = new CopyOnWriteArrayList<DefaultConsumer>();

同时添加三个函数

public List<DefaultConsumer> getConsumers() {
        return consumers;
    }

public void addConsumer(DefaultConsumer consumer){
    consumers.add(consumer);
    }
    
    public void removeConsumer(DefaultConsumer consumer){
    consumers.remove(consumer);
    }

2、在MinaConsumer类中doStart()函数里添加如下代码:

endpoint.addConsumer(this);

同时在doStop()函数里添加如下代码:

endpoint.removeConsumer(this);

3、在MinaProducer类的内部类ResponseHandler的messageReceived函数里修改部分代码为如下:

try {

       int size = endpoint.getConsumers().size();
       if (size == 0) {
        LOG.warn("No consumers available on endpoint: "
          + endpoint + " to process " + exchange);
       } else if (size == 1) {

        DefaultConsumer consumer = endpoint.getConsumers()
          .get(0);
        // AsyncProcessor processor =
        // AsyncProcessorTypeConverter.convert(consumer.getProcessor());
        consumer.getProcessor().process(exchange);
       } else if (size > 1) {
               for (DefaultConsumer consumer : endpoint.getConsumers()) {

                     consumer.getProcessor().process(exchange);
               }
       }
      } catch (Exception e) {
       e.printStackTrace();
      }

通过以上三步就可以实现MinaProducer到MinaConsumer的数据传送了,然后通过配置camel路由就可以实现我们上面所说的互通了。

转载于:https://my.oschina.net/u/2332347/blog/637867

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值