上次进行了简单的连接测试。这次主要进行一下小小的补充。利用线程将生产者消费者代码合到一个文件中。
我是将Recv.java(消费者)文件放在一个线程里添加到Send.java(生产者)中。
代码如下:
package MYRABBITMQ;
import com.rabbitmq.client.ConnectionFactory;
import com.rabbitmq.client.ConsumerCancelledException;
import com.rabbitmq.client.QueueingConsumer;
import com.rabbitmq.client.ShutdownSignalException;
import com.rabbitmq.client.Connection; import java.io.IOException;
import java.util.Scanner; import com.rabbitmq.client.Channel;
class RecvThread extends Thread{
RecvThread(String name){
super(name);//调用父类带参数的构造方法
}
public void run(){
final String QUEUE_NAME = "hello";
ConnectionFactory factory = new ConnectionFactory();
factory.setHost("123.206.216.31");
factory.setPort(5672);
factory.setUsername("admin");
factory.setPassword("admin");
// 打开连接和创建频道,与发送端一样
Connection connection = null;
try {
connection = factory.newConnection();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
Channel channel = null;
try {
channel = connection.createChannel();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} // 声明队列,主要为了防止消息接收者先运行此程序,队列还不存在时创建队列。
try {
channel.queueDeclare(QUEUE_NAME, false, false, false, null);
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
// 创建队列消费者 System.out.println(" [*] Waiting for messages. To exit press CTRL+C");
// 指定消费队列
// 指定消费队列
QueueingConsumer consumer = new QueueingConsumer(channel);
try {
channel.basicConsume(QUEUE_NAME, true, consumer);
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
while(true){
QueueingConsumer.Delivery delivery = null;
try {
delivery = consumer.nextDelivery();
} catch (ShutdownSignalException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (ConsumerCancelledException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
String message = new String(delivery.getBody());
System.out.println(" [x] Received '" + message + "'");
} } } public class Send {
private final static String QUEUE_NAME = "hello";
public static void main(String[] args) throws java.io.IOException {
/**
* 创建连接连接到MabbitMQ
*/
// 设置MabbitMQ所在主机ip或者主机名 ConnectionFactory factory = new ConnectionFactory();
factory.setHost("123.206.216.31");
factory.setPort(5672);
System.out.println("input your username:");
Scanner un=new Scanner(System.in);
String username=null;
username=un.next();
System.out.println("input your password::");
Scanner up=new Scanner(System.in);
String userpassword=null;
userpassword=up.nextLine();
factory.setUsername(username);
factory.setPassword(userpassword);
// 创建一个连接
Connection connection = factory.newConnection();
// 创建一个频道
Channel channel = connection.createChannel();
// 指定一个队列
channel.queueDeclare(QUEUE_NAME, false, false, false, null);
// 发送的消息
System.out.println("input what you wanna send:");
Scanner s=new Scanner(System.in);
String message=null;
message=s.nextLine();
// 往队列中发出一条消息
channel.basicPublish("", QUEUE_NAME, null, message.getBytes());
System.out.println(" [x] Sent '" + message + "'");
// 关闭频道和连接
channel.close();
connection.close();
RecvThread rthread= new RecvThread("test1");
rthread.start();
} }
运行结果如下:
另外,这里对于rabbitmq中的典型概念进行一个梳理:
刚刚接触RabbitMQ的时候,可能会被扑面而来的一堆概念搞的有些糊涂,又是 Exchange(交换器)、又是Queue(队列)、又是Routing_Key(路由);还有什么 Connection(连接)、Channel(管道)。而且各个官网的例子当中,有些概念会出现、有些又不会出现,也没有特别的讲清楚,所以我们还是要先把概念和流程搞搞清楚。
既然我们用RabbitMQ来处理消息,那么我们就要清楚这个消息到底是什么。
(例1):从实体的角度,我们可以把消息(Message)看成是个货物:我们从某宝、某东上买的货物,这个货物由厂家生产出来、通过卖家、快递送给我们,其中:货物就是“消息”,厂家就是生产者(publisher)、买家就是消费者(consumer)、某宝等平台就是交换器(Exchange)、物流快递就是队列(queue)。
(例2):从虚拟的角度,我们也可以把消息 看成是个订单,这个时候,我们就是订单(Message)的生产者、而商家就成了订单的消费者,而这个时候的队列就不是快递而是运行在电商平台(Exchange)上的信息流了。
把大象放进冰箱要几步?
答:3步,第一步把冰箱门打开,第二步把大象放进去,第三步把冰箱门关上。那么我们要在电商平台上下一个订单需要哪几步?
第一步:打开电脑
第二步:打开浏览器
第三步:打开某东网站
第四步:选定商品
第五步:选择付款方式(某东支付 or 白条支付 or 某信支付)
第六步:确认付款
第七步:关闭浏览器
第八步:关闭电脑我们把消费的过程和消息队列的生命周期对应一下,会发现有一定相似性
第一步:打开电脑 (连接到指定的RabbitMQ服务器 ,建立connection)
第二步:打开浏览器 (获取信道、即open channel)
第三步:打开某东网站 (声明交换器、即exchange_declare)
第四步:选定商品 (声明队列、即 queue_declare)
第五步:选择付款方式 (把队列和交换器绑定起来、即 queue_bind)
第六步:确认付款 (消费信息、即 basic_consume )
第七步:关闭浏览器 (关闭信道、即 close channel)
第八步:关闭电脑 (关闭连接、即 close connection)
一个完整的消息过程要包含上述八步,但是在打开电脑之后,其实你可以选择的事情有很多:你可以打开不止一个浏览器(channel)、也可以在不同的浏览器里打开很多个电商网站(exchange)、更不用说你在网站上可以任意的选择商品(queue)、以及选择喜欢的支付方式(queue_bind)。也就是说,connection只有一个、但是channel、exchange、exchange_type、queue、routing_key都可以根据一定的规则以及需求来组织。
概念部分转载自:http://m.blog.csdn.net/article/details?id=51039938
RabbitMQ/JAVA 客户端测试(补:利用线程)的更多相关文章
-
RABBITMQ/JAVA 客户端测试(再补:利用文件流)
(一)这里可以先复习一下java输入输出流和文件操作--- 1.File类保存文件或目录的各种元数据信息,包括文件名.文件长度.最后修改时间.是否可读.获取当前文件的路径名.判断指定文件是否存在.获取 ...
-
docker安装fastdfs与java客户端测试
一.docker 安装FastDFS 1.拉取镜像 docker pull morunchang/fastdfs 2.创建并启动tracker容器 docker run -d --name=track ...
-
[RabbitMQ]Java客户端:源码概览
本文简要介绍RabbitMQ提供的Java客户端中最基本的功能性接口/类及相关源码. Mavan依赖: <dependency> <groupId>com.rabbitmq&l ...
-
HBase的java客户端测试(二)---DML操作
测试准备 [首先同步时间:] for node in CloudDeskTop master01 master02 slave01 slave02 slave03;do ssh $node " ...
-
HBase的java客户端测试(一)---DDL操作
测试准备 [首先同步时间:] for node in CloudDeskTop master01 master02 slave01 slave02 slave03;do ssh $node " ...
-
RabbitMQ JAVA客户端调用例子
1.安装erlang 下载地址:http://www.erlang.org/downloads 设置ERLANG环境变量 2.安装RabbitMQ 下载地址: http://www.rabbitmq. ...
-
如何在Java中测试类是否是线程安全的
通过优锐课的java核心笔记中,我们可以看到关于如何在java中测试类是否线程安全的一些知识点汇总,分享给大家学习参考. 线程安全性测试与典型的单线程测试不同.为了测试一个方法是否是线程安全的,我们需 ...
-
译:1. RabbitMQ Java Client 之 ";Hello World";
这些教程介绍了使用RabbitMQ创建消息传递应用程序的基础知识.您需要安装RabbitMQ服务器才能完成教程 1. 打造第一个Hello World 程序 RabbitMQ是一个消息代理:它接受和转 ...
-
Java阶段性测试--知识点:数组,面向对象,集合、线程,IO流
#Java基础测试 涉及知识点:数组,面向对象,重载,重写,继承,集合,排序,线程,文件流 一.多项选择题(可能是单选,也可能是多选) 1.下列标识符命名不合法的是( D ). A.$_Name ...
随机推荐
-
【RobotFramework自动化测试】RFS常用脚本
读取后台数据文件:Import Variables | ${CURDIR}/\ABC.py 定位页面:Wait Until Keyword Succeeds | 5s | 500ms | select ...
-
【转】Monkeyrunner测试1——Monkeyrunner的使用
Monkeyrunner的使用 一.终端输入单行命令行实现 1. 开启android 模拟器 (1) 用Eclipse打开andorid的模拟器 (2) 在CMD中用andorid命令打开模拟器 定位 ...
-
QuartusII 中采用门级原语
QuartusII 中采用门级原语 默认的是前面第一个 为output 后面所有信号为输入 图中的工程实现的是 一个二选一多路选择器
-
Java工具类——通过配置XML验证Map
Java工具类--通过配置XML验证Map 背景 在JavaWeb项目中,接收前端过来的参数时通常是使用我们的实体类进行接收的.但是呢,我们不能去决定已经搭建好的框架是怎么样的,在我接触的框架中有一种 ...
-
pyqt win32发送QQ消息
标题应该改为:python+win32发送QQ消息,全程使用python套个pyqt壳. 其实代码来自: http://blog.csdn.net/suzyu12345/article/details ...
-
网络编程-SOCKET开发之----3. socket通信工作流程
1. TCP的socket通信流程 服务端 1)socket----创建socket对象. 2)bind----绑定本机ip+port. 3)listen----监听来电,若在监听到来电,则建立起连接 ...
-
spring-boot-2.0.3之quartz集成,数据源问题,源码探究
前言 开心一刻 着火了,他报警说:119吗,我家发生火灾了. 119问:在哪里? 他说:在我家. 119问:具体点. 他说:在我家的厨房里. 119问:我说你现在的位置. 他说:我趴在桌子底下. 11 ...
-
Django——User-Profile
Profile作用:User内置的字段不够完善,导致创建的用户信息单一,Profile就是为了对User进行扩展,即丰富用户信息 在models中创建Profile类,添加字段user与User形成O ...
-
Aircrack-ng破解WPA/WPA2加密WiFi教程(Kali)
一.说明 以前学Kali,很多人都笑赞“WiFi破解神器”.我很烦,一是我不会破解二是我觉得他们也不会破解三是我隐约觉得所谓的WiFi破解不是什么技术性的操作. 后来基础知识充分了然后弄了个无线网卡, ...
-
PostgreSQL之性能优化(转)
转载自:https://blog.csdn.net/huangwenyi1010/article/details/72853785 解决问题 前言 PostgreSQL的配置参数作为性能调优的一部分, ...