Zookeeper - Dasar-dasar

Sebelum mendalami pekerjaan ZooKeeper, mari kita lihat konsep dasar ZooKeeper. Kami akan membahas topik berikut dalam bab ini -

  • Architecture
  • Namespace hierarki
  • Session
  • Watches

Arsitektur ZooKeeper

Perhatikan diagram berikut. Ini menggambarkan "Arsitektur Client-Server" dari ZooKeeper.

Masing-masing komponen yang merupakan bagian dari arsitektur ZooKeeper telah dijelaskan dalam tabel berikut.

Bagian Deskripsi
Klien

Klien, salah satu node dalam cluster aplikasi terdistribusi kami, mengakses informasi dari server. Untuk interval waktu tertentu, setiap klien mengirim pesan ke server untuk memberi tahu server bahwa klien masih hidup.

Demikian pula, server mengirimkan pengakuan saat klien terhubung. Jika tidak ada respons dari server yang terhubung, klien secara otomatis mengalihkan pesan ke server lain.

Server Server, salah satu node dalam ansambel ZooKeeper kami, menyediakan semua layanan kepada klien. Memberikan pengakuan kepada klien untuk menginformasikan bahwa server masih hidup.
Ansambel Grup server ZooKeeper. Jumlah minimum node yang dibutuhkan untuk membentuk ansambel adalah 3.
Pemimpin Node server yang melakukan pemulihan otomatis jika salah satu node yang terhubung gagal. Pemimpin dipilih saat memulai layanan.
Pengikut Node server yang mengikuti instruksi pemimpin.

Namespace Hierarki

Diagram berikut menggambarkan struktur pohon sistem file Zookeeper yang digunakan untuk representasi memori. Node ZooKeeper disebut sebagaiznode. Setiap znode diidentifikasi dengan nama dan dipisahkan oleh urutan jalur (/).

  • Dalam diagram, pertama Anda memiliki root znodedipisahkan oleh "/". Di bawah root, Anda memiliki dua ruang nama logisconfig dan workers.

  • Itu config namespace digunakan untuk manajemen konfigurasi terpusat dan workers namespace digunakan untuk penamaan.

  • Dibawah confignamespace, setiap znode dapat menyimpan hingga 1MB data. Ini mirip dengan sistem file UNIX kecuali bahwa znode induk dapat menyimpan data juga. Tujuan utama dari struktur ini adalah untuk menyimpan data yang disinkronkan dan mendeskripsikan metadata dari znode. Struktur ini disebut sebagaiZooKeeper Data Model.

Setiap znode dalam model data ZooKeeper mempertahankan a statstruktur. Stat hanya menyediakanmetadatadari sebuah znode. Ini terdiri dari nomor Versi, Daftar kontrol tindakan (ACL), Stempel waktu, dan Panjang data.

  • Version number- Setiap znode memiliki nomor versi, yang berarti setiap kali data yang terkait dengan znode berubah, nomor versinya juga akan bertambah. Penggunaan nomor versi penting ketika beberapa klien penjaga kebun binatang mencoba melakukan operasi pada znode yang sama.

  • Action Control List (ACL)- ACL pada dasarnya adalah mekanisme otentikasi untuk mengakses znode. Ini mengatur semua operasi baca dan tulis znode.

  • Timestamp- Stempel waktu menunjukkan waktu yang telah berlalu dari pembuatan dan modifikasi znode. Biasanya ditampilkan dalam milidetik. ZooKeeper mengidentifikasi setiap perubahan pada znodes dari "ID Transaksi" (zxid).Zxid bersifat unik dan mempertahankan waktu untuk setiap transaksi sehingga Anda dapat dengan mudah mengidentifikasi waktu yang telah berlalu dari satu permintaan ke permintaan lainnya.

  • Data length- Jumlah total data yang disimpan dalam znode adalah panjang data. Anda dapat menyimpan data maksimal 1MB.

Jenis Znode

Znode dikategorikan sebagai persistence, sequential, dan ephemeral.

  • Persistence znode- Persistence znode tetap hidup bahkan setelah klien, yang membuat znode tertentu, diputus. Secara default, semua znode tetap ada kecuali ditentukan lain.

  • Ephemeral znode- Znode singkat aktif sampai klien hidup. Ketika klien terputus dari ansambel Zookeeper, maka znode singkat dihapus secara otomatis. Karena alasan ini, hanya znode sementara yang tidak diizinkan untuk memiliki anak lebih lanjut. Jika sebuah znode efemeral dihapus, maka node berikutnya yang sesuai akan mengisi posisinya. Znode singkat memainkan peran penting dalam pemilihan Pemimpin.

  • Sequential znode- Znode berurutan dapat berupa persistent atau ephemeral. Ketika znode baru dibuat sebagai znode berurutan, maka ZooKeeper menyetel jalur znode tersebut dengan melampirkan 10 digit nomor urut ke nama aslinya. Misalnya, jika znode dengan jalur/myapp dibuat sebagai znode berurutan, ZooKeeper akan mengubah jalur ke /myapp0000000001dan atur nomor urut berikutnya sebagai 0000000002. Jika dua znode berurutan dibuat secara bersamaan, maka Znode tidak pernah menggunakan nomor yang sama untuk setiap znode. Znode berurutan memainkan peran penting dalam Penguncian dan Sinkronisasi.

Sesi

Sesi sangat penting untuk pengoperasian ZooKeeper. Permintaan dalam satu sesi dieksekusi dalam urutan FIFO. Setelah klien terhubung ke server, sesi akan dibuat dan asession id ditugaskan ke klien.

Klien mengirim heartbeatspada interval waktu tertentu agar sesi tetap valid. Jika ansambel ZooKeeper tidak menerima detak jantung dari klien selama lebih dari periode (batas waktu sesi) yang ditentukan pada awal layanan, itu memutuskan bahwa klien meninggal.

Waktu tunggu sesi biasanya ditampilkan dalam milidetik. Saat sesi berakhir karena alasan apa pun, znode singkat yang dibuat selama sesi itu juga akan dihapus.

Jam tangan

Jam tangan adalah mekanisme sederhana bagi klien untuk mendapatkan pemberitahuan tentang perubahan dalam ansambel ZooKeeper. Klien dapat mengatur jam tangan saat membaca znode tertentu. Jam tangan mengirimkan pemberitahuan ke klien terdaftar untuk setiap perubahan znode (di mana klien mendaftar).

Perubahan Znode adalah modifikasi data yang terkait dengan znode atau perubahan pada turunan znode. Jam tangan hanya dipicu sekali. Jika klien menginginkan pemberitahuan lagi, itu harus dilakukan melalui operasi baca lainnya. Ketika sesi koneksi kedaluwarsa, klien akan terputus dari server dan jam tangan terkait juga dihapus.