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 Github Repositories Gitlab Repositories Mastodon Über mich home xmpp


Vor 5 Jahren hier im Blog

  • Certstream, InfluxDB, Grafana und Netflix

    16.04.2019

    Nachdem ich vor kurzem über mein erstes Spielen mit dem certstream berichtete, habe ich weitere Experimente gemacht und die Daten zur besseren Auswertung in eine InfluxDB gepackt, um sie mit Grafana untersuchen zu können.

    Weiterlesen...

Neueste Artikel

  • Die sQLshell ist nun cloudnative!

    Die sQLshell hat eine weitere Integration erfahren - obwohl ich eigentlich selber nicht viel dazu tun musste: Es existiert ein Projekt/Produkt namens steampipe, dessen Slogan ist select * from cloud; - Im Prinzip eine Wrapperschicht um diverse (laut Eigenwerbung mehr als 140) (cloud) data sources.

    Weiterlesen...
  • LinkCollections 2024 III

    Nach der letzten losen Zusammenstellung (für mich) interessanter Links aus den Tiefen des Internet von 2024 folgt hier gleich die nächste:

    Weiterlesen...
  • Funktionen mit mehreren Rückgabewerten in Java

    Da ich seit nunmehr einem Jahr bei meinem neeun Arbeitgeber beschäftigt und damit seit ungefähr derselben Zeit für Geld mit Python arbeite, haben sich gewisse Antipathien gegenüber Python vertieft (ich kann mit typlosen Sprachen einfach nicht umgehen) - aber auch einige meiner Gründe, Python zu lieben sind ebenso stärker geworden. Einer davon ist der Fakt, dass eine Methode in Python mehr als einen Wert zurückgeben kann.

    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, muß 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 GitHub-Repositories findet man hier - meine öffentlichen GitLab-Repositories finden sich dagegen hier.