Observability of the Java Virtual Machine

Image
The JVM is one of the most observable runtimes. It provides us lots of tools for troubleshooting a JVM application in production. 1. Thread observability Threads are how the JVM actually does work. When something is wrong in production, the symptom is almost always a thread: stopped, blocked, leaking etc. Thread dumps work on any JVM with no  instrumentation, no agents, no restarts. <Example project link with /threaddump endpoint>         // (1) Deadlock — two threads grab the same pair of locks in opposite order.         new Thread(() -> grab(LOCK_A, LOCK_B), "deadlock-A-then-B").start();         new Thread(() -> grab(LOCK_B, LOCK_A), "deadlock-B-then-A").start(); http://localhost:8080/actuator/threaddump To list the JVMS, we can use the command below. PS C:\observe-jvm> jps -lv 25296 jdk.jcmd/sun.tools.jps.Jps -Dapplication.home=C:\Program Files\Microsoft\jdk-21.0.3.9-hotspot -Xms8m -Djdk.module.main=...

NoSQL - Bölüm 3 : Yatay / Dikey Ölçeklenebilirlik

Yatay ölçeklenebilirlik (horizontal scalability) bir sistemin performansını kaynak havuzuna yeni makineler ekleyerek sağlamak anlamındadır. Buna karşılık dikey ölçeklenebilirlik (vertical scalability) ile kastedilen mevcut sistemin CPU, RAM gibi bileşenlerini güçlendirerek elde edilen performanstır. 
Veritabanı dünyasında horizontal scalability örneği olarak "sharding" uygulamasını gösterebiliriz. Burada verinin farklı kısımları farklı makinelere dağıtılarak yük dağılımı sağlanmaya çalışılır. Örneğin Amerika'da ikamet eden kullanıcıların bilgilerinin Amerika'daki server üzerinde tutulması gibi. Eğer yazılım sık gerçekleşen bir işlem tipi için çok sayıda "shard" üzerinden bilgi çekmek zorunda kalıyorsa burada performans iyileşmesinden söz edilemez. 
Diğer bir yöntem de "replication" uygulamasıdır. Bu kez veri kopyalanarak farklı makinelere dağıtılır. Örneğin bir master veritabanı ve N adet slave veritabanı sözkonusu olur. Bu veritabanları aynı bilgileri tutarlar fakat yük dağıtımı sağlanmıştır. Sharding ve replication bir arada da kullanılabilmektedir. Replication, okuma işlemi için yük dengelemesi sağlarken yazma işlemi için yük dağılımı sağlamamaktadır. Oysa sharding, yazma işlemleri için de yatay ölçeklenebilirlik sağlamaktadır.
Master-slave replication uyguladığımızda, slave makineler üzerindeki hatalar telafi edilebilir fakat burada esas olan master olduğu için master makine burada bir hata noktasıdır. 
Peer-to-peer replication uygulamasında ise master yoktur. Tüm node bileşenleri eşit şekilde ele alınır ve yazma işlemlerini kabul ederler. Herhangi birisi çöktüğünde bile hala veriye erişim sağlanabilmektedir. 



Comments

Popular posts from this blog

The WeakReference class, monitoring memory leak and garbage collection in a Java application

Simplescalar Simulator - Part 2: sim-outorder.c

Notes on Java Performance