All Downloads are FREE. Search and download functionalities are using the official Maven repository.

qunar.tc.qmq.delay.DelayLogFacade Maven / Gradle / Ivy

/*
 * Copyright 2018 Qunar, Inc.
 *
 * Licensed 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 qunar.tc.qmq.delay;

import qunar.tc.qmq.delay.base.LongHashSet;
import qunar.tc.qmq.delay.base.ReceivedDelayMessage;
import qunar.tc.qmq.delay.base.ReceivedResult;
import qunar.tc.qmq.delay.store.log.DispatchLogSegment;
import qunar.tc.qmq.delay.store.log.ScheduleSetSegment;
import qunar.tc.qmq.delay.store.model.AppendLogResult;
import qunar.tc.qmq.delay.store.model.LogRecord;
import qunar.tc.qmq.delay.store.model.ScheduleSetRecord;
import qunar.tc.qmq.delay.store.visitor.LogVisitor;
import qunar.tc.qmq.delay.wheel.WheelLoadCursor;
import qunar.tc.qmq.store.buffer.SegmentBuffer;
import qunar.tc.qmq.sync.DelaySyncRequest;

import java.nio.ByteBuffer;
import java.util.List;
import java.util.function.Consumer;

/**
 * @author xufeng.deng [email protected]
 * @since 2018-07-17 16:57
 */
public interface DelayLogFacade {
    void start();

    void shutdown();

    ReceivedResult appendMessageLog(ReceivedDelayMessage message);

    long getMessageLogMinOffset();

    SegmentBuffer getMessageLogs(long startSyncOffset);

    SegmentBuffer getDispatchLogs(long segmentBaseOffset, long dispatchLogOffset);

    long getMessageLogMaxOffset();

    long getDispatchLogMaxOffset(long dispatchSegmentBaseOffset);

    DelaySyncRequest.DispatchLogSyncRequest getDispatchLogSyncMaxRequest();

    boolean appendMessageLogData(long startOffset, ByteBuffer buffer);

    boolean appendDispatchLogData(long startOffset, long baseOffset, ByteBuffer body);

    List recoverLogRecord(List indexList);

    void appendDispatchLog(LogRecord record);

    DispatchLogSegment latestDispatchSegment();

    DispatchLogSegment lowerDispatchSegment(long latestOffset);

    ScheduleSetSegment loadScheduleLogSegment(long segmentBaseOffset);

    WheelLoadCursor.Cursor loadUnDispatch(ScheduleSetSegment setSegment, LongHashSet dispatchedSet, Consumer refresh);

    long higherScheduleBaseOffset(long index);

    AppendLogResult appendScheduleLog(LogRecord event);

    long initialMessageIterateFrom();

    void updateIterateOffset(long checkpoint);

    void blockUntilReplayDone();

    long higherDispatchLogBaseOffset(long segmentBaseOffset);
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy