java-ActiveMQ
ActiveMQ安装
下载 activeMQ jar包。(https://activemq.apache.org/download.html
)
1、直接运行
2、在服务里运行(如果要安装服务,点击InstallService.bat ,安装服务后,可以再服务控制台启动mq)
进入管理后台进行测试:http://127.0.0.1:8161,用户名、密码一般为admin:admin
例:
接收端:
@Component //申明为spring组件
public class GetSpeechRecognition_XF implements MessageListener{
// 静态初使化当前类
public static GetSpeechRecognition_XF getSpeechRecognitionInfo;
//注解@PostConstruct,这样方法就会在Bean初始化之后被Spring容器执行
@PostConstruct
public void init() {
getSpeechRecognitionInfo = this;
} private static final Logger logger = Logger.getLogger(GetSpeechRecognition_XF.class);
private String ipAndPortXF = SysConfigItemValue.getValue("IpAndPortXF");//监听地址
private String courtIdXF = SysConfigItemValue.getValue("CourtIdXF");//ID
private static MessageConsumer consumer = null;
private static Connection connection = null;
private static Destination destination = null;
private static Session session = null;
private static ConnectionFactory connectionFactory = null;
public static String textMessage = "";
/**
* 启动监听
*/
public void reciveXF() {
try {
//连接工厂(连接工厂,JMS 用它创建连接)
connectionFactory = new ActiveMQConnectionFactory(
ActiveMQConnection.DEFAULT_USER,
ActiveMQConnection.DEFAULT_PASSWORD,
ipAndPortXF //"tcp://213.138.160.57:61616"
);
//构造从工厂连接对象(JMS 客户端到JMS Provider 的连接)
connection = connectionFactory.createConnection();
connection.start();
//获取操作连接(一个发送或接收消息的线程)
session = connection.createSession(Boolean.FALSE, Session.AUTO_ACKNOWLEDGE);
//获取session,发布订阅的Topic方式(消息的目的地;消息发送给谁.)
destination = session.createTopic(courtIdXF);//session.createQueue("hzzy01");
//(消费者,消息接收者)
consumer = session.createConsumer(destination);
// 开始监听
consumer.setMessageListener(this);//(异步接收)
} catch (JMSException e) {
e.printStackTrace();
logger.error("reciveXF(启动对讯飞语音识别监听)异常:"+e.getMessage());
}finally { }
} public void recive()
{
try {
if (connection == null) {
reciveXF();
}
} catch (Exception e) {
e.printStackTrace();
logger.error("recive(监听)异常:"+e.getMessage());
}
} /**
* 异步接收(进行MessageListener监听)
*/
@Override
public void onMessage(Message arg0) {
try {
if(arg0 instanceof TextMessage)
{
TextMessage txtMsg = (TextMessage) arg0;
String txtContent = txtMsg.getText();
JSONObject jsonObject = JSONObject.parseObject(txtContent);
String text = JSONObject.parseObject(jsonObject.getString("messageMap")).getString("text");
String pgs = JSONObject.parseObject(jsonObject.getString("messageMap")).getString("pgs");//讯飞校验后的语音
if (text != null && !text.equals("") && pgs.equals("1")) {
ConfWebSocketService.sendMessage(text, "2");//向页面发送消息
}
logger.debug("讯飞返回消息:"+txtContent);
}
} catch (Exception e) {
logger.error("onMessage(讯飞语音识别)异常:"+e.getMessage());
e.printStackTrace();
}
}
}
发送端:
@Component //申明为spring组件
public class GetSpeechRecognition_XF2_Send {private static final Logger logger = Logger.getLogger(GetSpeechRecognition_XF2_Send.class);
private static final int SEND_NUMBER = 5;
private String systemId = SysConfigItemValue.getValue("SystemIdYJ");//系统编号 public void sendXF() {
ConnectionFactory connectionFactory; // ConnectionFactory--连接工厂,JMS用它创建连接
// Provider 的连接
Connection connection = null; // Connection :JMS 客户端到JMS
Session session; // Session: 一个发送或接收消息的线程
Destination destination; // Destination :消息的目的地;消息发送给谁.
MessageProducer producer; // MessageProducer:消息发送者
try {
// 构造ConnectionFactory实例对象,此处采用ActiveMq的实现jar
//connectionFactory = new ActiveMQConnectionFactory("tcp://localhost:61616");
connectionFactory = new ActiveMQConnectionFactory(ActiveMQConnection.DEFAULT_USER,
ActiveMQConnection.DEFAULT_PASSWORD, "tcp://127.0.0.1:61616");
// 构造从工厂得到连接对象
connection = connectionFactory.createConnection();
// 启动
connection.start();
// 获取操作连接
session = connection.createSession(Boolean.TRUE, Session.AUTO_ACKNOWLEDGE);
// 获取session注意参数值xingbo.xu-queue是一个服务器的queue,须在在ActiveMq的console配置
destination = session.createTopic("hzzy01");
// 得到消息生成者【发送者】
producer = session.createProducer(destination);
// 设置不持久化,此处学习,实际根据项目决定
producer.setDeliveryMode(DeliveryMode.NON_PERSISTENT);
// 构造消息,此处写死,项目就是参数,或者方法获取
sendMessage(session, producer);
//session.commit();
} catch (Exception e) {
e.printStackTrace();
} finally {
try {
if (null != connection)
connection.close();
} catch (Throwable ignore) {
}
} } public static void sendMessage(Session session, MessageProducer producer) throws Exception {
//for (int i = 1; i <= SEND_NUMBER; i++) {
TextMessage message = session.createTextMessage("ActiveMq 发送的消息" + 1);
// 发送消息到目的地方
System.out.println("发送消息:" + "ActiveMq 发送的消息" + 1);
producer.send(message);
//提交消息
session.commit();
Thread.sleep(500);
//}
}
}
java-ActiveMQ的更多相关文章
- Java ActiveMQ 讲解(一)理解JMS 和 ActiveMQ基本使用(转)
转自:http://www.cnblogs.com/luochengqiuse/p/4678020.html?utm_source=tuicool&utm_medium=referral 最近 ...
- java activemq初体验
1.下载安装ActiveMQ ActiveMQ官网下载地址:http://activemq.apache.org/download.html ActiveMQ 提供了Windows 和Linux.Un ...
- Java ActiveMQ 讲解(一)理解JMS 和 ActiveMQ基本使用
最近的项目中用到了mq,之前自己一直在码农一样的照葫芦画瓢.最近几天研究了下,把自己所有看下来的文档和了解总结一下. 一. 认识JMS 1.概述 对于JMS,百度百科,是这样介绍的:JMS即Java消 ...
- Java ActiveMQ队列模式案例
创建Eclipse项目并运行 创建java project:ActiveMQ-5.14,新建lib文件夹 打开apache-activemq-5.14.0-bin\apache-activemq-5. ...
- Java ActiveMQ 讲解(二)Spring ActiveMQ整合+注解消息监听
对于ActiveMQ消息的发送,原声的api操作繁琐,而且如果不进行二次封装,打开关闭会话以及各种创建操作也是够够的了.那么,Spring提供了一个很方便的去收发消息的框架,spring jms.整合 ...
- Java ActiveMQ 示例
所需引入Jar包: jms-1.1.jar activemq-all-5.15.0.jar 生产者 package com.mousewheel.demo; import javax.jms.Conn ...
- ActiveMQ在Linux中的安装
1.下载相关activeMQ安装包 下载路径:http://activemq.apache.org/download.html 下载最新安装包,选择Linux版进行下载 2.解压重命名 (1)解压: ...
- JDK Tools - jinfo: Java 配置信息工具
jinfo 是 JDK 自带的配置信息工具,可以查看.设置 Java 进程的参数配置. 命令格式 jinfo [ option ] pidjinfo [ option ] executable cor ...
- ActiveMQ 基于zookeeper的主从(levelDB Master/Slave)搭建以及Spring-boot下使用
0:说明 ActiveMQ 5.9.0新推出的主从实现,基于zookeeper来选举出一个master,其他节点自动作为slave实时同步消息.因为有实时同步数据的slave的存在,master不用担 ...
- 01.ActiveMQ安装部署
1.下载安装ActiveMQ 下载地址:http://activemq.apache.org/download-archives.html选择相应的版本,笔者选择的是:apache-activem ...
随机推荐
- 18-09-27 pandas 学习02
如何系统的学习python 中有关数据分析和挖掘相关的库?什么是系统的学习?系统的学习就是一个先搭建只是框架体系,然后不断填充知识看,不断更新迭代的过程. Pandas,numpy,scipy,mat ...
- MySQL:存储过程和函数
存储过程和函数 一.创建存储过程和函数 1.创建存储过程 语法: CREATE PROCEDURE sp_name ([proc_parameter[,...]]) [characteristic . ...
- 框架:初识Spring
Spring篇 第一章.Spring简介 一.Spring的体系结构 1.介绍 Spring有20多个的模块,这些模块分布与核心容器(Core Container).数据访问/集成(Data Acce ...
- 再谈kbmMW垃圾回收
很早就写了关于kbmMW Server如何实现的垃圾回收,但最近一段时间还是为此遇到问题,实现的Server不能稳定运行,发生问题后不响应客户端的查询请求,在客户端得到服务端返回地址错误信息,只能重启 ...
- Java技术体系
Shell 解释型编程语言(脚本语言都是解释型语言) Shell通过解释器/bin/bash 解释,运行在进程中 Java 编译型解释型语言(先编译再解释) Java通过编译器转换成字节码语言,再用过 ...
- Linux文件和目录常用操作命令(40个)
1.ls(list) [命令作用] 列出文件和目录 [命令语法] ls [选项] [参数] [常用选项] -l 以长格式显示(文件或目录的类型.权限.软硬链接的次数.属主.属组.大小.时间.文件名) ...
- youtube-dl 使用小记
0.官网地址 youtube-dl官网:https://yt-dl.org/项目地址:https://github.com/rg3/youtube-dl 1.文档简略翻译,具体请以官方文档为准 Usa ...
- Mariadb-10.1.22配置项
## These groups are read by MariaDB server.# Use it for options that only the server (but not client ...
- xdoj新生现场赛1269——带有限制条件的bfs 寻找最短路径
bfss是解决最短路径的强大武器 (尝试dfs寻找最短路径 -(7*7)就会爆炸) 例题1 ccf 201604-4 游戏 问题描述 小明在玩一个电脑游戏,游戏在一个n×m的方格图上进行,小明控制 ...
- 20155208徐子涵 2016-2017-2 《Java程序设计》第10周学习总结
#### **教材学习总结**网络编程 网络编程就是在两个或两个以上的设备(例如计算机)之间传输数据.程序员所作的事情就是把数据发送到指定的位置,或者接收到指定的数据,这个就是狭义的网络编程范畴. * ...