Penjaga kebun binatang - CLI

ZooKeeper Command Line Interface (CLI) digunakan untuk berinteraksi dengan ansambel ZooKeeper untuk tujuan pengembangan. Ini berguna untuk debugging dan bekerja dengan opsi yang berbeda.

Untuk melakukan operasi ZooKeeper CLI, pertama-tama hidupkan server ZooKeeper Anda ( "bin / zkServer.sh start" ) dan kemudian, klien ZooKeeper ( "bin / zkCli.sh" ). Setelah klien mulai, Anda dapat melakukan operasi berikut -

  • Buat znodes
  • Dapatkan data
  • Perhatikan znode untuk perubahan
  • Setel data
  • Buat anak dari sebuah znode
  • Buat daftar anak-anak dari sebuah znode
  • Periksa Status
  • Hapus / Hapus znode

Sekarang mari kita lihat perintah di atas satu per satu dengan sebuah contoh.

Buat Znodes

Buat znode dengan jalur yang diberikan. Ituflagargumen menentukan apakah znode yang dibuat akan menjadi ephemeral, persisten, atau berurutan. Secara default, semua znode bersifat persisten.

  • Ephemeral znodes (bendera: e) akan secara otomatis dihapus ketika sesi berakhir atau ketika klien terputus.

  • Sequential znodes menjamin bahwa jalur znode akan unik.

  • ZooKeeper ensemble akan menambahkan nomor urut bersama dengan 10 digit padding ke jalur znode. Misalnya, jalur znode / myapp akan diubah menjadi / myapp0000000001 dan nomor urut berikutnya adalah / myapp0000000002 . Jika tidak ada flag yang ditentukan, maka znode dianggap sebagaipersistent.

Sintaksis

create /path /data

Sampel

create /FirstZnode “Myfirstzookeeper-app”

Keluaran

[zk: localhost:2181(CONNECTED) 0] create /FirstZnode “Myfirstzookeeper-app”
Created /FirstZnode

Untuk membuat file Sequential znode, Menambahkan -s flag seperti gambar dibawah.

Sintaksis

create -s /path /data

Sampel

create -s /FirstZnode second-data

Keluaran

[zk: localhost:2181(CONNECTED) 2] create -s /FirstZnode “second-data”
Created /FirstZnode0000000023

Untuk membuat file Ephemeral Znode, Menambahkan -e flag seperti gambar dibawah.

Sintaksis

create -e /path /data

Sampel

create -e /SecondZnode “Ephemeral-data”

Keluaran

[zk: localhost:2181(CONNECTED) 2] create -e /SecondZnode “Ephemeral-data”
Created /SecondZnode

Ingatlah ketika koneksi klien terputus, znode singkat akan dihapus. Anda dapat mencobanya dengan keluar dari CLI ZooKeeper dan kemudian membuka kembali CLI.

Dapatkan Data

Ini mengembalikan data terkait dari znode dan metadata dari znode yang ditentukan. Anda akan mendapatkan informasi seperti kapan terakhir kali data diubah, di mana ia diubah, dan informasi tentang data tersebut. CLI ini juga digunakan untuk menetapkan jam tangan untuk menampilkan pemberitahuan tentang data.

Sintaksis

get /path

Sampel

get /FirstZnode

Keluaran

[zk: localhost:2181(CONNECTED) 1] get /FirstZnode
“Myfirstzookeeper-app”
cZxid = 0x7f
ctime = Tue Sep 29 16:15:47 IST 2015
mZxid = 0x7f
mtime = Tue Sep 29 16:15:47 IST 2015
pZxid = 0x7f
cversion = 0
dataVersion = 0
aclVersion = 0
ephemeralOwner = 0x0
dataLength = 22
numChildren = 0

Untuk mengakses znode berurutan, Anda harus memasukkan path lengkap dari znode tersebut.

Sampel

get /FirstZnode0000000023

Keluaran

[zk: localhost:2181(CONNECTED) 1] get /FirstZnode0000000023
“Second-data”
cZxid = 0x80
ctime = Tue Sep 29 16:25:47 IST 2015
mZxid = 0x80
mtime = Tue Sep 29 16:25:47 IST 2015
pZxid = 0x80
cversion = 0
dataVersion = 0
aclVersion = 0
ephemeralOwner = 0x0
dataLength = 13
numChildren = 0

Menonton

Jam tangan menampilkan notifikasi ketika data turunan znode atau znode yang ditentukan berubah. Anda dapat mengaturwatch hanya di get perintah.

