Package elephantdb.store

Source Code of elephantdb.store.DomainStore

package elephantdb.store;

import elephantdb.DomainSpec;
import elephantdb.persistence.Persistence;
import elephantdb.persistence.ShardSet;
import elephantdb.persistence.ShardSetImpl;
import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.fs.FileSystem;
import org.apache.hadoop.fs.FileUtil;
import org.apache.hadoop.fs.Path;

import java.io.IOException;
import java.util.List;


public class DomainStore {
    VersionedStore vs;
    DomainSpec spec;

    public DomainStore(FileSystem fs, String path) throws IOException {
        this(new VersionedStore(fs, path), null);
    }

    public DomainStore(FileSystem fs, String path, DomainSpec spec) throws IOException {
        this(new VersionedStore(fs, path), spec);
    }

    public DomainStore(String path) throws IOException {
        this(path, null);
    }

    public DomainStore(String path, DomainSpec spec) throws IOException {
        this(new VersionedStore(path), spec);
    }

    protected DomainStore(VersionedStore vs, DomainSpec spec) throws IOException {
        this.vs = vs;
        String path = vs.getRoot();
        FileSystem fs = vs.getFileSystem();
        if(DomainSpec.exists(fs, path)) {
            this.spec = DomainSpec.readFromFileSystem(fs, path);

            if(spec!=null && !this.spec.equals(spec)) {
                throw new IllegalArgumentException(spec.toString() + " does not match existing " + this.spec.toString());
            }
        } else {
            if(spec == null) {
                throw new IllegalArgumentException("You must supply a DomainSpec when creating a DomainStore.");
            } else {
                this.spec = spec;
                spec.writeToFileSystem(fs, path);
            }
        }
    }

    public DomainSpec getSpec() {
        return spec;
    }
   
    public ShardSet getShardSet(long version) {
        String path = versionPath(version);
        return new ShardSetImpl(path, spec);
    }

    public FileSystem getFileSystem() {
        return vs.getFileSystem();
    }

    public String getRoot() {
        return vs.getRoot();
    }

    /*
    Experimental code for accessing domains.
     */

    public Persistence openShardForAppend(int shardIdx) throws IOException {
        return openShardForAppend(shardIdx, mostRecentVersion());
    }

    public Persistence openShardForAppend(int shardIdx, long version) throws IOException {
        return getShardSet(version).openShardForAppend(shardIdx);
    }

    public Persistence openShardForRead(int shardIdx) throws IOException {
        return openShardForRead(shardIdx, mostRecentVersion());
    }

    public Persistence openShardForRead(int shardIdx, long version) throws IOException {
        return getShardSet(version).openShardForRead(shardIdx);
    }

    public Persistence createShard(int shardIdx) throws IOException {
        return createShard(shardIdx, mostRecentVersion());
    }

    public Persistence createShard(int shardIdx, long version) throws IOException {
        return getShardSet(version).createShard(shardIdx);
    }
   
    public String shardPath(int shardIdx) throws IOException {
        return shardPath(shardIdx, mostRecentVersion());
    }

    public String shardPath(int shardIdx, long version) throws IOException {
        return getShardSet(version).shardPath(shardIdx);
    }

    /*
    Back to old code.
     */
    public String versionPath(long version) {
        return vs.versionPath(version);
    }

    public String mostRecentVersionPath() throws IOException {
        return vs.mostRecentVersionPath();
    }

    public String mostRecentVersionPath(long maxVersion) throws IOException {
        return vs.mostRecentVersionPath(maxVersion);
    }

    public Long mostRecentVersion() throws IOException {
        return vs.mostRecentVersion();
    }

    public Long mostRecentVersion(long maxVersion) throws IOException {
        return vs.mostRecentVersion(maxVersion);
    }

    public String createVersion() throws IOException {
        return vs.createVersion();
    }

    public String createVersion(long version) throws IOException {
        return vs.createVersion(version);
    }

    public void failVersion(String path) throws IOException {
        vs.failVersion(path);
    }

    public void deleteVersion(long version) throws IOException {
        vs.deleteVersion(version);
    }

    public void succeedVersion(String path) throws IOException {
        vs.succeedVersion(path);
    }

    public Long parseVersion(String path) throws IOException {
        return vs.parseVersion(path);
    }

    public static void synchronizeVersions(FileSystem fs, DomainSpec spec, String oldv, String newv) throws IOException {
        // TODO: might want to do a distcp here if the files are large
        // kept simple here for now since large domains implies large updates which will hit every shard
        if(oldv!=null) {
            for(int i=0; i<spec.getNumShards(); i++) {
                String currPath = oldv + "/" + i;
                String newPath = newv + "/" + i;
                if(fs.exists(new Path(currPath)) && !fs.exists(new Path(newPath))) {
                    if(!FileUtil.copy(fs, new Path(currPath), fs, new Path(newPath), false, false, new Configuration())) {
                        throw new IOException("Unable to synchronize versions");
                    }
                }
            }
        }
    }

    /**
     * When updating the prior version:
     *
     * After the version at path has been completed, call this method to copy over any shards that didn't have any records for them
     * and so weren't processed in the MapReduce job.
     */
    public void synchronizeInProgressVersion(String path) throws IOException {
        synchronizeVersions(getFileSystem(), getSpec(), mostRecentVersionPath(), path);
    }

    public void cleanup() throws IOException {
        vs.cleanup();
    }

    public void cleanup(int versionsToKeep) throws IOException {
        vs.cleanup(versionsToKeep);
    }

    public List<Long> getAllVersions() throws IOException {
        return vs.getAllVersions();
    }

    public boolean hasVersion(long version) throws IOException {
        return vs.hasVersion(version);
    }
}
TOP

Related Classes of elephantdb.store.DomainStore

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.