Search in sources :

Example 1 with SegmentBlobReferenceRetriever

use of org.apache.jackrabbit.oak.segment.SegmentBlobReferenceRetriever in project jackrabbit-oak by apache.

the class DataStoreCheckCommand method checkDataStore.

static int checkDataStore(String... args) {
    OptionParser parser = new OptionParser();
    parser.allowsUnrecognizedOptions();
    String helpStr = "datastorecheck [--id] [--ref] [--consistency] [--store <path>|<mongo_uri>] " + "[--s3ds <s3ds_config>|--fds <fds_config>|--azureblobds <azureblobds_config>|--nods]" + " [--dump <path>] [--repoHome <repo_home>] [--track] [--verbose]";
    try (Closer closer = Closer.create()) {
        // Options for operations requested
        OptionSpecBuilder idOp = parser.accepts("id", "Get ids");
        OptionSpecBuilder refOp = parser.accepts("ref", "Get references");
        OptionSpecBuilder consistencyOp = parser.accepts("consistency", "Check consistency");
        // Node Store - needed for --ref, --consistency
        ArgumentAcceptingOptionSpec<String> store = parser.accepts("store", "Node Store").requiredIf(refOp, consistencyOp).withRequiredArg().ofType(String.class);
        // Optional argument to specify the dump path
        ArgumentAcceptingOptionSpec<String> dump = parser.accepts("dump", "Dump Path").withRequiredArg().ofType(String.class);
        // Optional argument to specify tracking
        OptionSpecBuilder trackOverride = parser.accepts("track", "Force override tracked ids");
        // Required argument for --consistency to specify tracking folder (otherwise can have inconsistencies)
        ArgumentAcceptingOptionSpec<String> repoHome = parser.accepts("repoHome", "Local repository home folder").requiredIf(trackOverride, consistencyOp).withRequiredArg().ofType(String.class);
        // Optional argument to specify tracking
        OptionSpecBuilder verbose = parser.accepts("verbose", "Output backend formatted ids/paths");
        OptionSpec<?> help = parser.acceptsAll(asList("h", "?", "help"), "show help").forHelp();
        // Required rules (any one of --id, --ref, --consistency)
        idOp.requiredUnless(refOp, consistencyOp);
        refOp.requiredUnless(idOp, consistencyOp);
        consistencyOp.requiredUnless(idOp, refOp);
        trackOverride.availableIf(idOp, consistencyOp);
        OptionSet options = null;
        try {
            options = parser.parse(args);
        } catch (Exception e) {
            System.err.println(e);
            System.err.println(Arrays.toString(args));
            System.err.println();
            System.err.println("Options :");
            parser.printHelpOn(System.err);
            return 1;
        }
        if (options.has(help)) {
            parser.printHelpOn(System.out);
            return 0;
        }
        String dumpPath = JAVA_IO_TMPDIR.value();
        if (options.has(dump)) {
            dumpPath = options.valueOf(dump);
        }
        GarbageCollectableBlobStore blobStore = null;
        BlobReferenceRetriever marker = null;
        NodeStore nodeStore = null;
        if (options.has(store)) {
            String source = options.valueOf(store);
            if (source.startsWith(MongoURI.MONGODB_PREFIX)) {
                MongoClientURI uri = new MongoClientURI(source);
                MongoClient client = new MongoClient(uri);
                DocumentNodeStore docNodeStore = newMongoDocumentNodeStoreBuilder().setMongoDB(client.getDB(uri.getDatabase())).build();
                closer.register(Utils.asCloseable(docNodeStore));
                blobStore = (GarbageCollectableBlobStore) docNodeStore.getBlobStore();
                marker = new DocumentBlobReferenceRetriever(docNodeStore);
                nodeStore = docNodeStore;
            } else {
                FileStore fileStore = fileStoreBuilder(new File(source)).withStrictVersionCheck(true).build();
                marker = new SegmentBlobReferenceRetriever(fileStore);
                closer.register(fileStore);
                nodeStore = SegmentNodeStoreBuilders.builder(fileStore).build();
            }
        }
        // Initialize S3/FileDataStore if configured
        String dsType = "";
        GarbageCollectableBlobStore dataStore = Utils.bootstrapDataStore(args, closer);
        if (dataStore != null) {
            dsType = getDSType(args);
            blobStore = dataStore;
        }
        // blob store still not initialized means configuration not supported
        if (blobStore == null) {
            System.err.println("Operation not defined for SegmentNodeStore without external datastore");
            parser.printHelpOn(System.err);
            return 1;
        }
        FileRegister register = new FileRegister(options);
        closer.register(register);
        if (options.has(idOp) || options.has(consistencyOp)) {
            File idTemp = createTempFile("ids", null);
            closer.register(new Closeable() {

                @Override
                public void close() throws IOException {
                    forceDelete(idTemp);
                }
            });
            File dumpFile = register.createFile(idOp, dumpPath);
            retrieveBlobIds(blobStore, idTemp);
            // If track path and track override specified copy the file to the location
            if (options.has(repoHome) && options.has(trackOverride)) {
                String trackPath = options.valueOf(repoHome);
                File trackingFileParent = new File(FilenameUtils.concat(trackPath, "blobids"));
                File trackingFile = new File(trackingFileParent, "blob-" + String.valueOf(System.currentTimeMillis()) + ".gen");
                FileUtils.copyFile(idTemp, trackingFile);
            }
            if (options.has(verbose)) {
                verboseIds(closer, dsType, idTemp, dumpFile);
            } else {
                FileUtils.copyFile(idTemp, dumpFile);
            }
        }
        if (options.has(refOp) || options.has(consistencyOp)) {
            if (options.has(verbose) && (nodeStore instanceof SegmentNodeStore || nodeStore instanceof org.apache.jackrabbit.oak.segment.SegmentNodeStore)) {
                NodeTraverser traverser = new NodeTraverser(nodeStore, dsType);
                closer.register(traverser);
                traverser.traverse();
                FileUtils.copyFile(traverser.references, register.createFile(refOp, dumpPath));
            } else {
                retrieveBlobReferences(blobStore, marker, register.createFile(refOp, dumpPath), dsType, options.has(verbose));
            }
        }
        if (options.has(consistencyOp)) {
            checkConsistency(register.get(idOp), register.get(refOp), register.createFile(consistencyOp, dumpPath), options.valueOf(repoHome), dsType);
        }
        return 0;
    } catch (Throwable t) {
        t.printStackTrace(System.err);
        return 1;
    }
}
Also used : MongoClientURI(com.mongodb.MongoClientURI) Closeable(java.io.Closeable) DocumentNodeStore(org.apache.jackrabbit.oak.plugins.document.DocumentNodeStore) SegmentBlobReferenceRetriever(org.apache.jackrabbit.oak.segment.SegmentBlobReferenceRetriever) OptionParser(joptsimple.OptionParser) MongoClient(com.mongodb.MongoClient) DocumentNodeStore(org.apache.jackrabbit.oak.plugins.document.DocumentNodeStore) NodeStore(org.apache.jackrabbit.oak.spi.state.NodeStore) SegmentNodeStore(org.apache.jackrabbit.oak.plugins.segment.SegmentNodeStore) OptionSpecBuilder(joptsimple.OptionSpecBuilder) DocumentBlobReferenceRetriever(org.apache.jackrabbit.oak.plugins.document.DocumentBlobReferenceRetriever) BlobReferenceRetriever(org.apache.jackrabbit.oak.plugins.blob.BlobReferenceRetriever) SegmentBlobReferenceRetriever(org.apache.jackrabbit.oak.segment.SegmentBlobReferenceRetriever) GarbageCollectableBlobStore(org.apache.jackrabbit.oak.spi.blob.GarbageCollectableBlobStore) Closer(com.google.common.io.Closer) IOException(java.io.IOException) IOException(java.io.IOException) FileStore(org.apache.jackrabbit.oak.segment.file.FileStore) OptionSet(joptsimple.OptionSet) DocumentBlobReferenceRetriever(org.apache.jackrabbit.oak.plugins.document.DocumentBlobReferenceRetriever) SegmentNodeStore(org.apache.jackrabbit.oak.plugins.segment.SegmentNodeStore) File.createTempFile(java.io.File.createTempFile) File(java.io.File)

