消息中间件activeMQ初学

消息中间件

  • 简介

    ​ 消息中间件利用高效可靠的消息传递机制进行平台无关的数据交流,并基于数据通信来进行分布式系统的集成。通过提供消息传递和消息排队模型,它可以在分布式环境下扩展进程间的通信。对于消息中间件,常见的角色大致也就有Producer(生产者)、Consumer(消费者)

一丶常见的消息中间件产品

  • ActiveMQ:ActiveMQ 是Apache出品,最流行的,能力强劲的开源消息总线。ActiveMQ 是一个完全支持JMS1.1和J2EE 1.4规范的 JMS Provider实现。
  • RabbitMQ:AMQP协议的领导实现,支持多种场景。淘宝的MySQL集群内部有使用它进行通讯,OpenStack开源云平台的通信组件,最先在金融行业得到运用。
  • ZeroMQ:史上最快的消息队列.
  • **Kafka:**Apache下的一个子项目 。特点:高吞吐,在一台普通的服务器上既可以达到10W/s的吞吐速率;完全的分布式系统。适合处理海量数据。

二丶JMS简介

  • 概念: JMS(JavaMessaging Service)是Java平台上有关面向消息中间件的技术规范,它便于消息系统中的Java应用程序进行消息交换,并且通过提供标准的产生、发送、接收消息的接口简化企业应用的开发。
    • JMS本身只定义了一系列的接口规范,是一种与厂商无关的 API,用来访问消息收发系统。它类似于 JDBC([**java** ](http://lib.csdn.net/base/java)Database Connectivity):这里,JDBC 是可以用来访问许多不同关系[**数据库**](http://lib.csdn.net/base/mysql)的 API,而 JMS 则提供同样与厂商无关的访问方法,以访问消息收发服务。许多厂商目前都支持 JMS,包括 IBM 的 MQSeries、BEA的 Weblogic JMS service和 Progress 的 SonicMQ,这只是几个例子。 JMS 使您能够通过消息收发服务(有时称为消息中介程序或路由器)从一个 JMS 客户机向另一个 JML 客户机发送消息。消息是 JMS 中的一种类型对象,由两部分组成:报头和消息主体。报头由路由信息以及有关该消息的元数据组成。消息主体则携带着应用程序的数据或有效负载。
      
    • ​ JMS 定义了五种不同的消息正文格式,以及调用的消息类型,允许你发送并接收以一些不同形式的数据,提供现有消息格式的一些级别的兼容性。
      • TextMessage–一个字符串对象
      • MapMessage–一套名称-值对
      • ObjectMessage–一个序列化的 Java 对象
      • · BytesMessage--一个字节的数据流
      • · StreamMessage – Java 原始值的数据流
  • jms消息传递类型:
    • 一种是点对点的,即一个生产者和一个消费者一一对应:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-YE7jIPWy-1577967208117)(C:\Users\86132\AppData\Roaming\Typora\typora-user-images\image-20200102201150618.png)]

    • 另一种是发布/ 订阅模式,即一个生产者产生消息并进行发送后,可以由多个消费者进

    行接收。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-alz5cO4M-1577966864376)(C:\Users\86132\AppData\Local\Temp\1576546936172.png)]

三丶ActiveMQ下载与安装

  • 官方网站:http://activemq.apache.org/
  • 安装(linux):
    • 将apache-activemq-5.12.0-bin.tar.gz 上传至服务器
    • 解压此文件 tar zxvf apache-activemq-5.12.0-bin.tar.gz
    • 为apache-activemq-5.12.0目录赋权:chmod 777 apache-activemq-5.12.0
    • 进入apache-activemq-5.12.0\bin目录
    • 赋与执行权限:chmod 755 activemq权限
    • 启动:./activemq start
  • 而后可进入访问,IP+端口号8161可进入管理界面,用户名密码为admin
  • 页面中标签解释:
    • [Number Of Pending Messages] **:**等待消费的消息 这个是当前未出队列的数量。
    • [Number Of Consumers] **:**消费者 这个是消费者端的消费者数量
    • [Messages Enqueued]**:**进入队列的消息 进入队列的总数量,包括出队列的。
    • [Messages Dequeued]**:**出了队列的消息 可以理解为是消费这消费掉的数量。

