एवीआरओ - कक्षा उत्पन्न करके देशीकरण

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

एक वर्ग उत्पन्न करके देशद्रोह

सीरियल किए गए डेटा को फ़ाइल में संग्रहीत किया जाता है emp.avro। आप एवरो का उपयोग करके इसे डीरिशियल कर सकते हैं और पढ़ सकते हैं।

एक फ़ाइल से क्रमबद्ध डेटा को डीरियलाइज़ करने के लिए नीचे दी गई प्रक्रिया का पालन करें।

चरण 1

का एक ऑब्जेक्ट बनाएँ DatumReader इंटरफ़ेस का उपयोग कर SpecificDatumReader कक्षा।

DatumReader<emp>empDatumReader = new SpecificDatumReader<emp>(emp.class);

चरण 2

इन्स्तांत करना DataFileReader के लिये empकक्षा। यह वर्ग किसी फ़ाइल से क्रमबद्ध डेटा पढ़ता है। इसकी आवश्यकता हैDataumeader ऑब्जेक्ट और फ़ाइल का पथ जहां सीरियल किए गए डेटा मौजूद हैं, निर्माणकर्ता के लिए एक पैरामीटर के रूप में।

DataFileReader<emp> dataFileReader = new DataFileReader(new File("/path/to/emp.avro"), empDatumReader);

चरण 3

के तरीकों का उपयोग करते हुए, डिसेररलाइज्ड डेटा प्रिंट करें DataFileReader

  • hasNext() विधि रीडर में कोई तत्व होने पर एक बूलियन लौटाएगा।

  • next() उसकि विधि DataFileReader रीडर में डेटा लौटाता है।

while(dataFileReader.hasNext()){

   em=dataFileReader.next(em);
   System.out.println(em);
}

उदाहरण - एक वर्ग उत्पन्न करके देशीकरण

निम्न पूरा कार्यक्रम दिखाता है कि एवरो का उपयोग करके किसी फ़ाइल में डेटा को कैसे निष्क्रिय किया जाए।

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

import org.apache.avro.file.DataFileReader;
import org.apache.avro.io.DatumReader;
import org.apache.avro.specific.SpecificDatumReader;

public class Deserialize {
   public static void main(String args[]) throws IOException{
	
      //DeSerializing the objects
      DatumReader<emp> empDatumReader = new SpecificDatumReader<emp>(emp.class);
		
      //Instantiating DataFileReader
      DataFileReader<emp> dataFileReader = new DataFileReader<emp>(new
         File("/home/Hadoop/Avro_Work/with_code_genfile/emp.avro"), empDatumReader);
      emp em=null;
		
      while(dataFileReader.hasNext()){
      
         em=dataFileReader.next(em);
         System.out.println(em);
      }
   }
}

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

$ cd home/Hadoop/Avro_work/with_code_gen/

अब, नामित फ़ाइल में उपरोक्त कार्यक्रम को कॉपी और सहेजें DeSerialize.java। नीचे दिखाए अनुसार इसे संकलित और निष्पादित करें -

$ javac Deserialize.java
$ java Deserialize

उत्पादन

{"name": "omar", "id": 1, "salary": 30000, "age": 21, "address": "Hyderabad"}
{"name": "ram", "id": 2, "salary": 40000, "age": 30, "address": "Hyderabad"}
{"name": "robbin", "id": 3, "salary": 35000, "age": 25, "address": "Hyderabad"}