एवीआरओ - पार्सर्स का उपयोग करते हुए देशीकरण
जैसा कि पहले उल्लेख किया गया है, एक एवरो स्कीमा को एक प्रोग्राम में या तो एक स्कीमा के अनुरूप वर्ग उत्पन्न करके या पार्स लाइब्रेरी का उपयोग करके पढ़ा जा सकता है। एवरो में, डेटा हमेशा अपने संबंधित स्कीमा के साथ संग्रहीत किया जाता है। इसलिए, हम हमेशा कोड पीढ़ी के बिना एक क्रमबद्ध आइटम पढ़ सकते हैं।
यह अध्याय स्कीमा को पढ़ने का तरीका बताता है using parsers library तथा Deserializing एवरो का उपयोग कर डेटा।
पार्सर्स लाइब्रेरी का उपयोग करते हुए देशीकरण
सीरियल किए गए डेटा को फ़ाइल में संग्रहीत किया जाता है mydata.txt। आप एवरो का उपयोग करके इसे डीरिशियल कर सकते हैं और पढ़ सकते हैं।
एक फ़ाइल से क्रमबद्ध डेटा को डीरियलाइज़ करने के लिए नीचे दी गई प्रक्रिया का पालन करें।
चरण 1
सबसे पहले, फ़ाइल से स्कीमा पढ़ें। ऐसा करने के लिए, का उपयोग करेंSchema.Parserकक्षा। यह वर्ग विभिन्न स्वरूपों में स्कीमा को पार्स करने के तरीके प्रदान करता है।
झटपट Schema.Parser उस फ़ाइल पथ को पास करके वर्ग जहाँ स्कीमा संग्रहीत है।
Schema schema = new Schema.Parser().parse(new File("/path/to/emp.avsc"));
चरण 2
का एक ऑब्जेक्ट बनाएँ DatumReader इंटरफ़ेस का उपयोग कर SpecificDatumReader कक्षा।
DatumReader<emp>empDatumReader = new SpecificDatumReader<emp>(emp.class);
चरण 3
इन्स्तांत करना DataFileReaderकक्षा। यह वर्ग किसी फ़ाइल से क्रमबद्ध डेटा पढ़ता है। इसकी आवश्यकता हैDatumReader ऑब्जेक्ट और फ़ाइल का पथ जहाँ सीरियल डेटा मौजूद है, निर्माणकर्ता के लिए एक पैरामीटर के रूप में।
DataFileReader<GenericRecord> dataFileReader = new DataFileReader<GenericRecord>(new File("/path/to/mydata.txt"), datumReader);
चरण 4
के तरीकों का उपयोग करते हुए, डिसेररलाइज्ड डेटा प्रिंट करें DataFileReader।
hasNext() विधि रीडर में कोई तत्व होने पर एक बूलियन देता है।
next() उसकि विधि DataFileReader रीडर में डेटा लौटाता है।
while(dataFileReader.hasNext()){
em=dataFileReader.next(em);
System.out.println(em);
}
उदाहरण - पार्सर्स लाइब्रेरी का उपयोग करते हुए देशीकरण
निम्न पूरा कार्यक्रम दिखाता है कि पार्सर्स लाइब्रेरी का उपयोग करके क्रमबद्ध डेटा को कैसे निष्क्रिय किया जाए -
public class Deserialize {
public static void main(String args[]) throws Exception{
//Instantiating the Schema.Parser class.
Schema schema = new Schema.Parser().parse(new File("/home/Hadoop/Avro/schema/emp.avsc"));
DatumReader<GenericRecord> datumReader = new GenericDatumReader<GenericRecord>(schema);
DataFileReader<GenericRecord> dataFileReader = new DataFileReader<GenericRecord>(new File("/home/Hadoop/Avro_Work/without_code_gen/mydata.txt"), datumReader);
GenericRecord emp = null;
while (dataFileReader.hasNext()) {
emp = dataFileReader.next(emp);
System.out.println(emp);
}
System.out.println("hello");
}
}
उस निर्देशिका में ब्राउज़ करें जहां उत्पन्न कोड रखा गया है। इस मामले में, यह पर हैhome/Hadoop/Avro_work/without_code_gen।
$ cd home/Hadoop/Avro_work/without_code_gen/
अब नाम की फाइल में उपरोक्त प्रोग्राम को कॉपी और सेव करें DeSerialize.java। नीचे दिखाए अनुसार इसे संकलित और निष्पादित करें -
$ javac Deserialize.java
$ java Deserialize
उत्पादन
{"name": "ramu", "id": 1, "salary": 30000, "age": 25, "address": "chennai"}
{"name": "rahman", "id": 2, "salary": 35000, "age": 30, "address": "Delhi"}