diff --git a/tools/src/main/java/org/apache/rocketmq/tools/command/message/ConsumeMessageCommand.java b/tools/src/main/java/org/apache/rocketmq/tools/command/message/ConsumeMessageCommand.java index aa98ee628704e032ff567e624ba9534ddd157a99..6bf91840aeb48df6e9b9a093201d06c7732b1bfd 100644 --- a/tools/src/main/java/org/apache/rocketmq/tools/command/message/ConsumeMessageCommand.java +++ b/tools/src/main/java/org/apache/rocketmq/tools/command/message/ConsumeMessageCommand.java @@ -142,7 +142,7 @@ public class ConsumeMessageCommand implements SubCommand { if (commandLine.hasOption('c')) { messageCount = Long.parseLong(commandLine.getOptionValue('c').trim()); if (messageCount <= 0) { - System.out.print("please input a positive messageNumber!"); + System.out.print("Please input a positive messageNumber!"); return; } } @@ -161,20 +161,33 @@ public class ConsumeMessageCommand implements SubCommand { } if (commandLine.hasOption('o')) { if (consumeType != ConsumeType.BYQUEUE) { - System.out.print("please set queueId before offset!"); + System.out.print("Please set queueId before offset!"); return; } offset = Long.parseLong(commandLine.getOptionValue('o').trim()); consumeType = ConsumeType.BYOFFSET; } + long now = System.currentTimeMillis(); if (commandLine.hasOption('s')) { String timestampStr = commandLine.getOptionValue('s').trim(); timeValueBegin = timestampFormat(timestampStr); + if (timeValueBegin > now) { + System.out.print("Please set the beginTimestamp before now!"); + return; + } } if (commandLine.hasOption('e')) { String timestampStr = commandLine.getOptionValue('e').trim(); timeValueEnd = timestampFormat(timestampStr); + if (timeValueEnd > now) { + System.out.print("Please set the endTimestamp before now!"); + return; + } + if (timeValueBegin > timeValueEnd) { + System.out.print("Please make sure that the beginTimestamp is less than or equal to the endTimestamp"); + return; + } } switch (consumeType) {