Rheinwerk Computing < openbook > Rheinwerk Computing - Professionelle Bücher. Auch für Einsteiger.
Professionelle Bücher. Auch für Einsteiger.
 
Inhaltsverzeichnis
Vorwort
1 Neues in Java 8 und Java 7
2 Fortgeschrittene String-Verarbeitung
3 Threads und nebenläufige Programmierung
4 Datenstrukturen und Algorithmen
5 Raum und Zeit
6 Dateien, Verzeichnisse und Dateizugriffe
7 Datenströme
8 Die eXtensible Markup Language (XML)
9 Dateiformate
10 Grafische Oberflächen mit Swing
11 Grafikprogrammierung
12 JavaFX
13 Netzwerkprogrammierung
14 Verteilte Programmierung mit RMI
15 RESTful und SOAP-Web-Services
16 Technologien für die Infrastruktur
17 Typen, Reflection und Annotationen
18 Dynamische Übersetzung und Skriptsprachen
19 Logging und Monitoring
20 Sicherheitskonzepte
21 Datenbankmanagement mit JDBC
22 Java Native Interface (JNI)
23 Dienstprogramme für die Java-Umgebung
Stichwortverzeichnis

Jetzt Buch bestellen
Ihre Meinung?

Spacer
<< zurück
Java SE 8 Standard-Bibliothek von Christian Ullenboom
Das Handbuch für Java-Entwickler
Buch: Java SE 8 Standard-Bibliothek

Java SE 8 Standard-Bibliothek
Pfeil 19 Logging und Monitoring
Pfeil 19.1 Logging mit Java
Pfeil 19.1.1 Logging-APIs
Pfeil 19.1.2 Logging mit java.util.logging
Pfeil 19.1.3 Logging mit log4j *
Pfeil 19.1.4 Die Simple Logging Facade
Pfeil 19.1.5 Aktuelle Entwicklungen der Java-Logging-APIs
Pfeil 19.2 Systemzustände überwachen
Pfeil 19.3 MBean-Typen, MBean-Server und weitere Begriffe
Pfeil 19.3.1 MXBeans des Systems
Pfeil 19.4 Geschwätzige Programme und JConsole
Pfeil 19.4.1 JConsole
Pfeil 19.5 Der MBeanServer
Pfeil 19.6 Eine eigene Standard-MBean
Pfeil 19.6.1 Management-Schnittstelle
Pfeil 19.6.2 Implementierung der Managed-Ressource
Pfeil 19.6.3 Anmeldung beim Server
Pfeil 19.6.4 Eine eigene Bean in JConsole einbringen
Pfeil 19.7 Zum Weiterlesen
 
Zum Seitenanfang

19.3MBean-Typen, MBean-Server und weitere Begriffe Zur vorigen ÜberschriftZur nächsten Überschrift

Um mit JMX zu arbeiten, ist ein wenig Vokabular nötig. Eine Managed Component ist die überwachte Komponente. Hinter den beobachtbaren Komponenten stehen die so genannten MBeans, die an einem MBean-Server registriert werden. Der Zugriff auf die Komponenten erfolgt über einen Adapter, etwa einen HTTP-Adapter, der dann einem Webbrowser die Administration erlaubt. Neben einem HTTP-Adapter sind für den Zugriff auf die MBeans andere Adaptoren denkbar: RMI oder SNMP zum Beispiel. Sie stehen auf dem Connector-Level. Der Webbrowser steht hingegen auf einer höheren Stufe beim Remote Manager. Ganz unten stehen die zu überwachenden Komponenten. Sie heißen instrumentalisierte Objekte, und alle Java-Objekte können mit JMX instrumentalisiert werden (Hardware, Software, Dienste, …). Diese Instrumentalisierung erfolgt über MBeans. Wichtig zum Verständnis ist die Tatsache, dass die überwachten Elemente selbst im Allgemeinen nicht auch die über JMX administrierten Objekte sind, sondern dass die MBeans die Repräsentanten sind.

Die JMX-Spezifikation definiert fünf Typen von MBeans:

  • Standard-MBeans

  • Dynamic MBeans

  • Model-MBeans

  • Open MBeans

  • MXBeans

Die Standard-MBeans stellen den einfachsten Weg für die JMX-Instrumentierung dar. Die nach außen offengelegte Schnittstelle (Management Interface) spezifiziert der Entwickler explizit, indem er sie in einem Java-Interface deklariert.

Wir werden uns im Folgenden mit den einfachen MBeans und MXBeans beschäftigen. Neben den anderen MBeans-Typen bietet der JMX-Standard weitere Möglichkeiten, etwa ein Benachrichtigungsmodell (engl. notification model), das Änderungen an den Komponenten überwacht und meldet, oder die Möglichkeit, remote auf MBeans zuzugreifen.

 
Zum Seitenanfang

19.3.1MXBeans des Systems Zur vorigen ÜberschriftZur nächsten Überschrift

