Galileo Computing < openbook > Galileo Computing - Professionelle Bücher. Auch für Einsteiger.
Professionelle Bücher. Auch für Einsteiger.

Inhaltsverzeichnis
Vorwort
1 Java ist auch eine Sprache
2 Sprachbeschreibung
3 Klassen und Objekte
4 Der Umgang mit Zeichenketten
5 Mathematisches
6 Eigene Klassen schreiben
7 Angewandte Objektorientierung
8 Exceptions
9 Generics, innere Klassen
10 Die Klassenbibliothek
11 Threads und nebenläufige Programmierung
12 Datenstrukturen und Algorithmen
13 Raum und Zeit
14 Dateien und Datenströme
15 Die eXtensible Markup Language (XML)
16 Grafische Oberflächen mit Swing
17 Grafikprogrammierung
18 Netzwerkprogrammierung
19 Verteilte Programmierung mit RMI und Web–Services
20 JavaServer Pages und Servlets
21 Applets
22 Midlets und die Java ME
23 Datenbankmanagement mit JDBC
24 Reflection und Annotationen
25 Logging und Monitoring
26 Sicherheitskonzepte
27 Java Native Interface (JNI)
28 Dienstprogramme für die Java-Umgebung
Stichwort

Download:
- ZIP, ca. 14,1 MB
Buch bestellen
Ihre Meinung?

Spacer
<< zurück
Java ist auch eine Insel (8. Auflage) von Christian Ullenboom
Programmieren mit der Java Standard Edition Version 6
Buch: Java ist auch eine Insel (8. Auflage)

Java ist auch eine Insel (8. Aufl.)
8., aktual. Auflage, geb., mit DVD
1.475 S., 49,90 Euro
Galileo Computing
ISBN 978-3-8362-1371-4
Pfeil 25 Logging und Monitoring
Pfeil 25.1 Logging mit Java
Pfeil 25.1.1 Logging-APIs
Pfeil 25.1.2 Logging mit log4j
Pfeil 25.2 Überwachen von Systemzuständen
Pfeil 25.3 MBean-Typen, MBean-Server und weitere Begriffe
Pfeil 25.3.1 MXBeans des Systems
Pfeil 25.4 Geschwätzige Programme und JConsole
Pfeil 25.4.1 JConsole
Pfeil 25.5 Der MBeanServer
Pfeil 25.6 Eine eigene Standard-MBean
Pfeil 25.6.1 Management-Schnittstelle
Pfeil 25.6.2 Implementierung der Managed-Ressource
Pfeil 25.6.3 Anmeldung beim Server
Pfeil 25.6.4 Eigene Bean in JConsole
Pfeil 25.7 Zum Weiterlesen


Galileo Computing - Zum Seitenanfang

25.3 MBean-Typen, MBean-Server und weitere Begriffe Zur nächsten ÜberschriftZur vorigen Ü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 Ad-ministration 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 instrumentiert werden (Hardware, Software, Dienste ...). Diese Instrumentierung 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-Spezifkation 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 den MBeans zuzugreifen.


Galileo Computing - Zum Seitenanfang

25.3.1 MXBeans des Systems topZur vorigen Überschrift

Die JVM repräsentiert Systeminformationen nicht nur über die System-Properties, sondern seit Java 5 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, unter ihnen:

  • ClassLoadingMXBean. Informiert, 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. GCs: 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

Exemplare konkreter Klassen, die oben genannte Schnittstellen implementieren, liefern Fabrikfunktionen 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 25.2 com/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 
  } 
}


Ihr Kommentar

Wie hat Ihnen das <openbook> gefallen? Wir freuen uns immer über Ihre freundlichen und kritischen Rückmeldungen.






<< zurück
  Zum Katalog
Zum Katalog: Java ist auch eine Insel





Java ist auch eine Insel
Jetzt bestellen


 Ihre Meinung?
Wie hat Ihnen das <openbook> gefallen?
Ihre Meinung

 Tipp
Zum Katalog: Coding for Fun





 Coding for Fun


 Buchempfehlungen
Zum Katalog: Objektorientierte Programmierung





 Objektorientierte
 Programmierung


Zum Katalog: Einstieg in Eclipse 3.4






 Einstieg in
 Eclipse 3.4


Zum Katalog: Java 6 lernen mit Eclipse






 Java 6 lernen
 mit Eclipse


Zum Katalog: NetBeans Platform 6






 NetBeans
 Platform 6


Zum Katalog: Java und XML






 Java und XML


Zum Katalog: Visual C# 2008






 Visual C# 2008


Zum Katalog: IT-Handbuch für Fachinformatiker






 IT-Handbuch für
 Fachinformatiker


Zum Katalog: C++ von A bis Z






 C++ von A bis Z


 Shopping
Versandkostenfrei bestellen in Deutschland und Österreich
InfoInfo




Copyright © Galileo Press 2009
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.


[Galileo Computing]

Galileo Press, Rheinwerkallee 4, 53227 Bonn, Tel.: 0228.42150.0, Fax 0228.42150.77, info@galileo-press.de