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

org.modeshape.jcr.api.BackupOptions Maven / Gradle / Ivy

There is a newer version: 5.5.1.fcr
Show newest version
/*
 * ModeShape (http://www.modeshape.org)
 *
 * 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 org.modeshape.jcr.api;

/**
 * Class which allows a customization of the backup process.
 * 
 * @author Horia Chiorean ([email protected])
 */
public abstract class BackupOptions {

    /**
     * By default, 100K nodes will be exported to a single backup file. 
     * So, if each node requires about 200 bytes (compressed), the resulting files will be about 19 MB in size.
     */
    public static final long DEFAULT_DOCUMENTS_PER_FILE = 100000L;

    /**
     * The number of documents read form the persistent store and written in a backup file in one unit
     */
    public static final int DEFAULT_BATCH_SIZE = 10000;
    
    /**
     * Default backup options which will be used when a backup is performed without an explicit set of options.
     */
    public static final BackupOptions DEFAULT = new BackupOptions(){};

    /**
     * Whether or not binary data should be part of the backup or not. Since ModeShape stores references from the schematic documents
     * toward the binary values which are being used, it might not always be desired to do a full binary backup.
     * 
     * @return {@code true} if binary data should be exported; defaults to {@code true}
     */
    public boolean includeBinaries() {
        return true;
    }

    /**
     * Return the number of documents which should be backed up in a single file. 
     *
     * @return the number documents; defaults to {@@value #DEFAULT_DOCUMENTS_PER_FILE}
     */
    public long documentsPerFile() {
        return DEFAULT_DOCUMENTS_PER_FILE;    
    }

    /**
     * Return the number of documents that should be read and written to the backup file in one unit.
     * 
     * 

* This is a setting that can be used to influence the memory and throughout of the backup process. *

* * @return the number of documents; defaults to {@value #DEFAULT_BATCH_SIZE} * @since 5.0 */ public int batchSize() { return DEFAULT_BATCH_SIZE; } /** * Return whether or not each backup file (which contains multiple documents) should be compressed or not. * * @return {@code true} if the backup files should be compressed; defaults to {@code true} */ public boolean compress() { return true; } @Override public String toString() { StringBuilder builder = new StringBuilder("[backup_options: "); builder.append("include binaries=").append(includeBinaries()); builder.append(", batch size=").append(batchSize()); builder.append(", documents per file=").append(documentsPerFile()); builder.append(", compress=").append(compress()); builder.append("]"); return builder.toString(); } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy