org.apache.rocketmq.store.GetMessageResult Maven / Gradle / Ivy
The newest version!
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.apache.rocketmq.store;
import java.nio.ByteBuffer;
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
public class GetMessageResult {
private final List messageMapedList;
private final List messageBufferList;
private final List messageQueueOffset;
private GetMessageStatus status;
private long nextBeginOffset;
private long minOffset;
private long maxOffset;
private int bufferTotalSize = 0;
private int messageCount = 0;
private boolean suggestPullingFromSlave = false;
private int msgCount4Commercial = 0;
private int commercialSizePerMsg = 4 * 1024;
private long coldDataSum = 0L;
public static final GetMessageResult NO_MATCH_LOGIC_QUEUE =
new GetMessageResult(GetMessageStatus.NO_MATCHED_LOGIC_QUEUE, 0, 0, 0, Collections.emptyList(),
Collections.emptyList(), Collections.emptyList());
public GetMessageResult() {
messageMapedList = new ArrayList<>(100);
messageBufferList = new ArrayList<>(100);
messageQueueOffset = new ArrayList<>(100);
}
public GetMessageResult(int resultSize) {
messageMapedList = new ArrayList<>(resultSize);
messageBufferList = new ArrayList<>(resultSize);
messageQueueOffset = new ArrayList<>(resultSize);
}
private GetMessageResult(GetMessageStatus status, long nextBeginOffset, long minOffset, long maxOffset,
List messageMapedList, List messageBufferList, List messageQueueOffset) {
this.status = status;
this.nextBeginOffset = nextBeginOffset;
this.minOffset = minOffset;
this.maxOffset = maxOffset;
this.messageMapedList = messageMapedList;
this.messageBufferList = messageBufferList;
this.messageQueueOffset = messageQueueOffset;
}
public GetMessageStatus getStatus() {
return status;
}
public void setStatus(GetMessageStatus status) {
this.status = status;
}
public long getNextBeginOffset() {
return nextBeginOffset;
}
public void setNextBeginOffset(long nextBeginOffset) {
this.nextBeginOffset = nextBeginOffset;
}
public long getMinOffset() {
return minOffset;
}
public void setMinOffset(long minOffset) {
this.minOffset = minOffset;
}
public long getMaxOffset() {
return maxOffset;
}
public void setMaxOffset(long maxOffset) {
this.maxOffset = maxOffset;
}
public List getMessageMapedList() {
return messageMapedList;
}
public List getMessageBufferList() {
return messageBufferList;
}
public void addMessage(final SelectMappedBufferResult mapedBuffer) {
this.messageMapedList.add(mapedBuffer);
this.messageBufferList.add(mapedBuffer.getByteBuffer());
this.bufferTotalSize += mapedBuffer.getSize();
this.msgCount4Commercial += (int) Math.ceil(
mapedBuffer.getSize() / (double)commercialSizePerMsg);
this.messageCount++;
}
public void addMessage(final SelectMappedBufferResult mapedBuffer, final long queueOffset) {
this.messageMapedList.add(mapedBuffer);
this.messageBufferList.add(mapedBuffer.getByteBuffer());
this.bufferTotalSize += mapedBuffer.getSize();
this.msgCount4Commercial += (int) Math.ceil(
mapedBuffer.getSize() / (double)commercialSizePerMsg);
this.messageCount++;
this.messageQueueOffset.add(queueOffset);
}
public void addMessage(final SelectMappedBufferResult mapedBuffer, final long queueOffset, final int batchNum) {
addMessage(mapedBuffer, queueOffset);
messageCount += batchNum - 1;
}
public void release() {
for (SelectMappedBufferResult select : this.messageMapedList) {
select.release();
}
}
public int getBufferTotalSize() {
return bufferTotalSize;
}
public int getMessageCount() {
return messageCount;
}
public boolean isSuggestPullingFromSlave() {
return suggestPullingFromSlave;
}
public void setSuggestPullingFromSlave(boolean suggestPullingFromSlave) {
this.suggestPullingFromSlave = suggestPullingFromSlave;
}
public int getMsgCount4Commercial() {
return msgCount4Commercial;
}
public void setMsgCount4Commercial(int msgCount4Commercial) {
this.msgCount4Commercial = msgCount4Commercial;
}
public List getMessageQueueOffset() {
return messageQueueOffset;
}
public long getColdDataSum() {
return coldDataSum;
}
public void setColdDataSum(long coldDataSum) {
this.coldDataSum = coldDataSum;
}
@Override
public String toString() {
return "GetMessageResult [status=" + status + ", nextBeginOffset=" + nextBeginOffset + ", minOffset="
+ minOffset + ", maxOffset=" + maxOffset + ", bufferTotalSize=" + bufferTotalSize + ", messageCount=" + messageCount
+ ", suggestPullingFromSlave=" + suggestPullingFromSlave + "]";
}
}