Die JVM repräsentiert Systeminformationen nicht nur über die System-Properties, sondern auch über MXBeans(Java Management Beans). MXBeans sind eine Erweiterung der MBeans, damit sie in einer Management-Konsole leichter zu verwenden sind. Vorhandene MXBeans geben Auskünfte über den Zustand der JVM. Zu ihnen zählen:

  • ClassLoadingMXBean: Informiert darüber, wie viele Klassen geladen sind und wann die Laufzeitumgebung eine Klasse lädt.

  • CompilationMXBean: Zeit für die Übersetzung

  • MemoryMXBean: komplexe Bean mit Informationen über den Speicherverbrauch

  • ThreadMXBean: komplexe Bean mit Infos über Threads

  • RuntimeMXBean: Welche Laufzeitumgebung führt aus? Wie ist der Bibliothekspfad/Klassenpfad …?

  • OperatingSystemMXBean: wenige Systeminfos

  • GarbageCollectorMXBean: Implementierungen zur automatischen Speicherbereinigung: Copy, MarkSweepCompact

  • MemoryManagerMXBean: Welche Speicherverwaltung: CodeCacheManager, Copy, MarkSweepCompact?

  • MemoryPoolMXBean: komplexe MBean für Speicherinformationen, etwa für Code Cache, Eden Space, Survivor Space, Tenured Gen, Perm Gen

Die Typen liegen im Paket java.lang.management, aber es gibt noch einen Typ com.sun.management.OperatingSystemMXBean (nicht das namensgleiche java.lang.management.OperatingSystemMXBean) mit neuen Methoden getSystemCpuLoad() und getProcessCpuLoad().

Exemplare konkreter Klassen, die oben genannte Schnittstellen implementieren, liefern Fabrikmethoden der Klasse ManagementFactory. Die Typen stammen alle aus dem Paket java.lang.management:

class java.lang.management.ManagementFactory
  • static ClassLoadingMXBean getClassLoadingMXBean()

  • static CompilationMXBean getCompilationMXBean()

  • static List<GarbageCollectorMXBean> getGarbageCollectorMXBeans()

  • static List<MemoryManagerMXBean> getMemoryManagerMXBeans()

  • static MemoryMXBean getMemoryMXBean()

  • static List<MemoryPoolMXBean> getMemoryPoolMXBeans()

  • static OperatingSystemMXBean getOperatingSystemMXBean()

  • static RuntimeMXBean getRuntimeMXBean()

  • static ThreadMXBean getThreadMXBean()

Testen wir das an einem Beispiel:

Listing 19.4com/tutego/insel/jmx/JvmMBeans.java

package com.tutego.insel.jmx;

import java.lang.management.*;

public class JvmMBeans {
public static void main( String[] args ) {
MemoryMXBean memoryMXBean = ManagementFactory.getMemoryMXBean();

// init = 0(0K) used = 169568(165K) committed = 2031616(1984K) max = 66650112(65088K)
System.out.println( memoryMXBean.getHeapMemoryUsage() );

// init = 29556736(28864K) used = 12026264(11744K)
// committed = 29851648(29152K) max = 121634816(118784K)
System.out.println( memoryMXBean.getNonHeapMemoryUsage() );

ClassLoadingMXBean classLoadingMXBean =
ManagementFactory.getClassLoadingMXBean();
System.out.println( classLoadingMXBean.getLoadedClassCount() ); // 301
System.out.println( classLoadingMXBean.getTotalLoadedClassCount() ); // 301


System.out.println( classLoadingMXBean.getUnloadedClassCount() ); // 0
}
}

 


Ihre Meinung

Wie hat Ihnen das Openbook gefallen? Wir freuen uns immer über Ihre Rückmeldung. Schreiben Sie uns gerne Ihr Feedback als E-Mail an kommunikation@rheinwerk-verlag.de.

<< zurück
 Zum Rheinwerk-Shop
Zum Rheinwerk-Shop: Java SE 8 Standard-Bibliothek Java SE 8 Standard-Bibliothek
Jetzt Buch bestellen

 Buchempfehlungen
Zum Rheinwerk-Shop: Java ist auch eine Insel
Java ist auch eine Insel


Zum Rheinwerk-Shop: Professionell entwickeln mit Java EE 8
Professionell entwickeln mit Java EE 8


Zum Rheinwerk-Shop: Besser coden
Besser coden


Zum Rheinwerk-Shop: Entwurfsmuster
Entwurfsmuster


Zum Rheinwerk-Shop: IT-Projektmanagement
IT-Projektmanagement


 Lieferung
Versandkostenfrei bestellen in Deutschland, Österreich und der Schweiz
InfoInfo

 
 


Copyright © Rheinwerk Verlag GmbH 2018
Für Ihren privaten Gebrauch dürfen Sie die Online-Version natürlich ausdrucken. Ansonsten unterliegt das Openbook denselben Bestimmungen, wie die gebundene Ausgabe: Das Werk einschließlich aller seiner Teile ist urheberrechtlich geschützt.
Alle Rechte vorbehalten einschließlich der Vervielfältigung, Übersetzung, Mikroverfilmung sowie Einspeicherung und Verarbeitung in elektronischen Systemen.

 
Nutzungsbestimmungen | Datenschutz | Impressum

Rheinwerk Verlag GmbH, Rheinwerkallee 4, 53227 Bonn, Tel.: 0228.42150.0, Fax 0228.42150.77, service@rheinwerk-verlag.de

Cookie-Einstellungen ändern