四丶jms点对点模式的简单使用

  • 依赖的引入:

    	 <dependency>
    		<groupId>org.apache.activemq</groupId>
    		<artifactId>activemq-client</artifactId>
    		<version>5.13.4</version>
    	 </dependency>
    
  • 创建类QueueProducer消息生产者 :

    //1.创建连接工厂
    	ConnectionFactory connectionFactory=new ActiveMQConnectionFactory("tcp://192.168.25.135:61616");
    	//2.获取连接
    	Connection connection = connectionFactory.createConnection();
    	//3.启动连接
    	connection.start();
    	//4.获取session  (参数1:是否启动事务,参数2:消息确认模式)
         //   创建session  的两个参数:
         //   第1个参数 是否使用事务
         //   第2个参数 消息的确认模式
         //   AUTO_ACKNOWLEDGE = 1    自动确认
         //   CLIENT_ACKNOWLEDGE = 2    客户端手动确认   
         //   DUPS_OK_ACKNOWLEDGE = 3    自动批量确认
           // SESSION_TRANSACTED = 0    事务提交并确认	
    	Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);		
    	//5.创建队列对象
    	Queue queue = session.createQueue("test-queue");
    	//6.创建消息生产者
    	MessageProducer producer = session.createProducer(queue);
    	//7.创建消息
    	TextMessage textMessage = session.createTextMessage("欢迎来到神奇的品优购世界");
    	//8.发送消息
    	producer.send(textMessage);
    	//9.关闭资源
    	producer.close();
    	session.close();
    	connection.close();
    
  • 消息消费者 创建类QueueConsumer :

    //1.创建连接工厂
    	ConnectionFactory connectionFactory=new ActiveMQConnectionFactory("tcp://192.168.25.135:61616");
    	//2.获取连接
    	Connection connection = connectionFactory.createConnection();
    	//3.启动连接
    	connection.start();
    	//4.获取session  (参数1:是否启动事务,参数2:消息确认模式)
    	Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
    	//5.创建队列对象
    	Queue queue = session.createQueue("test-queue");
    	//6.创建消息消费
    	MessageConsumer consumer = session.createConsumer(queue);
    	
    	//7.监听消息
    	consumer.setMessageListener(new MessageListener() {
    		public void onMessage(Message message) {
    			TextMessage textMessage=(TextMessage)message;
    			try {
    				System.out.println("接收到消息:"+textMessage.getText());
    			} catch (JMSException e) {
    				// TODO Auto-generated catch block
    				e.printStackTrace();
    			}
    		}
    	});	
    	//8.等待键盘输入,让上方持续监听的措施
    	System.in.read();	
    	//9.关闭资源
    	consumer.close();
    	session.close();
    	connection.close();	
    

    注意: 同时开启2个以上的消费者,再次运行生产者,观察每个消费者控制台的输出,会发现只有一个消费者会接收到消息。

五丶jms发布/订阅模式的简单实用

  • 创建消息生产者 创建类TopicProducer

    //1.创建连接工厂
    	ConnectionFactory connectionFactory=new ActiveMQConnectionFactory("tcp://192.168.25.135:61616");
    	//2.获取连接
    	Connection connection = connectionFactory.createConnection();
    	//3.启动连接
    	connection.start();
    	//4.获取session  (参数1:是否启动事务,参数2:消息确认模式)
    	Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
    	//5.创建主题对象
    	Topic topic = session.createTopic("test-topic");
    	//6.创建消息生产者
    	MessageProducer producer = session.createProducer(topic);
    	//7.创建消息
    	TextMessage textMessage = session.createTextMessage("欢迎来到神奇的品优购世界");
    	//8.发送消息
    	producer.send(textMessage);
    	//9.关闭资源
    	producer.close();
    	session.close();
    	connection.close();
    
  • 创建消息消费者 创建类TopicConsumer

    //1.创建连接工厂  连接端口与界面管理端口不一致
    	ConnectionFactory connectionFactory=new ActiveMQConnectionFactory("tcp://192.168.25.135:61616");
    	//2.获取连接
    	Connection connection = connectionFactory.createConnection();
    	//3.启动连接
    	connection.start();
    	//4.获取session  (参数1:是否启动事务,参数2:消息确认模式)
    	Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
    	//5.创建主题对象
    	//Queue queue = session.createQueue("test-queue");
    	Topic topic = session.createTopic("test-topic");
    	//6.创建消息消费
    	MessageConsumer consumer = session.createConsumer(topic);
    	
    	//7.监听消息
    	consumer.setMessageListener(new MessageListener() {
    		public void onMessage(Message message) {
    			TextMessage textMessage=(TextMessage)message;
    			try {
    				System.out.println("接收到消息:"+textMessage.getText());
    			} catch (JMSException e) {
    				// TODO Auto-generated catch block
    				e.printStackTrace();
    			}
    		}
    	});
    	//8.等待键盘输入
    	System.in.read();
    	//9.关闭资源
    	consumer.close();
    	session.close();
    	connection.close();	
    

    注意: 同时开启2个以上的消费者,再次运行生产者,观察每个消费者控制台的输出,会发现每个消费者会接收到消息

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值