Membuat dan mengelola klaster Kafka

Pengantar Apache Kafka

Mike Metzger

Data Engineering Consultant

Apa itu ZooKeeper?

  • ZooKeeper adalah kerangka kerja untuk mengelola informasi & menyediakan layanan yang diperlukan untuk menjalankan sistem terdistribusi
  • Utamanya digunakan pengembang untuk membuat aplikasi terdistribusi
    • Pengguna berinteraksi dengan ZooKeeper
  • Contoh aplikasi
    • Kafka
    • Hadoop
    • Neo4j

Logo Apache ZooKeeper

Pengantar Apache Kafka

Apa yang dilakukan ZooKeeper?

  • ZooKeeper menyediakan layanan yang diperlukan untuk menjalankan aplikasi terdistribusi
    • Penanganan konfigurasi
    • Penamaan sistem
    • Sinkronisasi antar sistem
    • Layanan yang dibutuhkan oleh sekumpulan sistem
  • Dirancang sebagai kerangka kerja agar tiap aplikasi terdistribusi tidak perlu mengimplementasikan layanan versi kustom.
    • Seperti konektor umum, mis. steker listrik atau kepala selang
Pengantar Apache Kafka

ZooKeeper dan Kafka

  • Kafka memakai ZooKeeper untuk manajemen klaster
    • Versi Kafka yang lebih baru dapat memakai KRaft
  • Dua berkas digunakan
    • config/zookeeper.properties
    • config/server.properties
# zookeeper.properties

# The directory where the 
# snapshot is stored.
dataDir=/tmp/zookeeper

# The port at which the clients 
# will connect
clientPort=2181

...
Pengantar Apache Kafka

config/server.properties

  • Menangani konfigurasi spesifik Kafka
    • Detail broker
    • Konfigurasi jaringan
    • Lokasi penyimpanan event
    • Konfigurasi topik dasar, termasuk replikasi
...
# A comma separated list of directories under which to store log files
log.dirs=/tmp/kafka-logs
# The default number of log partitions per topic.
num.partitions=1
Pengantar Apache Kafka

Menjalankan klaster Kafka

  • Klaster Kafka dijalankan dalam dua bagian
$ bin/zookeeper-server-start.sh config/zookeeper.properties
...
INFO   ______                  _                                           (org.apache.zookeeper.server.ZooKeeperServer)
INFO  |___  /                 | |                                          (org.apache.zookeeper.server.ZooKeeperServer)
INFO     / /    ___     ___   | | __   ___    ___   _ __     ___   _ __    (org.apache.zookeeper.server.ZooKeeperServer)
INFO    / /    / _ \   / _ \  | |/ /  / _ \  / _ \ | '_ \   / _ \ | '__| (org.apache.zookeeper.server.ZooKeeperServer)
INFO   / /__  | (_) | | (_) | |   <  |  __/ |  __/ | |_) | |  __/ | |     (org.apache.zookeeper.server.ZooKeeperServer)
INFO  /_____|  \___/   \___/  |_|\_\  \___|  \___| | .__/   \___| |_| (org.apache.zookeeper.server.ZooKeeperServer)
INFO                                               | |                      (org.apache.zookeeper.server.ZooKeeperServer)
INFO                                               |_|                      (org.apache.zookeeper.server.ZooKeeperServer)
INFO  (org.apache.zookeeper.server.ZooKeeperServer)
...
Pengantar Apache Kafka

Menjalankan klaster Kafka (lanj.)

$ bin/kafka-server-start.sh config/server.properties
INFO Awaiting socket connections on 0.0.0.0:9092. (kafka.network.DataPlaneAcceptor)
INFO Kafka version: 3.7.0 (org.apache.kafka.common.utils.AppInfoParser)
INFO Kafka commitId: 2ae524ed625438c5 (org.apache.kafka.common.utils.AppInfoParser)
INFO Kafka startTimeMs: 1717502877829 (org.apache.kafka.common.utils.AppInfoParser)
INFO [KafkaServer id=0] started (kafka.server.KafkaServer)
INFO [zk-broker-0-to-controller-forwarding-channel-manager]: Recorded new controller, 
     from now on will use node 815f25786085:9092 (id: 0 ra
Pengantar Apache Kafka

Menghentikan klaster Kafka

  • bin/kafka-server-stop.sh
  • bin/zookeeper-server-stop.sh
  • Perhatikan urutan penghentian terbalik
Pengantar Apache Kafka

Ayo berlatih!

Pengantar Apache Kafka

Preparing Video For Download...