Sintaksis

get /path [watch] 1

Sampel

get /FirstZnode 1

Keluaran

[zk: localhost:2181(CONNECTED) 1] get /FirstZnode 1
“Myfirstzookeeper-app”
cZxid = 0x7f
ctime = Tue Sep 29 16:15:47 IST 2015
mZxid = 0x7f
mtime = Tue Sep 29 16:15:47 IST 2015
pZxid = 0x7f
cversion = 0
dataVersion = 0
aclVersion = 0
ephemeralOwner = 0x0
dataLength = 22
numChildren = 0

Outputnya mirip dengan normal getperintah, tetapi itu akan menunggu perubahan znode di latar belakang. <Mulai di sini>

Atur Data

Atur data dari znode yang ditentukan. Setelah Anda menyelesaikan operasi set ini, Anda dapat memeriksa data menggunakanget Perintah CLI.

Sintaksis

set /path /data

Sampel

set /SecondZnode Data-updated

Keluaran

[zk: localhost:2181(CONNECTED) 1] get /SecondZnode “Data-updated”
cZxid = 0x82
ctime = Tue Sep 29 16:29:50 IST 2015
mZxid = 0x83
mtime = Tue Sep 29 16:29:50 IST 2015
pZxid = 0x82
cversion = 0
dataVersion = 1
aclVersion = 0
ephemeralOwner = 0x15018b47db00000
dataLength = 14
numChildren = 0

Jika Anda ditugaskan watch opsi di get perintah (seperti pada perintah sebelumnya), maka outputnya akan seperti gambar di bawah ini -

Keluaran

[zk: localhost:2181(CONNECTED) 1] get /FirstZnode “Mysecondzookeeper-app”

WATCHER: :

WatchedEvent state:SyncConnected type:NodeDataChanged path:/FirstZnode
cZxid = 0x7f
ctime = Tue Sep 29 16:15:47 IST 2015
mZxid = 0x84
mtime = Tue Sep 29 17:14:47 IST 2015
pZxid = 0x7f
cversion = 0
dataVersion = 1
aclVersion = 0
ephemeralOwner = 0x0
dataLength = 23
numChildren = 0

Buat Children / Sub-znode

Membuat anak mirip dengan membuat znode baru. Satu-satunya perbedaan adalah jalur znode turunan akan memiliki jalur induk juga.

Sintaksis

create /parent/path/subnode/path /data

Sampel

create /FirstZnode/Child1 firstchildren

Keluaran

[zk: localhost:2181(CONNECTED) 16] create /FirstZnode/Child1 “firstchildren”
created /FirstZnode/Child1
[zk: localhost:2181(CONNECTED) 17] create /FirstZnode/Child2 “secondchildren”
created /FirstZnode/Child2

Daftar Anak-anak

Perintah ini digunakan untuk mendaftar dan menampilkan file children dari sebuah znode.

Sintaksis

ls /path

Sampel

ls /MyFirstZnode

Keluaran

[zk: localhost:2181(CONNECTED) 2] ls /MyFirstZnode
[mysecondsubnode, myfirstsubnode]

Periksa Status

Statusmenjelaskan metadata dari znode tertentu. Ini berisi detail seperti Stempel waktu, Nomor versi, ACL, Panjang data, dan Znode anak.

Sintaksis

stat /path

Sampel

stat /FirstZnode

Keluaran

[zk: localhost:2181(CONNECTED) 1] stat /FirstZnode
cZxid = 0x7f
ctime = Tue Sep 29 16:15:47 IST 2015
mZxid = 0x7f
mtime = Tue Sep 29 17:14:24 IST 2015
pZxid = 0x7f
cversion = 0
dataVersion = 1
aclVersion = 0
ephemeralOwner = 0x0
dataLength = 23
numChildren = 0

Hapus sebuah Znode

Menghapus znode yang ditentukan dan secara rekursif semua anaknya. Ini hanya akan terjadi jika znode seperti itu tersedia.

Sintaksis

rmr /path

Sampel

rmr /FirstZnode

Keluaran

[zk: localhost:2181(CONNECTED) 10] rmr /FirstZnode
[zk: localhost:2181(CONNECTED) 11] get /FirstZnode
Node does not exist: /FirstZnode

Menghapus (delete /path) perintah mirip dengan remove perintah, kecuali fakta bahwa ia hanya bekerja pada znode tanpa anak.