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=...

Java Ortamında Ağ Uygulamalarına Genel Bakış

Ağ uygulamalarında karşımıza çıkan ilk kavram “ağ sunucusu (web server)” kavramı. Microsoft tarafında IIS (Internet Information Services) tek tip ağ sunucusu iken, Java tarafında birçok organizasyonun yazdığı ağ sunucuları mevcut. Java tarafında, programcıların makinelerinde geliştirme esnasında Apache Tomcat yaygın olarak kullanılmakta. Üretim (production) ortamında ise IBM Websphere gibi seçenekler mevcut.

Ağ sunucusu yazılımı, önceden belli olan bir dizin içerisine yerleştirilmiş ağ uygulamasını çalıştırmakla yükümlüdür. Ağ sunucusuna browser yoluyla HTTP istekleri (request) göndeririz ve HTTP cevapları (response) alırız. Cevap genellikle HTML biçimindedir. Java tarafında ağ sunucularının yazımı ile ilgili standartlar belirlenmiştir. Örneğin denilir ki, WEB-INF adlı dizin içerisinde bulunan web.xml dosyası uygulamanın nasıl çalıştırılacağına ilişkin çeşitli bilgileri tutar. Burada elbette bir “Servlet” teknolojisi ve standardı da işin içindedir.

Bugün bir Java ağ uygulaması geliştireceksek, seçmemiz gereken geliştirme çatıları hangileridir? Öncelikle “web framework” adı verilen bir geliştirme çatısı seçmeliyiz. Seçenekler arasında Struts, Spring MVC gibi çatılar göze çarpıyor. Seçmemiz gereken diğer bir framework ise, görüntü (view) şablonudur. Başka bir ifade ile, bir “template engine” seçmek durumundayız. Seçenekler arasında JSP, Velocity ve FreeMarker göze çarpıyor. Şu bir gerçek ki, Java tarafında büyük firmalardan bağımsız veya onların desteği ile geliştirilen açık kaynak kodlu projeler, programcı topluluğunun (community) yönelimleri (trend) belirlemesine sebep olmakta.

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