rabbitMq解析
import java.io.InputStream;
import java.net.HttpURLConnection;
import java.net.URL;
import java.util.ArrayList;
import java.util.List;
import java.util.Scanner; import net.sf.json.JSONArray;
import net.sf.json.JSONObject; import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional; import com.yunda.app.entity.vo.MessageQueue;
import com.yunda.app.entity.vo.Page;
import com.yunda.app.util.StaticVar; @Service(value = "messageQueueService")
@Transactional
public class MessageQueueServiceImpl implements MessageQueueService {
private Scanner scanner; @Override
public Page pageQuery(MessageQueue messageQueue) {
Page page = new Page();
try {
StringBuilder ipText = new StringBuilder();
String url = StaticVar.RABBITMQ_URL;
// 用户名密码部分
String username = StaticVar.RABBITMQ_USERNAME;
String password = StaticVar.RABBITMQ_PASSWORD;
String input = username + ":" + password;
String encoding = new String((new sun.misc.BASE64Encoder()).encode(input.getBytes()));
URL myURL = new URL(url);
HttpURLConnection conn = (HttpURLConnection) myURL.openConnection();
conn.setConnectTimeout(6 * 1000);
conn.setReadTimeout(6 * 1000);
conn.setRequestProperty("Authorization", "Basic " + encoding);
//如果连接成功,获得返回字符串
if (conn.getResponseCode() == 200) {
InputStream inputStream = conn.getInputStream();
scanner = new Scanner(inputStream, "utf-8");
while (scanner.hasNext()) {
ipText.append(scanner.next());
}
if (inputStream != null) {
inputStream.close();
}
conn.disconnect();
JSONArray jsonArray = JSONArray.fromObject(ipText.toString());
List<MessageQueue> mqList = new ArrayList<MessageQueue>();
int pageNo = messageQueue.getPageNo();
int pageSize = messageQueue.getPageSize();
//如果json有子项,说明有消息队列
if (jsonArray != null && jsonArray.size() > 0) {
String messageQueueName = messageQueue.getName();
//不是搜索某个消息队列
if (messageQueueName == null) {
//分页选取消息队列
for (int i = (pageNo - 1) * pageSize; i < pageNo
* pageSize; i++) {
if (i == jsonArray.size()) {
break;
}
MessageQueue mq = new MessageQueue();
JSONObject jsonobject = jsonArray.getJSONObject(i);
//获取消息队列name等字段
mq.setName(jsonobject.getString("name"));
mq.setMessagesReady(jsonobject
.getInt("messages_ready"));
mq.setMessagesUnacknowledged(jsonobject
.getInt("messages_unacknowledged"));
mq.setMessages(jsonobject.getInt("messages"));
mq.setConsumers(jsonobject.getInt("consumers"));
mq.setState(jsonobject.getString("state"));
mqList.add(mq);
}
if (mqList.size() > 0) {
page.setTotal(jsonArray.size());
page.setRows(mqList);
}
} else {//是搜索某个消息队列
MessageQueue mq = new MessageQueue();
for (int i = 0; i < jsonArray.size(); i++) {
JSONObject jsonobject = jsonArray.getJSONObject(i);
//获取消息队列name字段,判断是否和搜索队列名称相同
String jsonobjectName=jsonobject.getString("name");
if (jsonobjectName.equals(messageQueueName)) {
mq.setName(messageQueueName);
mq.setMessagesReady(jsonobject
.getInt("messages_ready"));
mq.setMessagesUnacknowledged(jsonobject
.getInt("messages_unacknowledged"));
mq.setMessages(jsonobject.getInt("messages"));
mq.setConsumers(jsonobject.getInt("consumers"));
mq.setState(jsonobject.getString("state"));
mqList.add(mq);
break;
}
}
if (mqList.size() > 0) {
page.setTotal(1);
page.setRows(mqList);
}
} } }
} catch (Exception e) {
e.printStackTrace();
}
return page;
}
}
public class MessageQueue extends PageQueryParams{
//队列名称
private String name;
//已准备好消息数
private int messagesReady;
//未应答消息数
private int messagesUnacknowledged;
//队列中消息总数
private int messages;
//消费者
private int consumers;
//队列状态
private String state;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getMessagesReady() {
return messagesReady;
}
public void setMessagesReady(int messagesReady) {
this.messagesReady = messagesReady;
}
public int getMessagesUnacknowledged() {
return messagesUnacknowledged;
}
public void setMessagesUnacknowledged(int messagesUnacknowledged) {
this.messagesUnacknowledged = messagesUnacknowledged;
}
public int getMessages() {
return messages;
}
public void setMessages(int messages) {
this.messages = messages;
}
public int getConsumers() {
return consumers;
}
public void setConsumers(int consumers) {
this.consumers = consumers;
}
public String getState() {
return state;
}
public void setState(String state) {
this.state = state;
}
}
import com.yunda.app.util.StaticVar;
public class PageQueryParams {
/** 分页查询的页号(前台视图页面传入) */
protected int pageNo;
/** 分页查询数据时,每页显示的记录数(前台视图页面传入) */
protected int pageSize;
/** 总记录数(由系统查询数据库后设置,无需过问) */
protected long total;
/** 本次查询记录的开始位置(由系统查询数据库计数后设置,无需过问) */
protected long start;
/**排序字段名称**/
protected String sortName;
/**排序类型**/
protected String sortOrder;
/**
* 获取实例
*
* @param pageNo
* @param PageSize
* @return
*/
public static PageQueryParams getInstance(int pageNo, int pageSize) {
PageQueryParams p = new PageQueryParams();
p.setPageNo(pageNo);
p.setPageSize(pageSize);
return p;
}
public int getPageNo() {
//如果页号小于等于0,则修正为1
if (pageNo <= 0) pageNo = 1;
return pageNo;
}
public void setPageNo(int pageNo) {
this.pageNo = pageNo;
}
public int getPageSize() {
return pageSize;
}
public void setPageSize(int pageSize) {
this.pageSize = pageSize;
}
public long getTotal() {
return total;
}
public void setTotal(long total) {
this.total = total;
}
public long getStart() {
return start;
}
public void setStart(long start) {
this.start = start;
}
/**
* 设置页号
* 提供该方法的目的是便于使用spring的自动参数注入功能
*
* @param page
*/
public void setPage(int page) {
this.pageNo = page <=0 ? StaticVar.DEFAULT_PAGE_NO : page;
}
/**
* 设置每页显示的记录数
* 提供该方法的目的是便于使用spring的自动参数注入功能
*
* @param rows
*/
public void setRows(int rows) {
this.pageSize = rows <=0 ? StaticVar.DEFAULT_PAGE_SIZE : rows;
}
}
rabbitMq解析的更多相关文章
- 消息队列1:RabbitMQ解析并基于Springboot实战
RabbitMQ简介 AMQP:Advanced Message Queue,高级消息队列协议.它是应用层协议的一个开放标准,为面向消息的中间件设计,基于此协议的客户端与消息中间件可传递消息,并不受产 ...
- 别以为真懂Openstack: 虚拟机创建的50个步骤和100个知识点(2)
二.nova-api 步骤3:nova-api接收请求 nova-api接收请求,也不是随便怎么来都接收的,而是需要设定rate limits,默认的实现是在ratelimit的middleware里 ...
- 零基础学习openstack【完整中级篇】及openstack资源汇总
1.你是如何学习openstack的?2.你对openstack的组件了解多少?3.你认为openstack该如何学习? 一直想写关于openstack的方面的内容,今天终于整理完成.算是完成一桩心事 ...
- 简单易用的.NET免费开源RabbitMQ操作组件EasyNetQ解析
对于目前大多的.NET项目,其实使用的技术栈都是差不多,估计现在很少用控件开发项目的了,毕竟一大堆问题.对.NET的项目,目前比较适合的架构ASP.NET MVC,ASP.NET WebAPI,ORM ...
- rabbitmq重装之后无法加入原有cluster的bug解析
背景: 一台controller node,一台compute1节点 两台机器的host文件均已经进行hostname解析 两节点本已经加入了同一rabbitmq cluster 但controlle ...
- RabbitMQ 端口号解析
转自:https://www.cnblogs.com/liuxingke/articles/9889517.html 端口号解析 12345 - 4369 (epmd), 25672 (Erlang ...
- 探索解析微服务下的RabbitMQ
概览 本文主要介绍如何使用RabbitMQ消息代理来实现分布式系统之间的通信,从而促进微服务的松耦合. RabbitMQ,也被称为开源消息代理,它支持多种消息协议,并且可以部署在分布式系统上.它轻量级 ...
- rabbitMQ消息队列 – Message方法解析
消息的创建由AMQPMessage对象来创建$message = new AMQPMessage("消息内容");是不是很简单. 后边是一个数组.可以对消息进行一些特殊配置$mes ...
- RabbitMQ安装、集群搭建、概念解析
RabbitMQ安装.集群搭建.概念解析 基本概念 为什么会产生MQ 1.解耦:采用异步方式实现业务需求达到解耦的目的. 2.缓冲流量,削峰填谷: 问:为什么会有流量冲击? 答:采用"直接调 ...
随机推荐
- bzoj 4261: 建设游乐场 费用流
题目 现在有一大块土地,可以看成N*M的方格.在这块土地上,有些格子内是崎岖的山地,无法建造任何东西:其他格子都是平原.现在打算在这块土地上建设一个游乐园.游乐园由若干条闭合的过山车轨道组成,每个平原 ...
- bzoj 3754: Tree之最小方差树 模拟退火+随机三分
题目大意: 求最小方差生成树.N<=100,M<=2000,Ci<=100 题解: 首先我们知道这么一个东西: 一些数和另一个数的差的平方之和的最小值在这个数是这些数的平均值时取得 ...
- Java中Calendar常用方法总结
//获取当前时刻yyyy-MM-dd HH:mm:ss Calendar calendar = Calendar.getInstance(); SimpleDateFormat sdf = new S ...
- Windows 7下Git SSH 创建Key的步骤
1.首先你要安装Git工具 下载地址:https://git-scm.com/downloads 2.右键鼠标,选中 “Git Bash here”,当然你也可以在windows的 “开始”---&g ...
- 第 五 课 golang语言变量
1 变量三种声明: (第一种的var和类型都是多余: 第二种最简洁,但是第二种只能用在函数中,不能是全局变量的声明) 第一种: var v_name v_type(注意顺序) v_nam ...
- SpringMvc之参数绑定注解详解之二
2 consumes.produces 示例 cousumes的样例: 1 @Controller 2 @RequestMapping(value = "/pets", met ...
- pycharm ubuntu安装
https://www.cnblogs.com/iamjqy/p/7000874.html
- R: 导入 csv 文件,导出到csv文件,;绘图后导出为图片、pdf等
################################################### 问题:导入 csv 文件 如何从csv文件中导入数据,?参数怎么设置?常用参数模板是啥? 解决方 ...
- 阶段3-团队合作\项目-网络安全传输系统\sprint1-传输子系统设计\第3课-加密传输优化
对之前的传输系统进行加密,使之成为加密的网络传输系统 客户端编程模型 通过以上模型对传统的TCP传输模型进行优化 首先完成初始化工作,它是要在创建socket之前完成 主要是以上四个函数的实现,那么这 ...
- ubuntu下apache2的cgi-bin中以root权限运行程序
一,安装apache2 sudo apt-get install apache2 二.配置cgi-bin sudo chmod 777 /var/www/html sudo vim /etc/apac ...