JMX zur Überwachung am Beispiel eines HTTP Proxy

vorhergehende Artikel in: Java Komponenten
06.04.2015

Ich war schon immer der Meinung, dass die Java Management Extensions eine stark unterschätzte Technologie sind, die nie zu der ihr zustehenden Bedeutung gekommen sind. Mein letztes Projekt bestärkte mich nochmals in dieser Meinung.

Ich habe neulich den Faden wiederaufgenommen, der schon geraume Zeit darauf wartete: Ich wollte eine Proxy-Infrastrukur schaffen, die über Plugins verschiedene Verhalten implementieren kann.

Dazu hatte ich angefangen, war aber in einem Stadium steckengeblieben, in dem der Proxy nicht nutzbar war: er leitete den Verkehr einfach nur durch - und auch da nicht immer korrekt.

Nachdem ich mich nun wieder einmal über den ganzen Werbemüll aufgeregt habe, der meine eh schon bescheidene, instabile 1 MBit-Leitung verstopft, habe ich mich nochmals hingesetzt und die verschiedenen Möglichkeiten geprüft, dieses abzustellen. Die bisher von mir eingesetzte über eine eigene Hosts-Datei, in der alle Namen von bösen Hosts auf localhost umgeleitet werden, hat zwei Nachteile:

  1. Wartung ist schwierig und funktioniert nur als root.
  2. Es ist nicht möglich, ganze Domains einzubinden - es können auf diese Art und Weise nur einzelne Rechner gesperrt werden.

Dann fand ich einen in Java geschriebenen Proxy, der gegen Ads und Tracker helfen sollte. Das erinnerte mich wieder an meinen eigenen Versuch und ich aktivierte ihn. Nach eingehender Analyse des vorliegenden Standes wurden folgende Verbesserungen umgesetzt:

  1. Refactoring des Codes
  2. AdBlock-Plugin mit Blacklist für Domains und Black- und Whitelist für Hosts
  3. Socketpool zur Effizienzsteigerung
  4. Threadpool zur Effizienzsteigerung
Nachdem diese Änderungen fertig umgesetzt waren, habe ich kurz über eine Möglichkeit nachgedacht, besonders die Pools, aber auch das Gesamtverhalten überwachen zu können. Mir fiel da eigentlich sofort JMX ein: Nach Hinzufügen entsprechender Interfaces konnte ich die Leistungsdaten der zentralen Komponenten sofort in der JConsole visualisieren:

public interface AdBlockWorkerStatisticsMBean
{
	public int getBlockedCount();
	public int getPassedOnCount();
	public void resetBlockedCount();
	public void resetPassedOnCount();
}

Screenshot Überblick über die Anzahl geblockter und durchgeleiteter Anfragen anhand der Namen der Hosts

public interface SocketPoolMBean
{
	public int getAvailableCount();
	public int getInUseCount();
}

Screenshot Überblick über die Anzahl im Pool befindlicher und aktuell genutzter Sockets

public interface ThreadManagerMBean
{
	public int getMinimumAvailableIdleThreadsAfterSweep();
	public void setMinimumAvailableIdleThreadsAfterSweep(int minimumAvailableIdleThreadsAfterSweep) throws java.beans.PropertyVetoException;
	public long getMaxAgeOfIdleThreadsInMillis();
	public void setMaxAgeOfIdleThreadsInMillis(long maxAgeOfIdleThreadsInMillis) throws java.beans.PropertyVetoException;
	public void setMaxthreads(int newmaxthreads);
	public int getMaxthreads();
	public int getAvailableCount();
	public int getWorkingCount();
	public int getWaitingCount();
	public int getMaxUsedThreads();
	public void resetMaxUsedThreads();
}

Screenshot Überblick über die Anzahl im Pool befindlicher und aktuell genutzter Threads

Alle Artikel rss Wochenübersicht Monatsübersicht Codeberg Repositories Mastodon Über mich home xmpp


Vor 5 Jahren hier im Blog

  • Open Source Switch Firmware

    05.09.2020

    Einige Links zum Thema...

    Weiterlesen

Neueste Artikel

  • Datenmodell für Inventarisierung

    Im vorhergehenden Artikel zum Thema Inventarisierung habe ich beschrieben, wie ich Rechner und deren Komponenten für meinen Haushalt/Labor mit einer sehr schnellen Lösung umfassend dokumentiert habe. Diese Beschränkung auf Rechner reicht natürlich nicht aus.

    Weiterlesen
  • Komponentenupdate und -refactoring 2025

    Ich habe wieder einmal einige Änderungen und Verbesserungen an den Komponenten ausgeführt, die Anwendungen wie der sQLshell oder dWb+ zugrundeliegen.

    Weiterlesen
  • Hardware-Inventarisierung mal anders(?)

    Ich habe bereits seit einiger Zeit immer mal wieder vor, die in meinen Bastelschränken und auf meinem Schreibtisch vorhandenen Hardwarekomponenten sauber zu inventarisieren. Alle meine bisherigen Versuche schlugen jedoch fehl, da ich mich bisher darauf fokussierte, eine self-hosted Anwendung dafür zu finden. Allerdings sind mir die üblichen Verdächtigen entweder zu schwergewichtig oder zu unflexibel. Ich kam aber auf eine (für mich) neue Idee:

    Weiterlesen

Manche nennen es Blog, manche Web-Seite - ich schreibe hier hin und wieder über meine Erlebnisse, Rückschläge und Erleuchtungen bei meinen Hobbies.

Wer daran teilhaben und eventuell sogar davon profitieren möchte, muss damit leben, daß ich hin und wieder kleine Ausflüge in Bereiche mache, die nichts mit IT, Administration oder Softwareentwicklung zu tun haben.

Ich wünsche allen Lesern viel Spaß und hin und wieder einen kleinen AHA!-Effekt...

PS: Meine öffentlichen Codeberg-Repositories findet man hier.