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

org.apache.bookkeeper.bookie.storage.EntryLogger Maven / Gradle / Ivy

There is a newer version: 4.17.1
Show 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.bookkeeper.bookie.storage;

import io.netty.buffer.ByteBuf;
import java.io.IOException;
import java.util.Collection;
import org.apache.bookkeeper.bookie.AbstractLogCompactor;
import org.apache.bookkeeper.bookie.Bookie.NoEntryException;
import org.apache.bookkeeper.bookie.EntryLogMetadata;


/**
 * Entry logger. Sequentially writes entries for a large number of ledgers to
 * a small number of log files, to avoid many random writes.
 * When an entry is added, a location is returned, which consists of the ID of the
 * log into which the entry was added, and the offset of that entry within the log.
 * The location is a long, with 32 bits each for the log ID and the offset. This
 * naturally limits the offset and thus the size of the log to Integer.MAX_VALUE.
 */
public interface EntryLogger extends AutoCloseable {
    long UNASSIGNED_LEDGERID = -1L;
    // log file suffix
    String LOG_FILE_SUFFIX = ".log";

    /**
     * Add an entry for ledger ```ledgerId``` to the entrylog.
     * @param ledgerId the ledger for which the entry is being added
     * @param buf the contents of the entry (this method does not take ownership of the refcount)
     * @return the location in the entry log of the added entry
     */
    long addEntry(long ledgerId, ByteBuf buf) throws IOException;

    /**
     * Read an entry from an entrylog location.
     * @param entryLocation the location from which to read the entry
     * @return the entry
     */
    ByteBuf readEntry(long entryLocation)
            throws IOException, NoEntryException;
    /**
     * Read an entry from an entrylog location, and verify that is matches the
     * expected ledger and entry ID.
     * @param ledgerId the ledgerID to match
     * @param entryId the entryID to match
     * @param entryLocation the location from which to read the entry
     * @return the entry
     */
    ByteBuf readEntry(long ledgerId, long entryId, long entryLocation)
            throws IOException, NoEntryException;

    /**
     * Flush any outstanding writes to disk.
     */
    void flush() throws IOException;

    @Override
    void close() throws IOException;

    /**
     * Create a new entrylog into which compacted entries can be added.
     * There is a 1-1 mapping between logs that are being compacted
     * and the log the compacted entries are written to.
     */
    CompactionEntryLog newCompactionLog(long logToCompact) throws IOException;

    /**
     * Return a collection of all the compaction entry logs which have been
     * compacted, but have not been cleaned up.
     */
    Collection incompleteCompactionLogs();

    /**
     * Get the log ids for the set of logs which have been completely flushed to
     * disk.
     * Only log ids in this set are considered for either compaction or garbage
     * collection.
     */
    Collection getFlushedLogIds();

    /**
     * Scan the given entrylog, returning all entries contained therein.
     */
    void scanEntryLog(long entryLogId, EntryLogScanner scanner) throws IOException;

    /**
     * Retrieve metadata for the given entrylog ID.
     * The metadata contains the size of the log, the size of the data in the log which is still
     * active, and a list of all the ledgers contained in the log and the size of the data stored
     * for each ledger.
     */
    default EntryLogMetadata getEntryLogMetadata(long entryLogId) throws IOException {
        return getEntryLogMetadata(entryLogId, null);
    }

    /**
     * Retrieve metadata for the given entrylog ID.
     * The metadata contains the size of the log, the size of the data in the log which is still
     * active, and a list of all the ledgers contained in the log and the size of the data stored
     * for each ledger.
     */
    EntryLogMetadata getEntryLogMetadata(long entryLogId, AbstractLogCompactor.Throttler throttler) throws IOException;

    /**
     * Check whether an entrylog with the given ID exists.
     */
    boolean logExists(long logId);

    /**
     * Delete the entrylog with the given ID.
     * @return false if the entrylog doesn't exist.
     */
    boolean removeEntryLog(long entryLogId);
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy