एवीआरओ - पार्सर्स का उपयोग करके सीरियलाइजेशन

एक एवरो स्कीमा को एक प्रोग्राम में या तो स्कीमा के अनुरूप वर्ग उत्पन्न करके या पार्सर लाइब्रेरी का उपयोग करके पढ़ा जा सकता है। एवरो में, डेटा हमेशा अपने संबंधित स्कीमा के साथ संग्रहीत किया जाता है। इसलिए, हम हमेशा कोड पीढ़ी के बिना एक स्कीमा पढ़ सकते हैं।

यह अध्याय स्कीमा को पढ़ने का तरीका बताता है by using parsers library और करने के लिए serialize एवरो का उपयोग कर डेटा।

पार्सर्स लाइब्रेरी का उपयोग करके सीरियलाइज़ेशन

डेटा को क्रमबद्ध करने के लिए, हमें स्कीमा को पढ़ना होगा, स्कीमा के अनुसार डेटा बनाना होगा और एविए एपीआई का उपयोग करके स्कीमा को क्रमबद्ध करना होगा। निम्नलिखित प्रक्रिया किसी भी कोड को उत्पन्न किए बिना डेटा को क्रमबद्ध करती है -

चरण 1

सबसे पहले, फ़ाइल से स्कीमा पढ़ें। ऐसा करने के लिए, का उपयोग करेंSchema.Parserकक्षा। यह वर्ग विभिन्न स्वरूपों में स्कीमा को पार्स करने के तरीके प्रदान करता है।

झटपट Schema.Parser उस फ़ाइल पथ को पास करके वर्ग जहाँ स्कीमा संग्रहीत है।

Schema schema = new Schema.Parser().parse(new File("/path/to/emp.avsc"));

चरण 2

की वस्तु बनाएँ GenericRecord इंटरफ़ेस, झटपट द्वारा GenericData.Recordनीचे दिखाया गया है। इसके निर्माता के लिए ऊपर बनाई गई स्कीमा ऑब्जेक्ट पास करें।

GenericRecord e1 = new GenericData.Record(schema);

चरण 3

स्कीमा का उपयोग करके मान डालें put() की विधि GenericData कक्षा।

e1.put("name", "ramu");
e1.put("id", 001);
e1.put("salary",30000);
e1.put("age", 25);
e1.put("address", "chennai");

चरण 4

का एक ऑब्जेक्ट बनाएँ DatumWriter इंटरफ़ेस का उपयोग कर SpecificDatumWriterकक्षा। यह जावा वस्तुओं को इन-मेमोरी क्रमबद्ध प्रारूप में परिवर्तित करता है। निम्न उदाहरण तात्कालिक हैSpecificDatumWriter के लिए वर्ग वस्तु emp वर्ग -

DatumWriter<emp> empDatumWriter = new SpecificDatumWriter<emp>(emp.class);

चरण 5

इन्स्तांत करना DataFileWriter के लिये empकक्षा। यह वर्ग स्कीमा के अनुरूप डेटा के क्रमबद्ध रिकॉर्ड लिखता है, स्कीमा के साथ ही, एक फाइल में। इस वर्ग की आवश्यकता हैDatumWriter ऑब्जेक्ट, कंस्ट्रक्टर के पैरामीटर के रूप में।

DataFileWriter<emp> dataFileWriter = new DataFileWriter<emp>(empDatumWriter);

चरण 6

उपयोग किए गए स्कीमा से मेल खाते डेटा को संग्रहीत करने के लिए एक नई फ़ाइल खोलें create()तरीका। इस पद्धति के लिए स्कीमा की आवश्यकता होती है, और फ़ाइल का पथ जहां डेटा संग्रहीत किया जाना है, मापदंडों के रूप में।

नीचे दिए गए उदाहरण में, स्कीमा का उपयोग करके पारित किया गया है getSchema() विधि और डेटा फ़ाइल पथ में संग्रहीत है

/home/Hadoop/Avro/serialized_file/emp.avro.

empFileWriter.create(e1.getSchema(), new
File("/home/Hadoop/Avro/serialized_file/emp.avro"));

चरण 7

फ़ाइल का उपयोग करके सभी बनाए गए रिकॉर्ड जोड़ें append( ) नीचे दिखाए अनुसार विधि।

empFileWriter.append(e1);
empFileWriter.append(e2);
empFileWriter.append(e3);

उदाहरण - पार्सर्स के उपयोग से क्रमांकन

निम्न पूरा कार्यक्रम दिखाता है कि पार्सर्स का उपयोग करके डेटा को कैसे क्रमबद्ध किया जाए -

import java.io.File;
import java.io.IOException;

import org.apache.avro.Schema;
import org.apache.avro.file.DataFileWriter;

import org.apache.avro.generic.GenericData;
import org.apache.avro.generic.GenericDatumWriter;
import org.apache.avro.generic.GenericRecord;

import org.apache.avro.io.DatumWriter;

public class Seriali {
   public static void main(String args[]) throws IOException{
	
      //Instantiating the Schema.Parser class.
      Schema schema = new Schema.Parser().parse(new File("/home/Hadoop/Avro/schema/emp.avsc"));
		
      //Instantiating the GenericRecord class.
      GenericRecord e1 = new GenericData.Record(schema);
		
      //Insert data according to schema
      e1.put("name", "ramu");
      e1.put("id", 001);
      e1.put("salary",30000);
      e1.put("age", 25);
      e1.put("address", "chenni");
		
      GenericRecord e2 = new GenericData.Record(schema);
		
      e2.put("name", "rahman");
      e2.put("id", 002);
      e2.put("salary", 35000);
      e2.put("age", 30);
      e2.put("address", "Delhi");
		
      DatumWriter<GenericRecord> datumWriter = new GenericDatumWriter<GenericRecord>(schema);
		
      DataFileWriter<GenericRecord> dataFileWriter = new DataFileWriter<GenericRecord>(datumWriter);
      dataFileWriter.create(schema, new File("/home/Hadoop/Avro_work/without_code_gen/mydata.txt"));
		
      dataFileWriter.append(e1);
      dataFileWriter.append(e2);
      dataFileWriter.close();
		
      System.out.println(“data successfully serialized”);
   }
}

उस निर्देशिका में ब्राउज़ करें जहां उत्पन्न कोड रखा गया है। इस मामले में, परhome/Hadoop/Avro_work/without_code_gen

$ cd home/Hadoop/Avro_work/without_code_gen/

अब नाम की फाइल में उपरोक्त प्रोग्राम को कॉपी और सेव करें Serialize.java। नीचे दिखाए अनुसार इसे संकलित और निष्पादित करें -

$ javac Serialize.java
$ java Serialize

उत्पादन

data successfully serialized

यदि आप प्रोग्राम में दिए गए पथ को सत्यापित करते हैं, तो आप नीचे दिखाए गए अनुसार उत्पन्न क्रमबद्ध फ़ाइल पा सकते हैं।