當前位置: 首頁>>代碼示例>>Java>>正文


Java RowConstants類代碼示例

本文整理匯總了Java中org.apache.kylin.cube.kv.RowConstants的典型用法代碼示例。如果您正苦於以下問題:Java RowConstants類的具體用法?Java RowConstants怎麽用?Java RowConstants使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


RowConstants類屬於org.apache.kylin.cube.kv包,在下文中一共展示了RowConstants類的13個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: preparedHBaseScan

import org.apache.kylin.cube.kv.RowConstants; //導入依賴的package包/類
private RawScan preparedHBaseScan(GTRecord pkStart, GTRecord pkEnd, List<GTRecord> fuzzyKeys, ImmutableBitSet selectedColBlocks) {
    final List<Pair<byte[], byte[]>> selectedColumns = makeHBaseColumns(selectedColBlocks);

    LazyRowKeyEncoder encoder = new LazyRowKeyEncoder(cubeSeg, cuboid);
    byte[] start = encoder.createBuf();
    byte[] end = encoder.createBuf();

    encoder.setBlankByte(RowConstants.ROWKEY_LOWER_BYTE);
    encoder.encode(pkStart, pkStart.getInfo().getPrimaryKey(), start);

    encoder.setBlankByte(RowConstants.ROWKEY_UPPER_BYTE);
    encoder.encode(pkEnd, pkEnd.getInfo().getPrimaryKey(), end);
    byte[] temp = new byte[end.length + 1];//append extra 0 to the end key to make it inclusive while scanning
    System.arraycopy(end, 0, temp, 0, end.length);
    end = temp;

    List<Pair<byte[], byte[]>> hbaseFuzzyKeys = translateFuzzyKeys(fuzzyKeys);

    KylinConfig config = cubeSeg.getCubeDesc().getConfig();
    int hbaseCaching = config.getHBaseScanCacheRows();
    int hbaseMaxResultSize = config.getHBaseScanMaxResultSize();
    //        if (isMemoryHungry(selectedColBlocks))
    //            hbaseCaching /= 10;

    return new RawScan(start, end, selectedColumns, hbaseFuzzyKeys, hbaseCaching, hbaseMaxResultSize);
}
 
開發者ID:apache,項目名稱:kylin,代碼行數:27,代碼來源:CubeHBaseRPC.java

示例2: getRowKeysDifferentShards

import org.apache.kylin.cube.kv.RowConstants; //導入依賴的package包/類
private List<byte[]> getRowKeysDifferentShards(byte[] halfCookedKey) {
    final short cuboidShardNum = cubeSeg.getCuboidShardNum(cuboid.getId());

    if (!cubeSeg.isEnableSharding()) {
        return Lists.newArrayList(halfCookedKey);//not shard to append at head, so it is already well cooked
    } else {
        List<byte[]> ret = Lists.newArrayList();
        for (short i = 0; i < cuboidShardNum; ++i) {
            short shard = ShardingHash.normalize(cubeSeg.getCuboidBaseShard(cuboid.getId()), i, cubeSeg.getTotalShards(cuboid.getId()));
            byte[] cookedKey = Arrays.copyOf(halfCookedKey, halfCookedKey.length);
            BytesUtil.writeShort(shard, cookedKey, 0, RowConstants.ROWKEY_SHARDID_LEN);
            ret.add(cookedKey);
        }
        return ret;
    }
}
 
開發者ID:apache,項目名稱:kylin,代碼行數:17,代碼來源:CubeHBaseScanRPC.java

示例3: cleanup

import org.apache.kylin.cube.kv.RowConstants; //導入依賴的package包/類
@Override
protected void cleanup(Context context) throws IOException, InterruptedException {
    List<Integer> keys = new ArrayList<Integer>();
    Iterator<Integer> it = hllcMap.keySet().iterator();
    while (it.hasNext()) {
        keys.add(it.next());
    }
    Collections.sort(keys);
    it = keys.iterator();
    while (it.hasNext()) {
        int key = it.next();
        HyperLogLogPlusCounter hllc = hllcMap.get(key);
        ByteBuffer buf = ByteBuffer.allocate(RowConstants.ROWVALUE_BUFFER_SIZE);
        buf.clear();
        hllc.writeRegisters(buf);
        buf.flip();
        context.write(new IntWritable(key), new LongWritable(hllc.getCountEstimate()));
        // context.write(new Text("ErrorRate_" + key), new
        // LongWritable((long)hllc.getErrorRate()));
    }

}
 
