/lmq

消息队列中间件内存版

Primary LanguageJava

一个简易的基于服务端内存的MQ : LMQ

需要的依赖

基于https://github.com/jianliu/lsf 的netty rpc基础代码 需下载https://github.com/jianliu/lsf ִ后打包 mvn install 得到

        <dependency>
            <groupId>com.liuj</groupId>
            <artifactId>lsf</artifactId>
            <version>1.0-SNAPSHOT</version>
        </dependency>

使用了spring命名空间

       消费端启动入口com.liuj.lmq.spring.ConsumerMain
       生产端启动入口com.liuj.lmq.spring.ProduceMain

MQ服务中心端,负责接收和分发消息

server配置中心负责接收生产者推送的数据,然后分发给消费者,server端在内存中记录数据,server启动无spring配置,启动入口为java main方法

       com.liuj.lmq.server.MQServer

生产者端 producer

生产者配置简单,多个生产者还未分离出一个相同的client负责传输数据到server

    <!--server端地址-->
    <lmq:server id="server" index="127.0.0.1" port="2222"/>

    <!--生产者对象-->
    <lmq:producer id="producer" topic="b" server="server"/>

消费端,负责发送消息 consumer

每个消费者都会有一个自己的线程池来处理消息,基于spring的配置

    <!--server端地址-->
    <lmq:server id="server" index="127.0.0.1" port="2222"/>

    <!--多个consumer共享一个client,它负责和server端交流-->
    <lmq:consumerClient id="consumerClient" server="server"/>

    <!--消息监听器-->
    <bean id="messageListener" class="com.liuj.lmq.client.DefaultMessageListener"/>

    <!--消费者实例-->
    <lmq:consumer id="defaultConsumer" topic="b" listener="messageListener" transport="consumerClient"
                  corePoolSize="1" maxPoolSize="5"/>