/** * $Id: ScheduleMessageTest.java 1831 2013-05-16 01:39:51Z shijia.wxr $ */ package com.alibaba.rocketmq.store.schedule; import static org.junit.Assert.assertTrue; import java.net.InetAddress; import java.net.InetSocketAddress; import java.net.SocketAddress; import java.util.concurrent.atomic.AtomicInteger; import org.junit.AfterClass; import org.junit.BeforeClass; import org.junit.Test; import com.alibaba.rocketmq.store.DefaultMessageStore; import com.alibaba.rocketmq.store.GetMessageResult; import com.alibaba.rocketmq.store.MessageExtBrokerInner; import com.alibaba.rocketmq.store.MessageStore; import com.alibaba.rocketmq.store.PutMessageResult; import com.alibaba.rocketmq.store.config.MessageStoreConfig; public class ScheduleMessageTest { // 队列个数 private static int QUEUE_TOTAL = 100; // 发往哪个队列 private static AtomicInteger QueueId = new AtomicInteger(0); // 发送主机地址 private static SocketAddress BornHost; // 存储主机地址 private static SocketAddress StoreHost; // 消息体 private static byte[] MessageBody; private static final String StoreMessage = "Once, there was a chance for me!"; public MessageExtBrokerInner buildMessage() { MessageExtBrokerInner msg = new MessageExtBrokerInner(); msg.setTopic("AAA"); msg.setTags("TAG1"); msg.setKeys("Hello"); msg.setBody(MessageBody); msg.setKeys(String.valueOf(System.currentTimeMillis())); msg.setQueueId(Math.abs(QueueId.getAndIncrement()) % QUEUE_TOTAL); msg.setSysFlag(4); msg.setBornTimestamp(System.currentTimeMillis()); msg.setStoreHost(StoreHost); msg.setBornHost(BornHost); return msg; } @BeforeClass public static void setUpBeforeClass() throws Exception { StoreHost = new InetSocketAddress(InetAddress.getLocalHost(), 8123); BornHost = new InetSocketAddress(InetAddress.getByName("10.232.102.184"), 0); } @AfterClass public static void tearDownAfterClass() throws Exception { } @Test public void test_delay_message() throws Exception { System.out.println("================================================================"); long totalMsgs = 10000; QUEUE_TOTAL = 32; // 构造消息体 MessageBody = StoreMessage.getBytes(); MessageStoreConfig messageStoreConfig = new MessageStoreConfig(); // 每个物理映射文件 4K messageStoreConfig.setMapedFileSizeCommitLog(1024 * 32); messageStoreConfig.setMapedFileSizeConsumeQueue(1024 * 16); messageStoreConfig.setMaxHashSlotNum(100); messageStoreConfig.setMaxIndexNum(1000 * 10); MessageStore master = new DefaultMessageStore(messageStoreConfig); // 第一步,load已有数据 boolean load = master.load(); assertTrue(load); // 第二步,启动服务 master.start(); for (int i = 0; i < totalMsgs; i++) { MessageExtBrokerInner msg = buildMessage(); msg.setDelayTimeLevel(i % 4); PutMessageResult result = master.putMessage(msg); System.out.println(i + "\t" + result.getAppendMessageResult().getMsgId()); } System.out.println("write message over, wait time up"); Thread.sleep(1000 * 20); // 开始读文件 for (long i = 0; i < totalMsgs; i++) { try { GetMessageResult result = master.getMessage("TOPIC_A", 0, i, 1024 * 1024, null); if (result == null) { System.out.println("result == null " + i); } assertTrue(result != null); result.release(); System.out.println("read " + i + " OK"); } catch (Exception e) { e.printStackTrace(); } } Thread.sleep(1000 * 15); // 关闭存储服务 master.shutdown(); // 删除文件 master.destroy(); System.out.println("================================================================"); } }