博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
RabbitMQ基本功能测试用例(Java实现)
阅读量:7071 次
发布时间:2019-06-28

本文共 2977 字,大约阅读时间需要 9 分钟。

为了测试RabbitMQ是否好用,编写了一个由Java语言编写的RabbitMQ基本功能测试用例,仅供参考。

代码说明:

由于实现语言是Java,因此有Java虚拟机(安装了JDK或JRE)即可测试,不需要像Python一样需要安装第三方模块,便于Docker环境下做简单测试。在此测试用例用用到了amqp-client-3.x.x.jar库,可以自行下载。

为实现一个java源文件中实现收与发(编译后还是3个Class文件),在main函数中起了两个线程,一个负责发,一个负责收,用来测试RabbitMQ消息的收与发。发送消息是每2s发一次(实现:Java Thread Sleep),为了每次发送消息内容的不同消息内容中加入了Java随机数(实现:Java Random)。

代码如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
package 
com.devops.broker.rabbitmq.client;
 
import 
com.rabbitmq.client.Channel;
import 
com.rabbitmq.client.Connection;
import 
com.rabbitmq.client.ConnectionFactory;
import 
com.rabbitmq.client.QueueingConsumer;
 
import 
java.io.IOException;
import 
java.util.Random;
 
class 
send 
extends 
Thread {
    
private 
final 
static 
String QUEUE_NAME = 
"hello"
;
 
    
public 
void 
run() {
        
ConnectionFactory factory = 
new 
ConnectionFactory();
        
factory.setHost(
"10.6.28.46"
);
        
factory.setPort(
5672
);
        
factory.setUsername(
"guest"
);
        
factory.setPassword(
"guest"
);
 
        
Random randomIntNumber = 
new 
Random();
 
        
try 
{
            
while 
(
true
) {
                
Connection connection = factory.newConnection();
                
Channel channel = connection.createChannel();
 
                
channel.queueDeclare(QUEUE_NAME, 
false
false
false
null
);
                
String message = 
"Hello World!"
;
                
Long ThreadID = send.currentThread().getId();
                
message = message + 
" Thread ID: " 
+ ThreadID.toString() + 
" Random Num: " 
+ randomIntNumber.nextInt();
                
channel.basicPublish(
""
, QUEUE_NAME, 
null
, message.getBytes());
                
System.out.println(
"Sent '" 
+ message + 
"'"
);
                
System.out.println(
""
);
                
channel.close();
                
connection.close();
                
try 
{
                    
Thread.sleep(
2000
);
                
catch 
(InterruptedException e) {
                    
e.printStackTrace();
                
}
            
}
 
 
        
catch 
(Exception e) {
            
System.out.println(e.getMessage());
        
}
    
}
}
 
class 
receiver 
extends 
Thread {
    
private 
final 
static 
String QUEUE_NAME = 
"hello"
;
 
    
public 
void 
run() {
        
ConnectionFactory factory = 
new 
ConnectionFactory();
        
factory.setHost(
"10.6.28.46"
);
        
factory.setPort(
5672
);
        
factory.setUsername(
"guest"
);
        
factory.setPassword(
"guest"
);
        
try 
{
            
Connection connection = factory.newConnection();
            
Channel channel = connection.createChannel();
 
            
channel.queueDeclare(QUEUE_NAME, 
false
false
false
null
);
 
            
QueueingConsumer consumer = 
new 
QueueingConsumer(channel);
            
channel.basicConsume(QUEUE_NAME, 
true
, consumer);
 
            
while 
(
true
) {
                
QueueingConsumer.Delivery delivery = consumer.nextDelivery();
                
String message = 
new 
String(delivery.getBody());
                
System.out.println(
"Received '" 
+ message + 
"'"
);
            
}
        
catch 
(Exception e) {
            
System.out.println(e.getMessage());
        
}
    
}
 
}
 
public 
class 
Main {
 
    
public 
static 
void 
main(String[] args) 
throws 
IOException {
        
send send = 
new 
send();
        
send.start();
 
        
receiver receiver = 
new 
receiver();
        
receiver.start();
    
}
}

tag:RabbitMQ Java demo,测试用例,功能测试

--end--

本文转自 urey_pp 51CTO博客,原文链接:http://blog.51cto.com/dgd2010/1794635,如需转载请自行联系原作者

你可能感兴趣的文章
在单页应用中,如何优雅的监听url的变化
查看>>
iOS笔记之Runtime
查看>>
基于 Module 的 Laravel API 架构
查看>>
Swift4 0新特性之String、Array和Dictionary
查看>>
《程序员的自我修养》-读书笔记
查看>>
异步社区本周半价电子书(5月28日-6月03日)
查看>>
Redux应用多人协作的思路和实现
查看>>
RestTemplate实践
查看>>
FYSBIS分析报告:SOFACY的Linux后门
查看>>
javascript 代理模式(通俗易懂)
查看>>
微信小程序开发者经验分享组织成立啦~~~
查看>>
五分钟学习 Java 8 行为参数化
查看>>
Elasticsearch の 初体验|一文了解她
查看>>
聊聊flink的Triggers
查看>>
自建最轻量的react+webpack+es6架构
查看>>
聊聊reactor extra的retry
查看>>
reactor-netty中HttpClient对TcpClient的封装
查看>>
数据库安全性操作——操作原则及SQL注入
查看>>
Java网络爬虫实操(9)
查看>>
前面有一个Redux,我们去撩(聊)一下它。
查看>>