RabbitMQ/JAVA 客户端测试(补:利用线程)

时间:2021-08-22 02:04:04

上次进行了简单的连接测试。这次主要进行一下小小的补充。利用线程将生产者消费者代码合到一个文件中。

我是将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/JAVA 客户端测试(补:利用线程)

另外,这里对于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 客户端测试(补:利用线程)的更多相关文章

  1. RABBITMQ/JAVA 客户端测试(再补:利用文件流)

    (一)这里可以先复习一下java输入输出流和文件操作--- 1.File类保存文件或目录的各种元数据信息,包括文件名.文件长度.最后修改时间.是否可读.获取当前文件的路径名.判断指定文件是否存在.获取 ...

  2. docker安装fastdfs与java客户端测试

    一.docker 安装FastDFS 1.拉取镜像 docker pull morunchang/fastdfs 2.创建并启动tracker容器 docker run -d --name=track ...

  3. [RabbitMQ]Java客户端:源码概览

    本文简要介绍RabbitMQ提供的Java客户端中最基本的功能性接口/类及相关源码. Mavan依赖: <dependency> <groupId>com.rabbitmq&l ...

  4. HBase的java客户端测试&lpar;二&rpar;---DML操作

    测试准备 [首先同步时间:] for node in CloudDeskTop master01 master02 slave01 slave02 slave03;do ssh $node &quot ...

  5. HBase的java客户端测试&lpar;一&rpar;---DDL操作

    测试准备 [首先同步时间:] for node in CloudDeskTop master01 master02 slave01 slave02 slave03;do ssh $node &quot ...

  6. RabbitMQ JAVA客户端调用例子

    1.安装erlang 下载地址:http://www.erlang.org/downloads 设置ERLANG环境变量 2.安装RabbitMQ 下载地址: http://www.rabbitmq. ...

  7. 如何在Java中测试类是否是线程安全的

    通过优锐课的java核心笔记中,我们可以看到关于如何在java中测试类是否线程安全的一些知识点汇总,分享给大家学习参考. 线程安全性测试与典型的单线程测试不同.为了测试一个方法是否是线程安全的,我们需 ...

  8. 译&colon;1&period; RabbitMQ Java Client 之 &quot&semi;Hello World&quot&semi;

    这些教程介绍了使用RabbitMQ创建消息传递应用程序的基础知识.您需要安装RabbitMQ服务器才能完成教程 1. 打造第一个Hello World 程序 RabbitMQ是一个消息代理:它接受和转 ...

  9. Java阶段性测试--知识点:数组,面向对象,集合、线程,IO流

    #Java基础测试 涉及知识点:数组,面向对象,重载,重写,继承,集合,排序,线程,文件流 一.多项选择题(可能是单选,也可能是多选) 1.下列标识符命名不合法的是(   D  ). A.$_Name ...

随机推荐

  1. 【RobotFramework自动化测试】RFS常用脚本

    读取后台数据文件:Import Variables | ${CURDIR}/\ABC.py 定位页面:Wait Until Keyword Succeeds | 5s | 500ms | select ...

  2. 【转】Monkeyrunner测试1——Monkeyrunner的使用

    Monkeyrunner的使用 一.终端输入单行命令行实现 1. 开启android 模拟器 (1) 用Eclipse打开andorid的模拟器 (2) 在CMD中用andorid命令打开模拟器 定位 ...

  3. QuartusII 中采用门级原语

    QuartusII  中采用门级原语 默认的是前面第一个 为output  后面所有信号为输入 图中的工程实现的是 一个二选一多路选择器

  4. Java工具类——通过配置XML验证Map

    Java工具类--通过配置XML验证Map 背景 在JavaWeb项目中,接收前端过来的参数时通常是使用我们的实体类进行接收的.但是呢,我们不能去决定已经搭建好的框架是怎么样的,在我接触的框架中有一种 ...

  5. pyqt win32发送QQ消息

    标题应该改为:python+win32发送QQ消息,全程使用python套个pyqt壳. 其实代码来自: http://blog.csdn.net/suzyu12345/article/details ...

  6. 网络编程-SOCKET开发之----3&period; socket通信工作流程

    1. TCP的socket通信流程 服务端 1)socket----创建socket对象. 2)bind----绑定本机ip+port. 3)listen----监听来电,若在监听到来电,则建立起连接 ...

  7. spring-boot-2&period;0&period;3之quartz集成,数据源问题,源码探究

    前言 开心一刻 着火了,他报警说:119吗,我家发生火灾了. 119问:在哪里? 他说:在我家. 119问:具体点. 他说:在我家的厨房里. 119问:我说你现在的位置. 他说:我趴在桌子底下. 11 ...

  8. Django——User-Profile

    Profile作用:User内置的字段不够完善,导致创建的用户信息单一,Profile就是为了对User进行扩展,即丰富用户信息 在models中创建Profile类,添加字段user与User形成O ...

  9. Aircrack-ng破解WPA&sol;WPA2加密WiFi教程(Kali)

    一.说明 以前学Kali,很多人都笑赞“WiFi破解神器”.我很烦,一是我不会破解二是我觉得他们也不会破解三是我隐约觉得所谓的WiFi破解不是什么技术性的操作. 后来基础知识充分了然后弄了个无线网卡, ...

  10. PostgreSQL之性能优化(转)

    转载自:https://blog.csdn.net/huangwenyi1010/article/details/72853785 解决问题 前言 PostgreSQL的配置参数作为性能调优的一部分, ...