Search in sources :

Example 1 with CachedObjectWrapper

use of org.solbase.cache.CachedObjectWrapper in project Solbase by Photobucket.

the class ShardDocumentLoader method loadObject.

public CachedObjectWrapper<Document, Long> loadObject(String docIdKey, int start, int end, LayeredCache<String, Document, Long, Document> cache) throws IOException {
    Document document = new Document();
    // TODO should probably get SchemaField from Schema object.
    String keyField = "docId";
    Field field = new Field(keyField, this.parseDocIdFromKey(docIdKey), Store.YES, Index.ANALYZED);
    document.add(field);
    // TODO, get from result
    Long versionIdentifier = 0l;
    return new CachedObjectWrapper<Document, Long>(document, versionIdentifier, System.currentTimeMillis());
}
Also used : CachedObjectWrapper(org.solbase.cache.CachedObjectWrapper) Field(org.apache.lucene.document.Field) Document(org.apache.lucene.document.Document)

Example 2 with CachedObjectWrapper

use of org.solbase.cache.CachedObjectWrapper in project Solbase by Photobucket.

the class TermDocMetadataLoader method loadObject.

public CachedObjectWrapper<CompactedTermDocMetadataArray, TermDocMetadataVersionIdentifier> loadObject(Term term, int start, int end, LayeredCache<Term, CompactedTermDocMetadataArray, TermDocMetadataVersionIdentifier, TermDocMetadata> cache) throws IOException {
    HTableInterface termVectorTable = SolbaseUtil.getTermVectorTable();
    try {
        byte[] termBeginKey = SolbaseUtil.generateTermKey(term, start);
        byte[] termEndKey;
        if (end > SolbaseShardUtil.getMaxDocId()) {
            // in case, we are in last shard, our end key is always get start from \xff\xff\xff\xff
            // meaning fetch remaining docs.
            termEndKey = SolbaseUtil.generateTermEndKey(term);
        } else {
            termEndKey = SolbaseUtil.generateTermKey(term, end);
        }
        Scan fieldScan = new Scan(termBeginKey, termEndKey);
        fieldScan.addFamily(SolbaseUtil.termVectorDocColumnFamilyName);
        fieldScan.setBatch(2000);
        fieldScan.setCaching(2000);
        ResultScanner fieldScanner = termVectorTable.getScanner(fieldScan);
        Result termDoc;
        ByteArrayOutputStream bis = new ByteArrayOutputStream();
        int docAmount = 0;
        while ((termDoc = fieldScanner.next()) != null) {
            if (storageType == STORAGE_TYPE.WIDE_ROW) {
                convertResultChunkToTermDoc(termDoc, bis);
            } else {
                convertResultToTermDoc(termDoc, bis);
                docAmount++;
            }
        }
        fieldScanner.close();
        logger.info("Read from HBase for term: " + term.toString() + " has this many docs: " + docAmount);
        // TODO LOAD VERSION
        TermDocMetadataVersionIdentifier versionIdentifier = getVersionIdentifier(term, start, end);
        return new CachedObjectWrapper<CompactedTermDocMetadataArray, TermDocMetadataVersionIdentifier>(new CompactedTermDocMetadataArray(bis, docAmount), versionIdentifier, System.currentTimeMillis());
    } finally {
        SolbaseUtil.releaseTable(termVectorTable);
    }
}
Also used : CachedObjectWrapper(org.solbase.cache.CachedObjectWrapper) ResultScanner(org.apache.hadoop.hbase.client.ResultScanner) Scan(org.apache.hadoop.hbase.client.Scan) ByteArrayOutputStream(java.io.ByteArrayOutputStream) HTableInterface(org.apache.hadoop.hbase.client.HTableInterface) Result(org.apache.hadoop.hbase.client.Result)

Example 3 with CachedObjectWrapper

use of org.solbase.cache.CachedObjectWrapper in project Solbase by Photobucket.

the class DocumentLoader method loadObject.

public CachedObjectWrapper<Document, Long> loadObject(Integer docNum, int start, int end, LayeredCache<Integer, Document, Long, ParsedDoc> cache) throws IOException {
    Document document = new Document();
    Get documentGet = new Get(SolbaseUtil.randomize(docNum));
    if (fieldNames == null || fieldNames.size() == 0) {
        // get all columns ( except this skips meta info )
        documentGet.addFamily(Bytes.toBytes("field"));
    } else {
        for (byte[] fieldName : fieldNames) {
            documentGet.addColumn(Bytes.toBytes("field"), fieldName);
        }
    }
    Result documentResult = null;
    // if docTable is set up, reuse instance, otherwise create brand new one and close after done
    if (this.docTable == null) {
        HTableInterface docTable = null;
        try {
            docTable = SolbaseUtil.getDocTable();
            documentResult = docTable.get(documentGet);
        } finally {
            SolbaseUtil.releaseTable(docTable);
        }
    } else {
        documentResult = this.docTable.get(documentGet);
    }
    if (documentResult == null || documentResult.isEmpty()) {
        return null;
    }
    // TODO, get from result
    Long versionIdentifier = 0l;
    NavigableMap<byte[], byte[]> familyMap = documentResult.getFamilyMap(Bytes.toBytes("field"));
    for (Map.Entry<byte[], byte[]> fieldColumn : familyMap.entrySet()) {
        Field field = null;
        String fieldName = Bytes.toString(fieldColumn.getKey());
        byte[] value;
        ByteBuffer v = ByteBuffer.wrap(fieldColumn.getValue());
        int vlimit = v.limit() + v.arrayOffset();
        if (v.array()[vlimit - 1] != Byte.MAX_VALUE && v.array()[vlimit - 1] != Byte.MIN_VALUE) {
            throw new CorruptIndexException("Solbase field is not properly encoded: " + docNum + "(" + fieldName + ")");
        } else if (v.array()[vlimit - 1] == Byte.MAX_VALUE) {
            // Binary
            value = new byte[vlimit - 1];
            System.arraycopy(v.array(), v.position() + v.arrayOffset(), value, 0, vlimit - 1);
            field = new Field(fieldName, value, Store.YES);
            document.add(field);
        } else if (v.array()[vlimit - 1] == Byte.MIN_VALUE) {
            // String
            value = new byte[vlimit - 1];
            System.arraycopy(v.array(), v.position() + v.arrayOffset(), value, 0, vlimit - 1);
            // Check for multi-fields
            String fieldString = new String(value, "UTF-8");
            if (fieldString.indexOf(Bytes.toString(SolbaseUtil.delimiter)) >= 0) {
                StringTokenizer tok = new StringTokenizer(fieldString, Bytes.toString(SolbaseUtil.delimiter));
                while (tok.hasMoreTokens()) {
                    // update logic
                    if (schema != null) {
                        SchemaField sfield = schema.getFieldOrNull(fieldName);
                        if (sfield.getType() instanceof EmbeddedIndexedIntField) {
                            EmbeddedIndexedIntField eiif = (EmbeddedIndexedIntField) sfield.getType();
                            EmbeddedSortField sf = new EmbeddedSortField(fieldName, tok.nextToken(), Field.Store.YES, Field.Index.NO, eiif.getFieldNumber());
                            document.add(sf);
                        } else {
                            Field f = sfield.createField(tok.nextToken(), 1.0f);
                            if (f != null) {
                                // null fields are not added
                                document.add(f);
                            }
                        }
                    } else {
                        field = new Field(fieldName, tok.nextToken(), Store.YES, Index.ANALYZED);
                        document.add(field);
                    }
                }
            } else {
                // update logic
                if (schema != null) {
                    SchemaField sfield = schema.getFieldOrNull(fieldName);
                    if (sfield.getType() instanceof EmbeddedIndexedIntField) {
                        EmbeddedIndexedIntField eiif = (EmbeddedIndexedIntField) sfield.getType();
                        EmbeddedSortField sf = new EmbeddedSortField(fieldName, fieldString, Field.Store.YES, Field.Index.NO, eiif.getFieldNumber());
                        document.add(sf);
                    } else {
                        Field f = sfield.createField(fieldString, 1.0f);
                        if (f != null) {
                            // null fields are not added
                            document.add(f);
                        }
                    }
                } else {
                    field = new Field(fieldName, fieldString, Store.YES, Index.ANALYZED);
                    document.add(field);
                }
            }
        }
    }
    return new CachedObjectWrapper<Document, Long>(document, versionIdentifier, System.currentTimeMillis());
}
Also used : CachedObjectWrapper(org.solbase.cache.CachedObjectWrapper) CorruptIndexException(org.apache.lucene.index.CorruptIndexException) EmbeddedSortField(org.apache.lucene.document.EmbeddedSortField) Document(org.apache.lucene.document.Document) SolrInputDocument(org.apache.solr.common.SolrInputDocument) HTableInterface(org.apache.hadoop.hbase.client.HTableInterface) ByteBuffer(java.nio.ByteBuffer) Result(org.apache.hadoop.hbase.client.Result) SchemaField(org.apache.solr.schema.SchemaField) EmbeddedIndexedIntField(org.apache.solr.schema.EmbeddedIndexedIntField) SchemaField(org.apache.solr.schema.SchemaField) Field(org.apache.lucene.document.Field) EmbeddedSortField(org.apache.lucene.document.EmbeddedSortField) StringTokenizer(java.util.StringTokenizer) Get(org.apache.hadoop.hbase.client.Get) Map(java.util.Map) NavigableMap(java.util.NavigableMap) EmbeddedIndexedIntField(org.apache.solr.schema.EmbeddedIndexedIntField)

Aggregations

CachedObjectWrapper (org.solbase.cache.CachedObjectWrapper)3 HTableInterface (org.apache.hadoop.hbase.client.HTableInterface)2 Result (org.apache.hadoop.hbase.client.Result)2 Document (org.apache.lucene.document.Document)2 Field (org.apache.lucene.document.Field)2 ByteArrayOutputStream (java.io.ByteArrayOutputStream)1 ByteBuffer (java.nio.ByteBuffer)1 Map (java.util.Map)1 NavigableMap (java.util.NavigableMap)1 StringTokenizer (java.util.StringTokenizer)1 Get (org.apache.hadoop.hbase.client.Get)1 ResultScanner (org.apache.hadoop.hbase.client.ResultScanner)1 Scan (org.apache.hadoop.hbase.client.Scan)1 EmbeddedSortField (org.apache.lucene.document.EmbeddedSortField)1 CorruptIndexException (org.apache.lucene.index.CorruptIndexException)1 SolrInputDocument (org.apache.solr.common.SolrInputDocument)1 EmbeddedIndexedIntField (org.apache.solr.schema.EmbeddedIndexedIntField)1 SchemaField (org.apache.solr.schema.SchemaField)1