開發者ID:KylinOLAP,項目名稱:Kylin,代碼行數:23,代碼來源:ColumnCardinalityReducer.java

示例4: init

import org.apache.kylin.cube.kv.RowConstants; //導入依賴的package包/類
private void init() {
    int[] offsets = new int[columns.length];
    int o = RowConstants.ROWKEY_CUBOIDID_LEN;
    for (int i = 0; i < columns.length; i++) {
        offsets[i] = o;
        o += columnSizes[i];
    }
    this.columnOffsets = offsets;

    this.columnsAsList = Arrays.asList(columns);

    HashMap<TblColRef, Integer> map = Maps.newHashMap();
    for (int i = 0; i < columns.length; i++) {
        map.put(columns[i], i);
    }
    this.columnIdxMap = map;
}
 
開發者ID:KylinOLAP,項目名稱:Kylin,代碼行數:18,代碼來源:CoprocessorRowType.java

示例5: init

import org.apache.kylin.cube.kv.RowConstants; //導入依賴的package包/類
private void init(Collection<ColumnValueRange> andDimensionRanges) {
    int size = andDimensionRanges.size();
    Map<TblColRef, String> startValues = Maps.newHashMapWithExpectedSize(size);
    Map<TblColRef, String> stopValues = Maps.newHashMapWithExpectedSize(size);
    Map<TblColRef, Set<String>> fuzzyValues = Maps.newHashMapWithExpectedSize(size);
    for (ColumnValueRange dimRange : andDimensionRanges) {
        TblColRef column = dimRange.getColumn();
        startValues.put(column, dimRange.getBeginValue());
        stopValues.put(column, dimRange.getEndValue());
        fuzzyValues.put(column, dimRange.getEqualValues());

        TblColRef partitionDateColumnRef = cubeSeg.getCubeDesc().getModel().getPartitionDesc().getPartitionDateColumnRef();
        if (column.equals(partitionDateColumnRef)) {
            initPartitionRange(dimRange);
        }
    }

    AbstractRowKeyEncoder encoder = new LazyRowKeyEncoder(cubeSeg, cuboid);
    encoder.setBlankByte(RowConstants.ROWKEY_LOWER_BYTE);
    this.startKey = encoder.encode(startValues);
    encoder.setBlankByte(RowConstants.ROWKEY_UPPER_BYTE);
    // In order to make stopRow inclusive add a trailing 0 byte. #See Scan.setStopRow(byte [] stopRow)
    this.stopKey = Bytes.add(encoder.encode(stopValues), ZERO_TAIL_BYTES);

    // always fuzzy match cuboid ID to lock on the selected cuboid
    this.fuzzyKeys = buildFuzzyKeys(fuzzyValues);
}
 
開發者ID:apache,項目名稱:kylin,代碼行數:28,代碼來源:HBaseKeyRange.java

示例6: getSplitsByRegionCount

import org.apache.kylin.cube.kv.RowConstants; //導入依賴的package包/類
private static byte[][] getSplitsByRegionCount(int regionCount) {
    byte[][] result = new byte[regionCount - 1][];
    for (int i = 1; i < regionCount; ++i) {
        byte[] split = new byte[RowConstants.ROWKEY_SHARDID_LEN];
        BytesUtil.writeUnsigned(i, split, 0, RowConstants.ROWKEY_SHARDID_LEN);
        result[i - 1] = split;
    }
    return result;
}
 
開發者ID:apache,項目名稱:kylin,代碼行數:10,代碼來源:CreateHTableJob.java

示例7: cleanup

import org.apache.kylin.cube.kv.RowConstants; //導入依賴的package包/類
@Override
protected void cleanup(Context context) throws IOException, InterruptedException {
    Iterator<Integer> it = hllcMap.keySet().iterator();
    while (it.hasNext()) {
        int key = it.next();
        HyperLogLogPlusCounter hllc = hllcMap.get(key);
        ByteBuffer buf = ByteBuffer.allocate(RowConstants.ROWVALUE_BUFFER_SIZE);
        buf.clear();
        hllc.writeRegisters(buf);
        buf.flip();
        context.write(new IntWritable(key), new BytesWritable(buf.array(), buf.limit()));
    }
}
 
開發者ID:KylinOLAP,項目名稱:Kylin,代碼行數:14,代碼來源:ColumnCardinalityMapper.java

示例8: getBytes

import org.apache.kylin.cube.kv.RowConstants; //導入依賴的package包/類
private byte[] getBytes(String str) throws IOException {
    HyperLogLogPlusCounter hllc = new HyperLogLogPlusCounter();
    StringTokenizer tokenizer = new StringTokenizer(str, ColumnCardinalityMapper.DEFAULT_DELIM);
    int i = 0;
    while (tokenizer.hasMoreTokens()) {
        String temp = i + "_" + tokenizer.nextToken();
        i++;
        hllc.add(Bytes.toBytes(temp));
    }
    ByteBuffer buf = ByteBuffer.allocate(RowConstants.ROWVALUE_BUFFER_SIZE);
    buf.clear();
    hllc.writeRegisters(buf);
    buf.flip();
    return buf.array();
}
 
開發者ID:KylinOLAP,項目名稱:Kylin,代碼行數:16,代碼來源:ColumnCardinalityReducerTest.java

示例9: basicTest

import org.apache.kylin.cube.kv.RowConstants; //導入依賴的package包/類
@Test
public void basicTest() {
    MeasureDesc descs[] = new MeasureDesc[] { measure("double"), measure("long"), measure("decimal"), measure("HLLC16"), measure("HLLC16") };
    MeasureCodec codec = new MeasureCodec(descs);

    DoubleWritable d = new DoubleWritable(1.0);
    LongWritable l = new LongWritable(2);
    BigDecimal b = new BigDecimal("333.1234567");
    HyperLogLogPlusCounter hllc = new HyperLogLogPlusCounter(16);
    hllc.add("1234567");
    hllc.add("abcdefg");
    HyperLogLogPlusCounter hllc2 = new HyperLogLogPlusCounter(16);
    hllc.add("1234567");
    hllc.add("abcdefg");
    Object values[] = new Object[] { d, l, b, hllc, hllc2 };

    ByteBuffer buf = ByteBuffer.allocate(RowConstants.ROWVALUE_BUFFER_SIZE);

    codec.encode(values, buf);
    buf.flip();
    System.out.println("size: " + buf.limit());

    Object copy[] = new Object[values.length];
    codec.decode(buf, copy);

    assertTrue(Arrays.equals(values, copy));
}
 
開發者ID:KylinOLAP,項目名稱:Kylin,代碼行數:28,代碼來源:MeasureCodecTest.java

示例10: init

import org.apache.kylin.cube.kv.RowConstants; //導入依賴的package包/類
private void init(Collection<ColumnValueRange> andDimensionRanges) {
    int size = andDimensionRanges.size();
    Map<TblColRef, String> startValues = Maps.newHashMapWithExpectedSize(size);
    Map<TblColRef, String> stopValues = Maps.newHashMapWithExpectedSize(size);
    Map<TblColRef, Set<String>> fuzzyValues = Maps.newHashMapWithExpectedSize(size);
    for (ColumnValueRange dimRange : andDimensionRanges) {
        TblColRef column = dimRange.getColumn();
        startValues.put(column, dimRange.getBeginValue());
        stopValues.put(column, dimRange.getEndValue());
        fuzzyValues.put(column, dimRange.getEqualValues());

        TblColRef partitionDateColumnRef = cubeSeg.getCubeDesc().getModel().getPartitionDesc().getPartitionDateColumnRef();
        if (column.equals(partitionDateColumnRef)) {
            initPartitionRange(dimRange);
        }
    }

    AbstractRowKeyEncoder encoder = AbstractRowKeyEncoder.createInstance(cubeSeg, cuboid);

    encoder.setBlankByte(RowConstants.ROWKEY_LOWER_BYTE);

    this.startKey = encoder.encode(startValues);

    encoder.setBlankByte(RowConstants.ROWKEY_UPPER_BYTE);

    // In order to make stopRow inclusive add a trailing 0 byte. #See
    // Scan.setStopRow(byte [] stopRow)
    this.stopKey = Bytes.add(encoder.encode(stopValues), ZERO_TAIL_BYTES);

    // restore encoder defaults for later reuse (note
    // AbstractRowKeyEncoder.createInstance() caches instances)
    encoder.setBlankByte(AbstractRowKeyEncoder.DEFAULT_BLANK_BYTE);

    // always fuzzy match cuboid ID to lock on the selected cuboid
    this.fuzzyKeys = buildFuzzyKeys(fuzzyValues);
}
 
開發者ID:KylinOLAP,項目名稱:Kylin,代碼行數:37,代碼來源:HBaseKeyRange.java

示例11: doSetup

import org.apache.kylin.cube.kv.RowConstants; //導入依賴的package包/類
@Override
protected void doSetup(Context context) throws IOException, InterruptedException {
    super.bindCurrentConfiguration(context.getConfiguration());

    cubeName = context.getConfiguration().get(BatchConstants.CFG_CUBE_NAME);
    segmentID = context.getConfiguration().get(BatchConstants.CFG_CUBE_SEGMENT_ID);

    config = AbstractHadoopJob.loadKylinPropsAndMetadata();

    cubeManager = CubeManager.getInstance(config);
    cube = cubeManager.getCube(cubeName);
    cubeDesc = cube.getDescriptor();
    mergedCubeSegment = cube.getSegmentById(segmentID);

    // int colCount = cubeDesc.getRowkey().getRowKeyColumns().length;
    newKeyBodyBuf = new byte[RowConstants.ROWKEY_BUFFER_SIZE];// size will auto-grow
    newKeyBuf = ByteArray.allocate(RowConstants.ROWKEY_BUFFER_SIZE);

    // decide which source segment
    FileSplit fileSplit = (FileSplit) context.getInputSplit();
    IMROutput2.IMRMergeOutputFormat outputFormat = MRUtil.getBatchMergeOutputSide2(mergedCubeSegment).getOuputFormat();
    sourceCubeSegment = outputFormat.findSourceSegment(fileSplit, cube);

    rowKeySplitter = new RowKeySplitter(sourceCubeSegment, 65, 255);
    rowKeyEncoderProvider = new RowKeyEncoderProvider(mergedCubeSegment);

    measureDescs = cubeDesc.getMeasures();
    codec = new BufferedMeasureCodec(measureDescs);
    measureObjs = new Object[measureDescs.size()];
    outputValue = new Text();

    dictMeasures = Lists.newArrayList();
    oldDicts = Maps.newHashMap();
    newDicts = Maps.newHashMap();
    for (int i = 0; i < measureDescs.size(); i++) {
        MeasureDesc measureDesc = measureDescs.get(i);
        MeasureType measureType = measureDesc.getFunction().getMeasureType();
        List<TblColRef> columns = measureType.getColumnsNeedDictionary(measureDesc.getFunction());
        boolean needReEncode = false;
        for (TblColRef col : columns) {
            //handle the column that all records is null
            if (sourceCubeSegment.getDictionary(col) == null) {
                continue;
            }

            oldDicts.put(col, sourceCubeSegment.getDictionary(col));
            newDicts.put(col, mergedCubeSegment.getDictionary(col));
            if (!sourceCubeSegment.getDictionary(col).equals(mergedCubeSegment.getDictionary(col))) {
                needReEncode = true;
            }
        }
        if (needReEncode) {
            dictMeasures.add(Pair.newPair(i, measureType.newIngester()));
        }
    }
}
 
開發者ID:apache,項目名稱:kylin,代碼行數:57,代碼來源:MergeCuboidMapper.java

示例12: testMapReduceWithSlr

import org.apache.kylin.cube.kv.RowConstants; //導入依賴的package包/類
@Ignore
@Test
public void testMapReduceWithSlr() throws IOException {

    String cubeName = "test_kylin_cube_with_slr_1_new_segment";
    String segmentID = "198va32a-a33e-4b69-83dd-0bb8b1f8c53b";
    mapReduceDriver.getConfiguration().set(BatchConstants.CFG_CUBE_NAME, cubeName);
    mapReduceDriver.getConfiguration().set(BatchConstants.CFG_CUBE_SEGMENT_ID, segmentID);

    byte[] key = { 0, 0, 0, 0, 0, 0, 0, 0, 1, -1, 0, -104, -106, -128, 11, 54, -105, 55, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 13, 71, 114, 65, 66, 73, 78, 9, 9, 9, 9, 9, 9, 9, 9, 0, 10, 0 };
    byte[] value = { 14, 7, 23, -16, 56, 92, 114, -80, 118, 14, 7, 23, -16, 56, 92, 114, -80, 118, 14, 7, 23, -16, 56, 92, 114, -80, 118, 1, 1 };
    Pair<Text, Text> input1 = new Pair<Text, Text>(new Text(key), new Text(value));

    mapReduceDriver.addInput(input1);

    List<Pair<Text, Text>> result = mapReduceDriver.run();

    assertEquals(4, result.size());

    byte[] resultKey = { 0, 0, 0, 0, 0, 0, 0, 0, 1, 127, 0, -104, -106, -128, 55, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 13, 71, 114, 65, 66, 73, 78, 9, 9, 9, 9, 9, 9, 9, 9, 0, 10, 0 };
    byte[] resultValue = { 14, 7, 23, -16, 56, 92, 114, -80, 118, 14, 7, 23, -16, 56, 92, 114, -80, 118, 14, 7, 23, -16, 56, 92, 114, -80, 118, 1, 1 };
    Pair<Text, Text> output1 = new Pair<Text, Text>(new Text(resultKey), new Text(resultValue));

    //As we will truncate decimal(KYLIN-766), value will no longer equals to resultValue
    Collection<Text> keys = Collections2.transform(result, new Function<Pair<Text, Text>, Text>() {
        @Nullable
        @Override
        public Text apply(Pair<Text, Text> input) {
            return input.getFirst();
        }
    });
    assertTrue(keys.contains(output1.getFirst()));
    assertTrue(!result.contains(output1));

    long[] keySet = new long[result.size()];

    System.out.println(Bytes.toLong(new byte[] { 0, 0, 0, 0, 0, 0, 1, -1 }));
    for (int i = 0; i < result.size(); i++) {
        byte[] bytes = new byte[result.get(i).getFirst().getLength()];
        System.arraycopy(result.get(i).getFirst().getBytes(), RowConstants.ROWKEY_SHARDID_LEN, bytes, 0, result.get(i).getFirst().getLength() - RowConstants.ROWKEY_SHARDID_LEN);
        System.out.println(Bytes.toLong(bytes));
        keySet[i] = Bytes.toLong(bytes);
    }

    // refer to CuboidSchedulerTest.testGetSpanningCuboid()
    assertArrayEquals(new long[] { 383, 447, 503, 504 }, keySet);

}
 
開發者ID:apache,項目名稱:kylin,代碼行數:49,代碼來源:NDCuboidMapperTest.java

示例13: getRowKeyPreambleSize

import org.apache.kylin.cube.kv.RowConstants; //導入依賴的package包/類
public int getRowKeyPreambleSize() {
    return isEnableSharding() ? RowConstants.ROWKEY_SHARD_AND_CUBOID_LEN : RowConstants.ROWKEY_CUBOIDID_LEN;
}
 
開發者ID:apache,項目名稱:kylin,代碼行數:4,代碼來源:CubeSegment.java


注:本文中的org.apache.kylin.cube.kv.RowConstants類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。