ActiveMq消息模式

P2P(点对点)

p2p的过程理解起来更加简单。它好比是两个人打电话,这两个人是独享这一条通信链路的。一方发送消息,另外一方接收,就这么简单。在实际应用中因为有多个用户对使用p2p的链路,它的通信场景如下图所示:

publish-subscribe 发布订阅模式

发布订阅模式有点类似于我们日常生活中订阅报纸。每年到年尾的时候,邮局就会发-本报纸集

合让我们来选择订阅哪一个。在这个表里头列了所有出版发行的报纸,那么对于我们每-一个订阅

者来说,我们可以选择- - 份或者多份报纸。比如北京日报、潇湘晨报等。那么这些个我们订阅的

报纸就相当于发布订阅模式里的topic。有很多个人订阅报纸,也有人可能和我订阅了相同的报

纸。那么在这里相当于我们在同-一个topic 里注册了。对于一份报纸发行方来说,它和所有的订

阅者就构成了一一个1对多的关系。这种关系如下图所示:

public class Publish {

I

private ConnectionFactory factory;

private Connection connection;

private Session session;

private MessageProducer producer;

public Publish(){

try

factory = new ActiveMQConnectionFactory (

//ActiveMQConnection . DEFAULT USER,

//ActiveMQConnection. DEFAULT PASSWORD,

‘’bhz”,”bhz’”

"tcp://localhost:61616");

connection = factory. createConnection ();

connection. start();

session = connection. createsession (false, Session . AUTO ACKNOWLEDGE) ;

producer = session. crea teProducer (nu11) ;

} catch (Exception e) {

e.printstackTrace();

}

public void sendMessage() throws Exception{

Destination destination = session. createTopic("topicI");  //变化的位置

TextMessage textMassge = session. crea teTextMessage ("我是内容");

Producer.send (des tination, textMassge) ;

}

pub1ic static void main (String[] args) throws Exception{

Publish P = new Publish() ;

P. sencMessage ();

}

}

public Consumer () {

this . connectionFactory = new ActiveMQConnectionFactory (

"bhz", //ActiveMQConnectionFac tory. DEFAULT USER,

"bhz",//ActiveMQConnectionFactory. DEFAULT PASSWORD,

"tcp://localhost: 61616");

this. connection = this. connectionFactory. createConnection () ;

this . connection.start() ;

this.session = this. connection. createsession (Boolean . False, Session . AUTO ACKNOWLEDGE) ;

} catch (JMSException e) {

e.printstackTrace () ;

}

public void receiver() {

try {

Destination destination = session. createTopic("topicI");  //变化的位置

consumer = session. crea teConsumer (des tination) ;

consumer. setMessageLis tener (new Listener());

} catch (JMSException e) {

e.printstackTrace() ;

)

}

class Listener implements MessageLi stener {

@override

public void onMessage (Message message) {

try {

TextMessage msg = (TextMessage) messageConsumer.receive();

System. out.printIn (msg );

}

} catch

(JMSException e) {

e .printstackTrace();

}

I

}

}

public static void main (string[]args) {

Consumer c = new Consumer ();

c.receiver();

}

}

  • 8
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

JAVA代码搬运工

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值