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

com.uber.hoodie.index.InMemoryHashIndex Maven / Gradle / Ivy

There is a newer version: 0.4.7
Show newest version
/*
 * Copyright (c) 2016 Uber Technologies, Inc. ([email protected])
 *
 * 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 com.uber.hoodie.index;

import com.google.common.base.Optional;
import com.uber.hoodie.common.table.HoodieTableMetaClient;
import com.uber.hoodie.config.HoodieWriteConfig;
import com.uber.hoodie.WriteStatus;
import com.uber.hoodie.common.model.HoodieKey;
import com.uber.hoodie.common.model.HoodieRecord;
import com.uber.hoodie.common.model.HoodieRecordLocation;
import com.uber.hoodie.common.model.HoodieRecordPayload;

import com.uber.hoodie.table.HoodieTable;
import org.apache.spark.api.java.JavaPairRDD;
import org.apache.spark.api.java.JavaRDD;
import org.apache.spark.api.java.JavaSparkContext;
import org.apache.spark.api.java.function.Function;
import org.apache.spark.api.java.function.Function2;

import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
import java.util.concurrent.ConcurrentHashMap;
import java.util.concurrent.ConcurrentMap;


/**
 * Hoodie Index implementation backed by an in-memory Hash map.
 * 

* ONLY USE FOR LOCAL TESTING */ public class InMemoryHashIndex extends HoodieIndex { private static ConcurrentMap recordLocationMap; public InMemoryHashIndex(HoodieWriteConfig config, JavaSparkContext jsc) { super(config, jsc); recordLocationMap = new ConcurrentHashMap<>(); } @Override public JavaPairRDD> fetchRecordLocation( JavaRDD hoodieKeys, final HoodieTable table) { throw new UnsupportedOperationException("InMemory index does not implement check exist yet"); } /** * Function that tags each HoodieRecord with an existing location, if known. */ class LocationTagFunction implements Function2>, Iterator>> { @Override public Iterator> call(Integer partitionNum, Iterator> hoodieRecordIterator) { List> taggedRecords = new ArrayList<>(); while (hoodieRecordIterator.hasNext()) { HoodieRecord rec = hoodieRecordIterator.next(); if (recordLocationMap.containsKey(rec.getKey())) { rec.setCurrentLocation(recordLocationMap.get(rec.getKey())); } taggedRecords.add(rec); } return taggedRecords.iterator(); } } @Override public JavaRDD> tagLocation(JavaRDD> recordRDD, HoodieTable hoodieTable) { return recordRDD.mapPartitionsWithIndex(this.new LocationTagFunction(), true); } @Override public JavaRDD updateLocation(JavaRDD writeStatusRDD, HoodieTable hoodieTable) { return writeStatusRDD.map(new Function() { @Override public WriteStatus call(WriteStatus writeStatus) { for (HoodieRecord record : writeStatus.getWrittenRecords()) { if (!writeStatus.isErrored(record.getKey())) { HoodieKey key = record.getKey(); java.util.Optional newLocation = record.getNewLocation(); if (newLocation.isPresent()) { recordLocationMap.put(key, newLocation.get()); } else { //Delete existing index for a deleted record recordLocationMap.remove(key); } } } return writeStatus; } }); } @Override public boolean rollbackCommit(String commitTime) { return true; } /** * Only looks up by recordKey * * @return */ @Override public boolean isGlobal() { return true; } /** * Mapping is available in HBase already. * * @return */ @Override public boolean canIndexLogFiles() { return true; } /** * Index needs to be explicitly updated after storage write. * * @return */ @Override public boolean isImplicitWithStorage() { return false; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy