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


Java ReflectData類代碼示例

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


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

示例1: createFlatAvroSchema

import org.apache.avro.reflect.ReflectData; //導入依賴的package包/類
/**
 * Creates a flat Avro Schema for testing.
 */
public static Schema createFlatAvroSchema(String[] fieldNames, TypeInformation[] fieldTypes) {
	final SchemaBuilder.FieldAssembler<Schema> fieldAssembler = SchemaBuilder
		.record("BasicAvroRecord")
		.namespace(NAMESPACE)
		.fields();

	final Schema nullSchema = Schema.create(Schema.Type.NULL);

	for (int i = 0; i < fieldNames.length; i++) {
		Schema schema = ReflectData.get().getSchema(fieldTypes[i].getTypeClass());
		Schema unionSchema = Schema.createUnion(Arrays.asList(nullSchema, schema));
		fieldAssembler.name(fieldNames[i]).type(unionSchema).noDefault();
	}

	return fieldAssembler.endRecord();
}
 
開發者ID:axbaretto,項目名稱:flink,代碼行數:20,代碼來源:AvroTestUtils.java

示例2: testReflect

import org.apache.avro.reflect.ReflectData; //導入依賴的package包/類
public static void testReflect(Object value, Type type, String schema)
  throws Exception {

  // check that schema matches expected
  Schema s = ReflectData.get().getSchema(type);
  assertEquals(Schema.parse(schema), s);

  // check that value is serialized correctly
  ReflectDatumWriter<Object> writer = new ReflectDatumWriter<Object>(s);
  ByteArrayOutputStream out = new ByteArrayOutputStream();
  writer.write(value, EncoderFactory.get().directBinaryEncoder(out, null));
  ReflectDatumReader<Object> reader = new ReflectDatumReader<Object>(s);
  Object after =
    reader.read(null,
                DecoderFactory.get().binaryDecoder(out.toByteArray(), null));
  assertEquals(value, after);
}
 
開發者ID:naver,項目名稱:hadoop,代碼行數:18,代碼來源:AvroTestUtil.java

示例3: readIndividualsFromFile

import org.apache.avro.reflect.ReflectData; //導入依賴的package包/類
public static List<IndividualWrapper<Individual, FitnessValue>> readIndividualsFromFile(
        Path filePath, Configuration configuration) throws IOException {
    List<IndividualWrapper<Individual, FitnessValue>> result =
            new ArrayList<IndividualWrapper<Individual, FitnessValue>>();

    SeekableInput seekableFileInput = new FsInput(filePath, configuration);
    ReflectData reflectData = new ReflectData(configuration.getClassLoader());
    DatumReader<IndividualWrapper<Individual, FitnessValue>> datumReader = new ReflectDatumReader<IndividualWrapper<Individual, FitnessValue>>(reflectData);
    DataFileReader<IndividualWrapper<Individual, FitnessValue>> avroFileReader =
            new DataFileReader<IndividualWrapper<Individual, FitnessValue>>(seekableFileInput, datumReader);

    for (IndividualWrapper<Individual, FitnessValue> individualWrapper : avroFileReader)
        result.add(individualWrapper);

    avroFileReader.close();
    return result;
}
 
開發者ID:pasqualesalza,項目名稱:elephant56,代碼行數:18,代碼來源:Driver.java

示例4: fromBytes

import org.apache.avro.reflect.ReflectData; //導入依賴的package包/類
@SuppressWarnings("unchecked")
public static <T> T fromBytes( byte[] val, Schema schema
    , SpecificDatumReader<T> datumReader, T object)
throws IOException {
  Type type = schema.getType();
  switch (type) {
  case ENUM:
    String symbol = schema.getEnumSymbols().get(val[0]);
    return (T)Enum.valueOf(ReflectData.get().getClass(schema), symbol);
  case STRING:  return (T)new Utf8(toString(val));
  case BYTES:   return (T)ByteBuffer.wrap(val);
  case INT:     return (T)Integer.valueOf(bytesToVint(val));
  case LONG:    return (T)Long.valueOf(bytesToVlong(val));
  case FLOAT:   return (T)Float.valueOf(toFloat(val));
  case DOUBLE:  return (T)Double.valueOf(toDouble(val));
  case BOOLEAN: return (T)Boolean.valueOf(val[0] != 0);
  case RECORD:  //fall
  case MAP:
  case ARRAY:   return (T)IOUtils.deserialize(val, (SpecificDatumReader<SpecificRecord>)datumReader, schema, (SpecificRecord)object);
  default: throw new RuntimeException("Unknown type: "+type);
  }
}
 
開發者ID:jianglibo,項目名稱:gora-boot,代碼行數:23,代碼來源:ByteUtils.java

示例5: getSchema

import org.apache.avro.reflect.ReflectData; //導入依賴的package包/類
private Schema  getSchema(Object payload){
	Schema schema = null;
	logger.debug("Obtaining schema for class {}", payload.getClass());
	if(GenericContainer.class.isAssignableFrom(payload.getClass())) {
		schema = ((GenericContainer) payload).getSchema();
		logger.debug("Avro type detected, using schema from object");
	}else{
		Integer id = localSchemaMap.get(payload.getClass().getName());
		if(id == null){
			if(!properties.isDynamicSchemaGenerationEnabled()) {
				throw new SchemaNotFoundException(String.format("No schema found on local cache for %s", payload.getClass()));
			}
			else{
				Schema localSchema = ReflectData.get().getSchema(payload.getClass());
				id = schemaRegistryClient.register(localSchema);
			}

		}
		schema = schemaRegistryClient.fetch(id);
	}

	return schema;
}
 
開發者ID:viniciusccarvalho,項目名稱:schema-evolution-samples,代碼行數:24,代碼來源:AvroCodec.java

示例6: dynamicReflectEncoderReflectDecoder

import org.apache.avro.reflect.ReflectData; //導入依賴的package包/類
@Test
public void dynamicReflectEncoderReflectDecoder() throws Exception{
	Schema schema = ReflectData.get().getSchema(Account.class);
	SchemaRegistryClient client = mock(SchemaRegistryClient.class);
	when(client.register(any())).thenReturn(10);
	when(client.fetch(eq(10))).thenReturn(schema);
	AvroCodec codec = new AvroCodec();
	AvroCodecProperties properties = new AvroCodecProperties();
	properties.setDynamicSchemaGenerationEnabled(true);
	codec.setProperties(properties);
	codec.setSchemaRegistryClient(client);
	codec.setResolver(new PathMatchingResourcePatternResolver(new AnnotationConfigApplicationContext()));
	codec.init();
	Account account = new Account();
	account.setCreatedAt(System.currentTimeMillis());
	account.setId(1L);
	byte[] results = codec.encode(account);
	Account decoded = codec.decode(results,Account.class);
	Assert.assertEquals(account.getId(), decoded.getId());
}
 
開發者ID:viniciusccarvalho,項目名稱:schema-evolution-samples,代碼行數:21,代碼來源:AvroCodecTests.java

示例7: testCreationWithSchema

import org.apache.avro.reflect.ReflectData; //導入依賴的package包/類
@Test
public void testCreationWithSchema() throws Exception {
  List<Bird> expected = createRandomRecords(100);
  String filename = generateTestFile("tmp.avro", expected, SyncBehavior.SYNC_DEFAULT, 0,
      AvroCoder.of(Bird.class), DataFileConstants.NULL_CODEC);

  // Create a source with a schema object
  Schema schema = ReflectData.get().getSchema(Bird.class);
  AvroSource<GenericRecord> source = AvroSource.from(filename).withSchema(schema);
  List<GenericRecord> records = SourceTestUtils.readFromSource(source, null);
  assertEqualsWithGeneric(expected, records);

  // Create a source with a JSON schema
  String schemaString = ReflectData.get().getSchema(Bird.class).toString();
  source = AvroSource.from(filename).withSchema(schemaString);
  records = SourceTestUtils.readFromSource(source, null);
  assertEqualsWithGeneric(expected, records);
}
 
開發者ID:apache,項目名稱:beam,代碼行數:19,代碼來源:AvroSourceTest.java

示例8: initializeAvro

import org.apache.avro.reflect.ReflectData; //導入依賴的package包/類
private void initializeAvro() {
	final ClassLoader cl = Thread.currentThread().getContextClassLoader();

	if (SpecificRecord.class.isAssignableFrom(type)) {
		this.avroData = new SpecificData(cl);
		this.schema = this.avroData.getSchema(type);
		this.reader = new SpecificDatumReader<>(schema, schema, avroData);
		this.writer = new SpecificDatumWriter<>(schema, avroData);
	}
	else {
		final ReflectData reflectData = new ReflectData(cl);
		this.avroData = reflectData;
		this.schema = this.avroData.getSchema(type);
		this.reader = new ReflectDatumReader<>(schema, schema, reflectData);
		this.writer = new ReflectDatumWriter<>(schema, reflectData);
	}

	this.encoder = new DataOutputEncoder();
	this.decoder = new DataInputDecoder();
}
 
開發者ID:axbaretto,項目名稱:flink,代碼行數:21,代碼來源:AvroSerializer.java

示例9: testWriteAVROFileGenericRecord

import org.apache.avro.reflect.ReflectData; //導入依賴的package包/類
@Test
public void testWriteAVROFileGenericRecord() {

    try {
        //Creation of EnrichedEventBody
        EnrichedEventBody enrichedEventBody = createEnrichedEventBody();

        //Get schema from EnrichedEventBody class
        Schema schema = ReflectData.get().getSchema(EnrichedEventBody.class);

        //Transform EnrichedEventBody object to GenericRecord object
        GenericRecord genericRecord = SerializationUtils.enrichedEventBody2GenericRecord(enrichedEventBody, schema);

        //Serialization of GenericRecord object into a AVRO file
        File fileAvro = new File("fileAvro1.avro");
        SerializationUtils.writeAVROFile(fileAvro, schema, genericRecord);


    } catch (Exception e) {
        e.printStackTrace();
        Assert.fail("Unexpected exception in testWriteAVROFileGenericRecord");
    }

}
 
開發者ID:keedio,項目名稱:flume-enrichment-interceptor-skeleton,代碼行數:25,代碼來源:SerializationUtilsTest.java

示例10: testWriteAVROFileGenericRecordCodec

import org.apache.avro.reflect.ReflectData; //導入依賴的package包/類
@Test
public void testWriteAVROFileGenericRecordCodec() {

    try {
        //Creation of EnrichedEventBody
        EnrichedEventBody enrichedEventBody = createEnrichedEventBody();

        //Get schema from EnrichedEventBody class
        Schema schema = ReflectData.get().getSchema(EnrichedEventBody.class);

        //Transform EnrichedEventBody object to GenericRecord object
        GenericRecord genericRecord = SerializationUtils.enrichedEventBody2GenericRecord(enrichedEventBody, schema);

        //Serialization of GenericRecord object into a AVRO file (with snappy codec)
        File fileAvro = new File("fileAvro2.avro");
        SerializationUtils.writeAVROFile(fileAvro, schema, genericRecord, CodecFactory.snappyCodec());

    } catch (Exception e) {
        e.printStackTrace();
        Assert.fail("Unexpected exception in testWriteAVROFileGenericRecordCodec");
    }

}
 
開發者ID:keedio,項目名稱:flume-enrichment-interceptor-skeleton,代碼行數:24,代碼來源:SerializationUtilsTest.java

示例11: serialise

import org.apache.avro.reflect.ReflectData; //導入依賴的package包/類
@Override
public byte[] serialise(final Object object) throws SerialisationException {
    Schema schema = ReflectData.get().getSchema(object.getClass());
    DatumWriter<Object> datumWriter = new ReflectDatumWriter<>(schema);
    DataFileWriter<Object> dataFileWriter = new DataFileWriter<>(datumWriter);
    ByteArrayOutputStream byteOut = new ByteArrayOutputStream();
    try {
        dataFileWriter.create(schema, byteOut);
        dataFileWriter.append(object);
        dataFileWriter.flush();
    } catch (final IOException e) {
        throw new SerialisationException("Unable to serialise given object of class: " + object.getClass().getName(), e);
    } finally {
        close(dataFileWriter);
    }
    return byteOut.toByteArray();
}
 
開發者ID:gchq,項目名稱:Gaffer,代碼行數:18,代碼來源:AvroSerialiser.java

示例12: init

import org.apache.avro.reflect.ReflectData; //導入依賴的package包/類
private void init(String path) throws Exception {
        Configuration conf = new Configuration();
        conf.set("fs.defaultFS", "hdfs://localhost:8020");
        DatasetRepository datasetRepository = new FileSystemDatasetRepository.Builder()
                .rootDirectory(new URI(path)).configuration(conf).build();
        Schema schema = ReflectData.get().getSchema(FileInfo.class);
//        PartitionStrategy partitionStrategy = new PartitionStrategy.Builder().hash("pkey", "HASH", 5).build();
        PartitionStrategy partitionStrategy = new PartitionStrategy.Builder().identity("pkey", "ID", 10).build();
        DatasetDescriptor descriptor = new DatasetDescriptor.Builder()
                .schema(schema)
                .format(Formats.AVRO)
                .partitionStrategy(partitionStrategy)
                .build();
        Dataset<FileInfo> dataset = datasetRepository.create("fileinfo", descriptor);
        writer = dataset.newWriter();
        System.out.println("** USING: " + writer);
        writer.open();
    }
 
開發者ID:trisberg,項目名稱:hdfs-examples,代碼行數:19,代碼來源:MyFilesApp.java

示例13: writePojosToParquetFile

import org.apache.avro.reflect.ReflectData; //導入依賴的package包/類
private Path writePojosToParquetFile( int num, CompressionCodecName compression,
                                      boolean enableDictionary) throws IOException {
  File tmp = File.createTempFile(getClass().getSimpleName(), ".tmp");
  tmp.deleteOnExit();
  tmp.delete();
  Path path = new Path(tmp.getPath());

  Pojo object = getPojo();

  Schema schema = ReflectData.get().getSchema(object.getClass());
  ParquetWriter<Pojo> writer = AvroParquetWriter.<Pojo>builder(path)
      .withSchema(schema)
      .withCompressionCodec(compression)
      .withDataModel(ReflectData.get())
      .withDictionaryEncoding(enableDictionary)
      .build();
  for (int i = 0; i < num; i++) {
    writer.write(object);
  }
  writer.close();
  return path;
}
 
開發者ID:apache,項目名稱:parquet-mr,代碼行數:23,代碼來源:TestReflectReadWrite.java

示例14: testWriteUUIDMissingLogicalType

import org.apache.avro.reflect.ReflectData; //導入依賴的package包/類
@Test(expected = ClassCastException.class)
public void testWriteUUIDMissingLogicalType() throws IOException {
  Schema uuidSchema = SchemaBuilder.record(RecordWithUUID.class.getName())
      .fields().requiredString("uuid").endRecord();
  LogicalTypes.uuid().addToSchema(uuidSchema.getField("uuid").schema());

  UUID u1 = UUID.randomUUID();
  UUID u2 = UUID.randomUUID();

  RecordWithUUID r1 = new RecordWithUUID();
  r1.uuid = u1;
  RecordWithUUID r2 = new RecordWithUUID();
  r2.uuid = u2;

  // write without using REFLECT, which has the logical type
  File test = write(uuidSchema, r1, r2);

  // verify that the field's type overrides the logical type
  Schema uuidStringSchema = SchemaBuilder
      .record(RecordWithStringUUID.class.getName())
      .fields().requiredString("uuid").endRecord();

  // this fails with an AppendWriteException wrapping ClassCastException
  // because the UUID isn't converted to a CharSequence expected internally
  read(ReflectData.get(), uuidStringSchema, test);
}
 
開發者ID:apache,項目名稱:parquet-mr,代碼行數:27,代碼來源:TestReflectLogicalTypes.java

示例15: fromBytes

import org.apache.avro.reflect.ReflectData; //導入依賴的package包/類
@SuppressWarnings("unchecked")
public static <T> T fromBytes( byte[] val, Schema schema
    , SpecificDatumReader<T> datumReader, T object)
throws IOException {
  Type type = schema.getType();
  switch (type) {
  case ENUM:
    String symbol = schema.getEnumSymbols().get(val[0]);
    return (T)Enum.valueOf(ReflectData.get().getClass(schema), symbol);
  case STRING:  return (T)new Utf8(toString(val));
  case BYTES:   return (T)ByteBuffer.wrap(val);
  case INT:     return (T)Integer.valueOf(bytesToVint(val));
  case LONG:    return (T)Long.valueOf(bytesToVlong(val));
  case FLOAT:   return (T)Float.valueOf(toFloat(val));
  case DOUBLE:  return (T)Double.valueOf(toDouble(val));
  case BOOLEAN: return (T)Boolean.valueOf(val[0] != 0);
  case RECORD:  //fall
  case MAP:
  case ARRAY:   return (T)IOUtils.deserialize(val, (SpecificDatumReader<SpecificRecord>)datumReader, (SpecificRecord)object);
  default: throw new RuntimeException("Unknown type: "+type);
  }
}
 
開發者ID:apache,項目名稱:gora,代碼行數:23,代碼來源:ByteUtils.java


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