Impala - Sekilas
Apa itu Impala?
Impala adalah mesin kueri SQL MPP (Massive Parallel Processing) untuk memproses data dalam jumlah besar yang disimpan di cluster Hadoop. Ini adalah perangkat lunak open source yang ditulis dalam C ++ dan Java. Ini memberikan kinerja tinggi dan latensi rendah dibandingkan dengan mesin SQL lainnya untuk Hadoop.
Dengan kata lain, Impala adalah mesin SQL berkinerja tertinggi (memberikan pengalaman seperti RDBMS) yang menyediakan cara tercepat untuk mengakses data yang disimpan di Sistem File Terdistribusi Hadoop.
Mengapa Impala?
Impala menggabungkan dukungan SQL dan kinerja multi-pengguna dari database analitik tradisional dengan skalabilitas dan fleksibilitas Apache Hadoop, dengan memanfaatkan komponen standar seperti HDFS, HBase, Metastore, YARN, dan Sentry.
Dengan Impala, pengguna dapat berkomunikasi dengan HDFS atau HBase menggunakan kueri SQL dengan cara yang lebih cepat dibandingkan dengan mesin SQL lain seperti Hive.
Impala dapat membaca hampir semua format file seperti Parquet, Avro, RCFile yang digunakan oleh Hadoop.
Impala menggunakan metadata yang sama, sintaks SQL (Hive SQL), driver ODBC, dan antarmuka pengguna (Hue Beeswax) sebagai Apache Hive, menyediakan platform yang akrab dan terpadu untuk kueri berorientasi batch atau real-time.
Tidak seperti Apache Hive, Impala is not based on MapReduce algorithms. Ini mengimplementasikan arsitektur terdistribusi berdasarkandaemon processes yang bertanggung jawab atas semua aspek eksekusi kueri yang berjalan di mesin yang sama.
Dengan demikian, ini mengurangi latensi penggunaan MapReduce dan ini membuat Impala lebih cepat daripada Apache Hive.
Keuntungan Impala
Berikut adalah daftar beberapa keuntungan dari Cloudera Impala.
Menggunakan impala, Anda dapat memproses data yang disimpan dalam HDFS secepat kilat dengan pengetahuan SQL tradisional.
Karena pemrosesan data dilakukan di tempat data berada (di cluster Hadoop), transformasi data dan perpindahan data tidak diperlukan untuk data yang disimpan di Hadoop, saat bekerja dengan Impala.
Dengan menggunakan Impala, Anda dapat mengakses data yang disimpan di HDFS, HBase, dan Amazon s3 tanpa sepengetahuan Java (pekerjaan MapReduce). Anda dapat mengaksesnya dengan ide dasar kueri SQL.
Untuk menulis kueri di alat bisnis, data harus melalui siklus ekstrak-transform-load (ETL) yang rumit. Tapi, dengan Impala, prosedur ini dipersingkat. Tahapan pemuatan & pengaturan ulang yang memakan waktu diatasi dengan teknik baru sepertiexploratory data analysis & data discovery membuat prosesnya lebih cepat.
Impala merintis penggunaan format file Parket, tata letak penyimpanan berbentuk kolom yang dioptimalkan untuk kueri skala besar yang khas dalam skenario gudang data.
Fitur Impala
Diberikan di bawah ini adalah fitur cloudera Impala -
Impala tersedia secara bebas sebagai open source di bawah lisensi Apache.
Impala mendukung pemrosesan data dalam memori, yaitu mengakses / menganalisis data yang disimpan di node data Hadoop tanpa pergerakan data.
Anda dapat mengakses data menggunakan Impala menggunakan kueri seperti SQL.
Impala menyediakan akses yang lebih cepat untuk data di HDFS jika dibandingkan dengan mesin SQL lainnya.
Dengan menggunakan Impala, Anda dapat menyimpan data di sistem penyimpanan seperti HDFS, Apache HBase, dan Amazon s3.
Anda dapat mengintegrasikan Impala dengan alat intelijen bisnis seperti Tableau, Pentaho, Strategi mikro, dan data Zoom.
Impala mendukung berbagai format file seperti, LZO, Sequence File, Avro, RCFile, dan Parquet.
Impala menggunakan metadata, driver ODBC, dan sintaks SQL dari Apache Hive.
Database Relasional dan Impala
Impala menggunakan bahasa Query yang mirip dengan SQL dan HiveQL. Tabel berikut menjelaskan beberapa perbedaan utama antara SQL dan bahasa Query Impala.
Impala | Database relasional |
---|---|
Impala menggunakan bahasa kueri seperti SQL yang mirip dengan HiveQL. | Database relasional menggunakan bahasa SQL. |
Di Impala, Anda tidak dapat memperbarui atau menghapus rekaman individu. | Dalam database relasional, dimungkinkan untuk memperbarui atau menghapus catatan individu. |
Impala tidak mendukung transaksi. | Database relasional mendukung transaksi. |
Impala tidak mendukung pengindeksan. | Database relasional mendukung pengindeksan. |
Impala menyimpan dan mengelola data dalam jumlah besar (petabyte). | Database relasional menangani jumlah data yang lebih kecil (terabyte) jika dibandingkan dengan Impala. |
Sarang, Hbase, dan Impala
Meskipun Cloudera Impala menggunakan bahasa kueri, metastore, dan antarmuka pengguna yang sama dengan Hive, ini berbeda dengan Hive dan HBase dalam aspek tertentu. Tabel berikut menyajikan analisis komparatif antara HBase, Hive, dan Impala.
HBase | Sarang lebah | Impala |
---|---|---|
HBase adalah database penyimpanan kolom lebar berdasarkan Apache Hadoop. Ini menggunakan konsep BigTable. | Hive adalah perangkat lunak gudang data. Dengan ini, kita dapat mengakses dan mengelola kumpulan data terdistribusi besar, yang dibangun di atas Hadoop. | Impala adalah alat untuk mengelola, menganalisis data yang disimpan di Hadoop. |
Model data HBase adalah penyimpanan kolom lebar. | Sarang mengikuti model Relasional. | Impala mengikuti model Relasional. |
HBase dikembangkan dengan menggunakan bahasa Java. | Sarang dikembangkan dengan menggunakan bahasa Java. | Impala dikembangkan menggunakan C ++. |
Model data HBase bebas skema. | Model data sarang berbasis skema. | Model data Impala berbasis Skema. |
HBase menyediakan Java, RESTful dan, Thrift API. | Hive menyediakan JDBC, ODBC, Thrift API. | Impala menyediakan API JDBC dan ODBC. |
Mendukung bahasa pemrograman seperti C, C #, C ++, Groovy, Java PHP, Python, dan Scala. | Mendukung bahasa pemrograman seperti C ++, Java, PHP, dan Python. | Impala mendukung semua bahasa yang mendukung JDBC / ODBC. |
HBase memberikan dukungan untuk pemicu. | Sarang tidak memberikan dukungan apa pun untuk pemicu. | Impala tidak memberikan dukungan apa pun untuk pemicu. |
Ketiga database ini -
Apakah database NOSQL.
Tersedia sebagai open source.
Mendukung pembuatan skrip sisi server.
Ikuti properti ACID seperti Durability dan Concurrency.
Menggunakan sharding untuk partitioning.
Kekurangan Impala
Beberapa kekurangan menggunakan Impala adalah sebagai berikut -
- Impala tidak memberikan dukungan apa pun untuk Serialisasi dan Deserialisasi.
- Impala hanya dapat membaca file teks, bukan file biner kustom.
- Setiap kali catatan / file baru ditambahkan ke direktori data di HDFS, tabel perlu di-refresh.