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.