Aggregations

Closer (com.google.common.io.Closer)1 MongoClient (com.mongodb.MongoClient)1 MongoClientURI (com.mongodb.MongoClientURI)1 Closeable (java.io.Closeable)1 File (java.io.File)1 File.createTempFile (java.io.File.createTempFile)1 IOException (java.io.IOException)1 OptionParser (joptsimple.OptionParser)1 OptionSet (joptsimple.OptionSet)1 OptionSpecBuilder (joptsimple.OptionSpecBuilder)1 BlobReferenceRetriever (org.apache.jackrabbit.oak.plugins.blob.BlobReferenceRetriever)1 DocumentBlobReferenceRetriever (org.apache.jackrabbit.oak.plugins.document.DocumentBlobReferenceRetriever)1 DocumentNodeStore (org.apache.jackrabbit.oak.plugins.document.DocumentNodeStore)1 SegmentNodeStore (org.apache.jackrabbit.oak.plugins.segment.SegmentNodeStore)1 SegmentBlobReferenceRetriever (org.apache.jackrabbit.oak.segment.SegmentBlobReferenceRetriever)1 FileStore (org.apache.jackrabbit.oak.segment.file.FileStore)1 GarbageCollectableBlobStore (org.apache.jackrabbit.oak.spi.blob.GarbageCollectableBlobStore)1 NodeStore (org.apache.jackrabbit.oak.spi.state.NodeStore)1