HBase - Gambaran Umum
Sejak tahun 1970, RDBMS adalah solusi untuk penyimpanan data dan masalah terkait pemeliharaan. Setelah munculnya data besar, perusahaan menyadari manfaat dari pemrosesan data besar dan mulai memilih solusi seperti Hadoop.
Hadoop menggunakan sistem file terdistribusi untuk menyimpan data besar, dan MapReduce untuk memprosesnya. Hadoop unggul dalam menyimpan dan memproses data besar dari berbagai format seperti arbitrary, semi-, atau bahkan tidak terstruktur.
Batasan Hadoop
Hadoop hanya dapat melakukan pemrosesan batch, dan data hanya akan diakses secara berurutan. Itu berarti seseorang harus mencari seluruh dataset bahkan untuk pekerjaan yang paling sederhana.
Kumpulan data yang sangat besar ketika diproses menghasilkan kumpulan data besar lainnya, yang juga harus diproses secara berurutan. Pada titik ini, solusi baru diperlukan untuk mengakses setiap titik data dalam satu unit waktu (akses acak).
Database Akses Acak Hadoop
Aplikasi seperti HBase, Cassandra, couchDB, Dynamo, dan MongoDB adalah beberapa database yang menyimpan data dalam jumlah besar dan mengakses data secara acak.
Apa itu HBase?
HBase adalah database berorientasi kolom terdistribusi yang dibangun di atas sistem file Hadoop. Ini adalah proyek open-source dan dapat diskalakan secara horizontal.
HBase adalah model data yang mirip dengan tabel besar Google yang dirancang untuk memberikan akses acak cepat ke sejumlah besar data terstruktur. Ini memanfaatkan toleransi kesalahan yang disediakan oleh Hadoop File System (HDFS).
Ini adalah bagian dari ekosistem Hadoop yang menyediakan akses baca / tulis waktu nyata acak ke data di Sistem File Hadoop.
Seseorang dapat menyimpan data dalam HDFS baik secara langsung atau melalui HBase. Konsumen data membaca / mengakses data dalam HDFS secara acak menggunakan HBase. HBase berada di atas Sistem File Hadoop dan menyediakan akses baca dan tulis.
HBase dan HDFS
HDFS | HBase |
---|---|
HDFS adalah sistem file terdistribusi yang cocok untuk menyimpan file besar. | HBase adalah database yang dibangun di atas HDFS. |
HDFS tidak mendukung pencarian catatan individual yang cepat. | HBase menyediakan pencarian cepat untuk tabel yang lebih besar. |
Ini menyediakan pemrosesan batch latensi tinggi; tidak ada konsep pemrosesan batch. | Ini memberikan akses latensi rendah ke baris tunggal dari miliaran catatan (akses acak). |
Ini hanya menyediakan akses data berurutan. | HBase secara internal menggunakan tabel Hash dan menyediakan akses acak, dan menyimpan data dalam file HDFS yang diindeks untuk pencarian yang lebih cepat. |
Mekanisme Penyimpanan di HBase
HBase adalah a column-oriented databasedan tabel di dalamnya diurutkan berdasarkan baris. Skema tabel hanya mendefinisikan keluarga kolom, yang merupakan pasangan nilai kunci. Tabel memiliki beberapa keluarga kolom dan setiap keluarga kolom dapat memiliki sejumlah kolom. Nilai kolom selanjutnya disimpan berdekatan di disk. Setiap nilai sel tabel memiliki stempel waktu. Singkatnya, dalam HBase:
- Tabel adalah kumpulan baris.
- Baris adalah kumpulan keluarga kolom.
- Keluarga kolom adalah kumpulan kolom.
- Kolom adalah kumpulan pasangan nilai kunci.
Diberikan di bawah ini adalah contoh skema tabel di HBase.
Rowid | Keluarga Kolom | Keluarga Kolom | Keluarga Kolom | Keluarga Kolom | ||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|
col1 | col2 | col3 | col1 | col2 | col3 | col1 | col2 | col3 | col1 | col2 | col3 | |
1 | ||||||||||||
2 | ||||||||||||
3 |
Berorientasi Kolom dan Berorientasi Baris
Database berorientasi kolom adalah database yang menyimpan tabel data sebagai bagian dari kolom data, bukan sebagai baris data. Singkatnya, mereka akan memiliki keluarga kolom.
Database Berorientasi Baris | Database Berorientasi Kolom |
---|---|
Sangat cocok untuk Proses Transaksi Online (OLTP). | Sangat cocok untuk Online Analytical Processing (OLAP). |
Database semacam itu dirancang untuk sejumlah kecil baris dan kolom. | Database berorientasi kolom dirancang untuk tabel besar. |
Gambar berikut menunjukkan keluarga kolom dalam database berorientasi kolom:
HBase dan RDBMS
HBase | RDBMS |
---|---|
HBase tidak memiliki skema, tidak memiliki konsep skema kolom tetap; hanya mendefinisikan keluarga kolom. | RDBMS diatur oleh skemanya, yang menjelaskan seluruh struktur tabel. |
Itu dibangun untuk tabel lebar. HBase dapat diskalakan secara horizontal. | Ini tipis dan dibuat untuk meja kecil. Sulit untuk diukur. |
Tidak ada transaksi di HBase. | RDBMS bersifat transaksional. |
Ini memiliki data yang tidak dinormalisasi. | Ini akan memiliki data yang dinormalisasi. |
Ini bagus untuk data semi-terstruktur maupun terstruktur. | Ini bagus untuk data terstruktur. |
Fitur HBase
- HBase dapat diskalakan secara linier.
- Ini memiliki dukungan kegagalan otomatis.
- Ini memberikan pembacaan dan penulisan yang konsisten.
- Ini terintegrasi dengan Hadoop, baik sebagai sumber dan tujuan.
- Ini memiliki API java yang mudah untuk klien.
- Ini menyediakan replikasi data di seluruh cluster.
Dimana Menggunakan HBase
Apache HBase digunakan untuk memiliki akses baca / tulis acak dan real-time ke Big Data.
Ini menjadi tuan rumah tabel yang sangat besar di atas kelompok perangkat keras komoditas.
Apache HBase adalah database non-relasional yang dimodelkan setelah Bigtable Google. Bigtable bekerja di Google File System, begitu pula Apache HBase bekerja di atas Hadoop dan HDFS.
Aplikasi HBase
- Ini digunakan setiap kali ada kebutuhan untuk menulis aplikasi berat.
- HBase digunakan kapan pun kita perlu menyediakan akses acak cepat ke data yang tersedia.
- Perusahaan seperti Facebook, Twitter, Yahoo, dan Adobe menggunakan HBase secara internal.
Sejarah HBase
Tahun | Peristiwa |
---|---|
November 2006 | Google merilis makalah tentang BigTable. |
Feb 2007 | Prototipe HBase awal dibuat sebagai kontribusi Hadoop. |
Okt 2007 | HBase yang dapat digunakan pertama bersama dengan Hadoop 0.15.0 dirilis. |
Jan 2008 | HBase menjadi sub proyek Hadoop. |
Okt 2008 | HBase 0.18.1 dirilis. |
Jan 2009 | HBase 0.19.0 dirilis. |
Sept 2009 | HBase 0.20.0 dirilis. |
Mei 2010 | HBase menjadi proyek tingkat atas Apache. |