AVRO - Deserialisierung mit Parsern
Wie bereits erwähnt, kann ein Avro-Schema in ein Programm eingelesen werden, indem entweder eine Klasse generiert wird, die einem Schema entspricht, oder indem die Parser-Bibliothek verwendet wird. In Avro werden Daten immer mit dem entsprechenden Schema gespeichert. Daher können wir ein serialisiertes Element immer ohne Codegenerierung lesen.
In diesem Kapitel wird das Lesen des Schemas beschrieben using parsers library und Deserializing die Daten mit Avro.
Deserialisierung mit Parsers Library
Die serialisierten Daten werden in der Datei gespeichert mydata.txt. Sie können es mit Avro deserialisieren und lesen.
Befolgen Sie die unten angegebenen Schritte, um die serialisierten Daten aus einer Datei zu deserialisieren.
Schritt 1
Lesen Sie zunächst das Schema aus der Datei. Verwenden Sie dazuSchema.ParserKlasse. Diese Klasse bietet Methoden zum Parsen des Schemas in verschiedenen Formaten.
Instanziieren Sie die Schema.Parser Klasse durch Übergeben des Dateipfads, in dem das Schema gespeichert ist.
Schema schema = new Schema.Parser().parse(new File("/path/to/emp.avsc"));
Schritt 2
Erstellen Sie ein Objekt von DatumReader Schnittstelle mit SpecificDatumReader Klasse.
DatumReader<emp>empDatumReader = new SpecificDatumReader<emp>(emp.class);
Schritt 3
Instanziieren DataFileReaderKlasse. Diese Klasse liest serialisierte Daten aus einer Datei. Es erfordert dieDatumReader Objekt und Pfad der Datei, in der die serialisierten Daten vorhanden sind, als Parameter für den Konstruktor.
DataFileReader<GenericRecord> dataFileReader = new DataFileReader<GenericRecord>(new File("/path/to/mydata.txt"), datumReader);
Schritt 4
Drucken Sie die deserialisierten Daten mit den Methoden von DataFileReader.
Das hasNext() Die Methode gibt einen Booleschen Wert zurück, wenn der Reader Elemente enthält.
Das next() Methode von DataFileReader gibt die Daten im Reader zurück.
while(dataFileReader.hasNext()){
em=dataFileReader.next(em);
System.out.println(em);
}
Beispiel - Deserialisierung mit der Parsers Library
Das folgende vollständige Programm zeigt, wie die serialisierten Daten mithilfe der Parsers-Bibliothek deserialisiert werden:
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");
}
}
Navigieren Sie in das Verzeichnis, in dem sich der generierte Code befindet. In diesem Fall ist es beihome/Hadoop/Avro_work/without_code_gen.
$ cd home/Hadoop/Avro_work/without_code_gen/
Kopieren Sie nun das obige Programm und speichern Sie es in der genannten Datei DeSerialize.java. Kompilieren Sie es und führen Sie es wie unten gezeigt aus -
$ javac Deserialize.java
$ java Deserialize
Ausgabe
{"name": "ramu", "id": 1, "salary": 30000, "age": 25, "address": "chennai"}
{"name": "rahman", "id": 2, "salary": 35000, "age": 30, "address": "Delhi"}