Red Hat Training

A Red Hat training course is available for Red Hat JBoss Enterprise Application Platform

7.0.0 Versionshinweise

Red Hat JBoss Enterprise Application Platform 7.0

Für den Gebrauch mit der Red Hat JBoss Enterprise Application Platform 7

Red Hat Customer Content Services

Zusammenfassung

Diese Versionshinweise enthalten wichtige Informationen zur Red Hat JBoss Enterprise Application Platform 7.

Kapitel 1. Neue Features und Verbesserungen

Kompatibilität und Interoperabilität
  • EJB, JMS und WS Clients sind über alle Nebenreleases und Patch-Releases von JBoss EAP 7 hinweg kompatibel.
  • Ein Domain-Administrator, der von JBoss EAP 7 verwaltet wird, kann Domain Hosts und Server der JBoss EAP 6 verwalten.
  • Ein JBoss EAP 7 Domain Controller kann andere JBoss EAP 7 Hosts in einer Managed Domain verwalten, so lange der Domain Controller dieselbe oder eine aktuellere Version als der Rest der Domain besitzt.
  • Es existiert eine Interoperabilität entfernter EJB-Aufrufe zwischen JBoss EAP 5 oder JBoss EAP 6 auf der einen Seite und JBoss EAP 7 auf der anderen Seite, wenn Sie die aktuellste Version der JBoss EAP 5 oder JBoss EAP 6 ausführen.

    Die folgenden Szenarien sind möglich:

    • Methodenaufruf an entfernten EJBs durch RMI, IIOP oder über SOAP-Webdienste.
    • Weitergabe des Sicherheitskontexts.
    • Weitergabe der Transaktion.
  • Entfernte EJB-Aufrufe zwischen JBoss EAP 7 und JBoss EAP 5 sind jetzt über IIOP möglich. Zwischen JBoss EAP 6 und JBoss EAP 7 sind die Aufrufe auch über EJB API-Aufrufe mittels JNDI möglich.
  • JBoss EAP 5 Interoperabilität wird bei Verwendung von Webdiensten in der Release unterstützt.
  • JBoss EAP 7 liefert Messaging-Konsolidierung und Rückwärtskompatibilität mit JBoss EAP 6. Die JBoss EAP 6 HornetQ Code-Basis wurde dem Apache ActiveMQ Projekt bereitgestellt und die HornetQ Community half beim Erstellen eines Messaging-Brokers der nächsten Generation. Dies wurde in der ersten Hauptrelease des ActiveMQ Artemis Projekts umgesetzt. ActiveMQ Artemis beinhaltet zahlreiche neue Funktionen und behält außerdem die Protokollkompatibilität mit dem HornetQ Broker bei. JBoss EAP 7 beinhaltet dieses neue aufregende Projekt als seinen JMS-Broker und ersetzt aufgrund der Protokollkompatibilität das HornetQ Projekt vollständig.
JBoss EAP 7 Verwaltung
  • JBoss EAP 7 beinhaltet eine aktualisierte Benutzeroberfläche der Management-Konsole für vereinfachte Navigation sowie erweiterten Support für Domain-Konfigurationen in großem Rahmen.
  • Die JBoss EAP Produktversion wird in der linken unteren Ecke der Management-Konsole angezeigt. Klicken Sie auf den Link um Profil, Version, HAL Version und Core-Version einzusehen.
  • Mit dem Management-CLI können Administratoren den Verlauf von Konfigurationsänderungen sehen, die von anderen autorisierten Administratoren vorgenommen wurden.
  • Erweiterte Protokollierungsverwaltung bietet die Möglichkeit, die verfügbaren Protokolldateien auf einem Server einzusehen, benutzerdefinierte Formatierer für Protokolle in der Management-Konsole zu bestimmen und Protokollierung auf Subsystem-Ebene im Management-CLI zu konfigurieren.
  • Sie können einen Server mit dem Management-CLI verwalten, ohne den Server starten zu müssen. Dieses Offline Management-CLI funktioniert auf ähnliche Weise, wie der admin-only-Modus, erfordert jedoch keinen Start des Servers und keine Verwendung eines TCP-Ports. Das CLI bettet den Server ein und startet ihn direkt im admin-only-Modus.
  • Ist das Subsystem PicketLink Federation aktiviert, so kann es mit der Management-Konsole konfiguriert werden.
  • Ein Administrator kann mit dem Management-CLI eine Installationszusammenfassung von Standalone und Managed Domain Serverinstancen erstellen.
  • Sie können Ihr eigenes Profil erstellen, indem Sie existierende JBoss EAP Profile (default, full, ha, full-ha) aus Management-CLI oder Management-Konsole klonen.
  • Auf der Startseite der Management-Konsole finden Sie den Link Einführung. Klicken Sie auf diesen Link, um sich die neu überarbeitete Management-Konsole präsentieren zu lassen.
  • Ein Administrator kann den Parameter resolve-expressions im Management-CLI verwenden, um die Ausdrücke der ausgegebenen Attribute zu ihren Werten auf dem Server aufzulösen.
  • In einer Managed Domain kann ein Administrator eine Profilhierarchie erstellen. Dies ermöglicht die Erzeugung eines Basisprofils mit allgemeinen Verbesserungen, die von anderen Profilen geerbt werden können.
Anmerkung

Weitere Informationen über die Management-Konsole finden Sie im Abschnitt Management-Konsole im JBoss EAP Konfigurationshandbuch.

Weitere Informationen zum Management-CLI finden Sie im JBoss EAP Management-CLI Handbuch.

Hoch skalierbarer Webserver (Undertow)
  • Die Implementierung von Webserver und Servlet wurde von JBoss Web zu Undertow geändert. Undertow ist ein moderner NIO-Webserver, der für maximalen Durchsatz und Skalierbarkeit entworfen wurde, auch für Umgebungen mit mehr als einer Million Verbindungen. Er unterstützt nicht sperrende und sperrende Handler, traditionelle und asynchrone Servlets sowie JSR-356 WebSocket.
  • Mit Undertow kann die JBoss EAP 7 auch dazu konfiguriert werden, als Lastverteiler für mehrere Plattformen zu agieren.
  • Sie können mehrere HTTP-Sitzungen zwischen mehreren WAR-Modulen in demselben EAR teilen.
  • Undertow beinhaltet Handler, die Funktionen von JBoss Web-Valves ersetzen.
Anmerkung

Weitere Informationen finden Sie unter Konfigurieren des Webservers (Undertow) im JBoss EAP Konfigurationshandbuch.

Java EE 7

JBoss EAP 7 implementiert die Java EE 7 Full Platform und Web-Profil-Standards, einschließlich:

  • Batch 1.0
  • JSON-P 1.0
  • Concurrency 1.0
  • WebSocket 1.1
  • JMS 2.0
  • JPA 2.1
  • JCA 1.7
  • JAX-RS 2.0
  • JAX-WS 2.2
  • Servlet 3.1
  • JSF 2.2
  • JSP 2.3
  • EL 3.0
  • CDI 1.2
  • JTA 1.2
  • Interceptors 1.2
  • Allgemeine Anmerkungen 1.1
  • Managed Beans 1.0
  • EJB 3.2
  • Bean-Validierung 1.1
Java SE 8
  • JBoss EAP 7 erfordert Java SE 8 und JBoss EAP 7 wurde getestet mit Open JDK 8, Oracle JDK 8, IBM JDK 8 und HP JDK 8.
Clustering
  • Neu optimierte Sitzungsreplikation und Implementierung von Einmal-Anmeldung (Single Sign-On) mittels Undertow.
  • Neue verbesserte Verteilung von @Stateful EJB Caching-Implementierung.
  • HA-Singleton Deployments (für Failover Anwendungsfälle ähnlich JBoss EAP 5. Zum Beispiel aktivierte EJB-Deployments in einem Knoten im Cluster).
  • Neues API für HA-Singleton-Dienste.
JCA und Datenquellen
  • Der erweiterte JCA Connection Manager umfasst Verbesserungen für den »lazy« Connection-Manager.
  • Über die Datenquellen- und Ressourcenadapter-Subsysteme können Sie Kapazitätsrichtlinien festlegen.
  • Die Deaktivierung von Enlistment-Tracing in IronJacamar wird voll unterstützt.
  • Sie können JDBC-Anweisungen ausführen, wenn eine JDBC-Verbindung von einem Pool erhalten und an den Pool zurückgegeben wird.
  • Es ist jetzt möglich eine bestimmte ManagedConnectionPool Implementierungsklasse für jede Datenquelle und jede Verbindungsdefinition eines Ressourcenadapters auszuwählen.
  • Sie können die Fairness-Einstellung der Semaphore-Klasse über die Subsysteme von Datenquellen und Ressourcenadaptern konfigurieren. Diese Klasse wird verwendet, um die Verbindungs-Pools in JCA zu verwalten, was in manchen Anwendungsfällen einen Leistungsvorteil bietet, wenn die Reihenfolge der Lease-Verbindungen nicht erforderlich ist.
Anmerkung

Weitere Informationen finden Sie unter Java Connector Architecture (JCA) Management und Datenquellen-Parameter im JBoss EAP Konfigurationshandbuch.

Java EE Sicherheits-Manager
Die Bereitstellung von Deployment-Berechtigungen basiert auf der Java EE 7 Spezifikation, genauer gesagt META-INF/permissions.xml im Deployment höchster Ebene. Sie können die Berechtigungen unter Verwendung einer benutzerdefinierten Deployment-Deskriptor META-INF/jboss-permissions.xml Datei optimieren,was auch für Submodule des Deployments definiert werden kann. Weitere Information zu Konfigurationsberechtigungen finden Sie unter Konfiguration von Server-Sicherheit für JBoss EAP.
Verbesserungen bei der Modularität
  • Mit dem Management-API können Sie Modulabhängigkeiten anzeigen.
  • Index wird für Statik-Module automatisch erstellt. Das Statik-Modul muss keinen vorab generierten Index für Annotationen enthalten, damit Applikationen Java EE Komponenten im Statik-Modul verwenden.
Anmerkung

Weitere Informationen finden Sie im Bereich Module im JBoss EAP Konfigurationshandbuch.

Transaktionsverbesserungen
  • Eine XAResource, die Teil einer XA-Transaction ist und XAResourceWrapper implementiert, bleibt synchron, wenn die XA-Ressource vor einem Absturz des Transaction-Managers ausgeführt wird. Ein manueller Eingriff nach dem Neustart des Transaction-Managers ist nicht mehr notwendig.

    Anmerkung

    Dieses Feature funktioniert nicht für Ressourcenmanager von Drittanbietern, die XAResourceWrapper nicht implementieren. Es funktioniert insbesondere nicht für Ressourcenmanager von WebSphere MQ.

»Server Suspend« Modus/Ordnungsgemäßes Herunterfahren
  • Ist der neue »Server Suspend«-Modus in JBoss EAP 7 aktiviert, so lehnt er neue Anfragen ab, erlaubt aber die Fertigstellung bestehender Anfragen. Ist der Unterbrechungsprozess beendet, so kann der Server entweder ohne Abbruch aktueller Transaktionen gestoppt werden, in angehaltenem Status gewartet werden oder in den aktiven Status zurückversetzt werden, in dem neue Anfragen wieder zulässig sind. (Ausgenommen sind Messaging und Transaktionen; eingeschlossen sind Web, EJB, mod_cluster, Batch, Naming und teilweise EE Concurrency).
Anmerkung

Weitere Informationen finden Sie unter Suspend and Shut Down JBoss EAP Gracefully im JBoss EAP Konfigurationshandbuch.

Port-Reduktion

Die JBoss EAP 7 hat jetzt fast alle Protokolle im Multiplex-Modus auf zwei Ports. Diese zwei Ports umfassen:

  • Ein Management-Port (HTTP/JSON Management, HTTP Upgraded Remoting - Native Management & JMX, Management-Konsole).
  • Ein Applikations-Port (HTTP Servlet, JAX-RS, JAX-WS, WebSocket, HTTP Upgraded Remoting-EJB Invocation-Remote JNDI).
IIOP-Implementierung
  • Die IIOP-Implementierung wurde von JacORB zu einem Downstream Zweig des OpenJDK ORB geändert. Diese Änderung sollte zu einer besseren Interoperabilität mit der JVM ORB und dem Java EE RI führen.
Batch-Verbesserungen

Batch-Verbesserungen umfassen:

  • Verbesserungen bei der Überwachung, wie beispielsweise die Fähigkeit aktive Jobs, beendete Jobs und die Ausführungsschritte von Jobs aufzulisten.
  • Die Fähigkeit, Batch-Jobs über das Management-API zu starten, zu stoppen und fortzusetzen.
  • Die Fähigkeit, Batch-Jobs neu zu starten, die zuvor wegen eines Serverfehlers fehlgeschlagen sind. Der vorherige Status kann zurückgesetzt werden (d.h. ignore/log), sodass der Batch-Job an einem anderen Server in der Domain-Servergruppe ausgeführt werden kann.
Migration CLI Operationen für die eingestellten Subsysteme von JBoss EAP 6
  • Um Benutzern bei der Migration von alten Subsystemen zu JBoss EAP 6, wie beispielsweise JBoss Web, JacORB und HornetQ zu helfen, wurde ein Satz von Verwaltungsvorgängen eingeführt, durch die alte Konfigurationen zum äquivalenten neuen Subsystem konvertiert werden können. Da diese Vorgänge das zugrundeliegende Management-Ressourcenmodell migrieren, können sie auch von alten CLI-Skripten oder benutzerdefinierten Provisioning-Systemen verwendet werden.
Anmerkung

Weitere Informationen finden Sie unter Management CLI Migration Operation im JBoss EAP Migrationshandbuch.

Änderungen bei der Lieferung von JBoss EAP Natives und Apache HTTP Server

JBoss EAP 7 Natives werden in dieser Release anders geliefert als früher. Einige werden jetzt mit dem neuen Produkt Red Hat JBoss Core Services geliefert, eine Auswahl zusätzlicher Software, die in vielen Red Hat JBoss Middleware-Produkten gebräuchlich sind. Das neue Produkt ermöglicht Ihnen eine schnellere und beständigere Verteilung von Updates. Das Produkt JBoss Core Services steht an einer anderen Stelle im Red Hat Kundenportal als Download zur Verfügung.

  • Die folgende Tabelle listet die Unterschiede in den Lieferungsmethoden zwischen den Versionen auf.

    PaketJBoss EAP 6JBoss EAP 7

    AIO Natives für Messaging

    Wird in einem separaten "Native Utilities" Download mit dem Produkt geliefert

    In der JBoss EAP Distribution inbegriffen. Zusätzlicher Download ist nicht erforderlich.

    Apache HTTP Server

    Wird in einem separaten "Apache HTTP Server" Download mit dem Produkt geliefert

    Wird mit dem neuen Produkt JBoss Core Services geliefert

    mod_cluster, mod_jk, isapi und nsapi Konnektoren

    Wird in einem separaten "Webserver Connector Natives" Download mit dem Produkt geliefert

    Wird mit dem neuen Produkt JBoss Core Services geliefert

    JSVC

    Wird in einem separaten "Native Utilities" Download mit dem Produkt geliefert

    Wird mit dem neuen Produkt JBoss Core Services geliefert

    OpenSSL

    Wird in einem separaten "Native Utilities" Download mit dem Produkt geliefert

    Dies wurde in JBoss EAP7 weggelassen

    tcnatives

    Wird in einem separaten "Native Components" Download mit dem Produkt geliefert

    Dies wurde in JBoss EAP7 weggelassen

  • Sie sollten sich zudem folgender Änderungen bewusst sein:

    • Der Support für mod_cluster and mod_jk Konnektoren, die mit Apache HTTP Server von Red Hat Enterprise Linux RPM Channels verwendet werden, wurde eingestellt. Wenn Sie den Apache HTTP Server von Red Hat Enterprise Linux RPM Channels aus ausführen und Lastverteilung für JBoss EAP 7 Server konfigurieren müssen, können Sie folgendermaßen vorgehen:

      • Verwenden Sie den Apache HTTP Server, der von JBoss Core Services bereitgestellt wird.
      • Sie können die JBoss EAP 7 dazu konfigurieren, als Front-End Lastenverteiler zu agieren. Weitere Informationen finden Sie unter Configuring JBoss EAP as a Front-end Load Balancer im JBoss EAP Konfigurationshandbuch.
      • Sie können den Apache HTTP Server auf einem Rechner deployen, der unterstützt und supported and zertifiziert ist und dann den Lastenverteiler auf diesem Rechner ausführen. Eine liste von unterstützten Konfigurationen finden Sie unterOverview of HTTP Connectors im JBoss EAP 7 Konfigurationshandbuch.
    • Der Support für mod_cluster and mod_jk Konnektoren, die mit dem Apache HTTP Server von HP-UX Web Server Suites verwendet wurden, wurde eingestellt. Wenn Sie den Apache HTTP Server von HP-UX Web Server Suites aus verwenden und Lastenverteilung für JBoss EAP 7 Server konfigurieren müssen, können Sie folgendermaßen vorgehen:

      • Sie können die JBoss EAP 7 dazu konfigurieren, als Front-End Lastenverteiler zu agieren. Weitere Informationen finden Sie unter Configuring JBoss EAP as a Front-end Load Balancer im JBoss EAP Konfigurationshandbuch.
      • Sie können den Apache HTTP Server auf einem Rechner deployen, der unterstützt und zertifiziert ist, und dann den Lastenverteiler auf diesem Rechner ausführen. Eine Liste von unterstützten Konfigurationen finden Sie unter Overview of HTTP Connectors im JBoss EAP Konfigurationshandbuch.
  • Weitere Informationen zu JBoss Core Services finden Sie im Apache HTTP Server Installationshandbuch.

Kapitel 2. Technologievorschau

Moderne Enterprise Web Applications mit JavaScript auf JVM Serverseite (technische Vorschau für JBoss EAP 7.0)
  • JBoss EAP 7 ermöglicht JavaScript-Schreibvorgänge auf Serverseite (mittels JDK 8 Nashorn Fähigkeiten) zur schnellen Entwicklung von REST-Endpunkten, die CDI-Beans einziehen, JNDI-Lookups durchführen und JPA Entity Beans aufrufen können. Das Undertow-Projekt bietet diese Fähigkeit.
PowerShell Skripte

Die PowerShell Skripte sind nur zur technischen Vorschau verfügbar und werden nicht unterstützt. PowerShell Skripte wurden entwickelt, um korrekt mit Version 2 und Neueren zu funktionieren, weil JBoss EAP auf Windows Server 2008 R2 Enterprise x86_64 und Windows Server 2012 R2 Standard x86_64 unterstützt wird.

  • Standardmäßig benutzt Windows Server 2008 R2 Enterprise x86_64 die PowerShell Version 2. Eine neuere Version kann installiert werden.
  • Standardmäßig benutzt Windows Server 2012 R2 Standard x86_64 die PowerShell Version 4. Eine neuere Version kann installiert werden.

    Der Pfad der PowerShell Skripte lautet EAP_HOME/bin und Sie können die Skripte verwenden, wenn Sie moderne Skriptsprache auf Windows verwenden wollen.

Undertow bietet Support für den HTTP/2 Standard
Undertow bietet Support für den HTTP/2 Standard (technische Vorschau nur für JBoss EAP 7.0). HTTP/2 senkt die Latenz durch das Komprimieren von Headern und das Multiplexen von Streams über dieselbe TCP-Verbindung. Es unterstützt auch die Möglichkeit des Servers Ressourcen an den Client zu pushen, ehe er diese angefordert hat, wodurch Seiten schneller geladen werden.
Clustered Singleton MDB
Die Clustered Singleton MDB ist eine technische Vorschau in JBoss EAP 7. Wenn eine MDB als ein Clustered Singleton identifiziert und in einem Cluster bereitgestellt wurde, dann wird sie immer nur an einem Knoten aktiv sein. Wenn der Serverknoten fehlschlägt oder herunter fährt, dann ist die Clustered Singleton MDB auf einem anderen Knoten aktiviert und beginnt die Nachrichten auf diesem Knoten zu verbrauchen.
Vorlagen für Datenquellen in der Management Konsole
Die Datenquellen-Vorlage für die Erstellung neuer Datenquellen in der Management Konsole ist eine technische Vorschau in JBoss EAP 7.
JCA und Datenquellen
JBoss EAP 7 unterstützt die Implementierung von DistributedWorkManager, basierend auf dem Projekt JGroups. Dies ist lediglich eine technische Vorschau.
Transaktionsüberwachung

JBoss EAP 7 unterstützt Transaktionsüberwachung. Die ist lediglich eine technische Vorschau. Die beiden folgenden neuen Attribute wurden zur Überwachung der Transaktionen hinzugefügt:

  • number-of-system-rollbacks: Die Anzahl von Transaktionen, die aufgrund eines internen Systemfehlers zurückgesetzt werden mussten.
  • average-commit-time: Die durchschnittliche Zeit in Nanosekunden für die Ausführung einer Transaktion.

    Diese Statistiken sind nur durch den Standard JMX Client verfügbar.

    Anmerkung

    Eine geringe Anzahl stecken gebliebener Transaktionen kann die gesamte average-commit-time verfälschen.

Die Konfiguration bestimmter Subsysteme in der Management Konsole

Die Konfiguration bestimmter Subsysteme in der Management Konsole ist eine technische Vorschau in JBoss EAP 7:

  • IO
  • Remoting
  • BeanValidation
  • Jaxrs
  • Jdr
  • Jsf
  • Jsr77
  • Naming
  • Pojo
  • RequestController
  • Sar
  • SecurityManager
  • Singleton
  • Weld
Batch-Verarbeitung (JSR 352) durch JBeret

Batch-Verarbeitung (JSR 352) wird von JBeret vorgenommen. Bei JBeret gibt es die folgenden drei Helfer-Anmerkungen, die in einer zukünftigen Release gegebenenfalls Teil der Batch-Spezifikation werden.

  • @org.jberet.cdi.JobScoped
  • @org.jberet.cdi.StepScoped
  • @org.jberet.cdi.PartitionScoped

    Diese Anmerkungen sind im org.jberet.core Modul, welches ein privates Modul ist. Diese spezifischen Anmerkungen werden lediglich als technische Vorschau erachtet. In einer zukünftigen Release können diese Anmerkungen in ein unterstütztes öffentliches Modul verschoben werden. Derzeit führt die Verwendung dieser Anmerkungen zu einer Warnmeldung, die angibt, dass das org.jberet.core Modul ein privates Modul ist.

Server-Sent Events (SSE) in Java
Eine Implementierung des Server-Sent Event Modells in Java wird Kunden zur Verfügung gestellt, die mit mobilen und reichen Kunden arbeiten. Dies beinhaltet nur die Server-Implementierung. Hierbei handelt es sich lediglich eine technische Vorschau.
Microsoft Azure Discovery-Protokoll
Das JGroups AZURE_PING Discovery-Protokoll für Microsoft Azure wurde einer minimalen Testphase unterzogen und ist nur für eine technische Vorschau verfügbar in JBoss EAP 7. Weitere Informationen finden Sie unter JBEAP-3327 und im jgroups-azure GitHub Repository.

Kapitel 3. Nicht unterstützte und veraltete Funktionen

3.1. Nicht unterstützte Features

Der Support wurde aufgrund hoher Erhaltungskosten, geringem Interesse der Community und besseren Alternativ-Lösungen für manche Technologien entfernt. Die folgenden Funktionen werden in JBoss EAP 7 nicht unterstützt.

JAX-RPC
  • JAX-RPC wird nicht mehr unterstützt. JAX-WS bietet eine akkuratere und vollständigere Lösung an.
JSR 88
  • JSR-88 hatte begrenzte Übernahme.
JBoss Web Services
  • Bean-Validierung 1.1 Interzeptoren und Features
  • JASPI Authentifizierung
Messaging (ActiveMQ Artemis)
  • AMQP, Stomp, REST, MQTT und OpenWire Protokoll
  • Netty über HTTP und Netty Servlet Transport
  • OIO (Old Java IO) Typ Connector/Acceptor
  • Vert.x, AeroGear, Spring und Jolokia Integration
  • Erstellung einer dynamischen Warteschlange
  • Chain Cluster
  • Verwendung von ActiveMQ Artemis Management mittels JMX
  • Datenbank als geteilten JDBC-Speicher verwenden
  • Im Cluster herunterskalieren
  • HA-Topologie mit geteiltem Standort wurde mittels http-connector/http-acceptor oder mittels replication-colocated/shared-store-colocated konfiguriert
3. JMS-Broker Zertifizierung
  • Generiscer JMS-Ressourcenadapter
Management Konsole
  • Alle Bereinigungsvorgänge (Flush) für Verbindungspools
  • Die Integration von Red Hat Access wurde in JBoss EAP7 weggelassen
RESTEasy 3
  • jose-jwt
  • resteasy-crypto
  • resteasy-yaml-provider
Command Line Interface (CLI)
  • CLI-Präferenzen in der .jbossclirc Datei
  • Arbeit mit komplexen Attributen vereinfachen
  • Vervollständigung mit der TAB-Taste im CLI für Pfad-Syntax der Attributnamen
  • Verbindungs-Controller Alias in jboss-cli.xml
  • RBAc-basierte Vervollständigung mit der TAB-Taste für CLI-Befehle
Clustering
  • Websiteübergreifende Replikation
  • Deklarative Channels, Channel-Forks, Fork-Protocol-Stacks und benutzerdefinierte JGroups-Protokolle im JGroups-Subsystem
  • Öffentliches API für die Erstellung von JGroups-Channels
  • Laufzeit-Verwaltungsmetrik für JGroups-Channels
  • Mögliche Konfiguration von Thread-Pools über Protocol-Stack im JGroups-Subsystem
  • Mögliche Konfiguration von Thread-Pools über Cache-Container im Infinispan-Subsystem
Transaktionen
  • Ausgleichbare Transaktionen
  • REST Transaktionen
Benutzer hinzufügen
  • Benutzer aktivieren oder deaktivieren über das Hilfsprogramm add-user
Hibernate
  • Generika in Hibernate nativem API
PicketLink
  • PicketLink IDM
  • PicketLink IDM Subsystem
  • STS Client Pooling ist eine Funktion von PicketLink Federation
  • PicketLink JEE (CDI Security)
Natives
  • Support eingestellt für mod_cluster und mod_jk connectors, verwendet mit Apache HTTP Server von Red Hat Enterprise Linux RPM Channels.
  • Support eingestellt für mod_cluster und mod_jk connectors, verwendet mit Apache HTTP Server von HP-UX Web Server Suites.
  • OpenSSL wurde weggelassen in JBoss EAP 7
  • tcnatives wurde weggelassen in JBoss EAP 7
Undertow
  • Die Funktion WebDAV ist in JBoss EAP 7 nicht vorhanden. Um die Funktion WebDAV in JBoss EAP 7 hinzuzufügen, müssen Sie das Servlet implementieren, welches die Funktion WebDAV implementiert.
ORB
  • JacORB Funktionen

3.2. Veraltetes Feature

Manche Features sind mit der Release von JBoss EAP 7 veraltet. Das bedeutet, dass keine Verbesserungen an diesen Features mehr vorgenommen werden und sie in Zukunft, gewöhnlich zur nächsten Haupt-Release, entfernt werden können.

Red Hat wird weiterhin unter den allgemeinen Geschäftsbedingungen vollen Support leisten und Fehlerkorrekturen vornehmen. Weitere Informationen zu den Red Hat Support Richtlinien finden Sie in dem Artikel Red Hat JBoss Middleware Product Update and Support Policy im Red Hat Kundenportal.

Details zu veralteten Features finden Sie in dem Artikel JBoss Enterprise Application Platform Component Details im Red Hat Kundenportal.

  • Alle PicketLink-Module einschließlich Federation sind in JBoss EAP 7 veraltet, was bedeutet, dass sie in zukünftigen Versionen der JBoss EAP entfernt werden können. PicketLink Federation wird in JBoss EAP 7 noch unterstützt.
  • resteasy-jettison-provider ist in JBoss EAP 7 veraltet. Weitere Informationen finden Sie unter Änderungen am Provider RESTEasy Jettison JSON im JBoss EAP Migrationshandbuch.

Kapitel 4. Bekannte Probleme bei der 7.0 Release

Sicherheits-Manager

JBEAP-408 - Die Einstellung Maximale Bereichtigungen des Sicherheits-Managers funktioniert nicht

Die Konfiguration einer leeren Maximal-Einstellung des Sicherheits-Managers führt zu der Verwendung von AllPermission. Wenn Sie absichtlich ein leeres Set konfigurieren, dann versuchen Sie eine leere Berechtigungssammlung herzustellen, um Deployments mit deklarierten Berechtigungen zu blockieren. Die zugewiesene Standardeinstellung AllPermission lässt dieses Szenario nicht zu und führt dazu, dass deklarierte Berechtigungen vom Subsystem angenommen werden.

Dies verhindert, dass Deployments mit deklarierten Sicherheitsberechtigungen blockiert werden. Es könnte eine Richtlinie zum Blockieren dieser Deployments geben, aber dies ist im aktuellen Verhalten nicht erlaubt.

Problemumgehung

In META-INF/permissions.xml können Sie überprüfen, ob Deployments Berechtigungen haben, und sie einfach nicht bereitstellen, anstatt sich darauf zu verlassen, dass das Subsystem diese Überprüfung durchführt. Deployments, die Sicherheitsberechtigungen benötigen, werden nicht angezeigt.

Sicherheit

JBEAP-3997 - Einfaches Logout ist nicht voll funktionsfähig auf verteiltem PicketLink Identity Provider
Das Global Logout (GLO) ist unter gewissen Umständen nicht voll funktionsfähig auf einem verteilten PicketLink Identity Provider (IDP), zum Beispiel, wenn die Funktion Sticky Session nicht bei der Lastenverteilung für eine IDP-Anwendung verwendet wird, oder wenn ein Knoten mit einem IDP, den Sie derzeit verwenden, vor GLO fehlschlägt. Wenn Sie verschiedene Knoten mit einem IDP für das Ein- oder Ausloggen von Serviceprovidern verwenden, können Sie auch nach GLO bei einigen Diensten angemeldet bleiben, weil die Liste von GLO-Teilnehmern auf den IDP beschränkt ist, an den die GLO-Anfrage gesendet wurde.

Domain-Management

JBEAP-4125 - RBAC: Die beiden Arten von Nichtadressierbarkeit

Einige Ressourcen sind nicht adressierbar für server-group und Host begrenzte Rollen, um verbesserte Benutzerfreundlichkeit und eine vereinfachte Ansicht des Management-Modells zu bieten. Dies unterscheidet sich von anderen nicht adressierbaren Ressourcen, bei denen vertrauliche Daten geschützt werden sollen.

Für auf Servergruppen begrenzte Rollen bedeutet dies, dass Ressourcen in den Bereichen profile, socket binding group, deployment, deployment override, server group, server config und server des Management-Modells nicht sichtbar sind, wenn sie nicht mit Servergruppen verbunden sind, die für diese Rolle festgelegt sind.

Für auf Host begrenzte Rollen bedeutet dies, dass Ressourcen im Bereich /host=* des Management-Modells nicht sichtbar sind, wenn sie nicht mit den für diese Rolle festgelegten Servergruppen verbunden sind.

In manchen Fällen kann aber diese vereinfachte Ansicht Informationen verbergen, die zwar außerhalb des vom Benutzer verwalteten Bereichs liegen, aber hilfreich für die Vorgehensweise des Benutzers sein können. Ein Beispiel hierfür ist JBEAP-4160 - RBAC: Fehler beim Bereitstellen des gleichen Deployments, das bereits von einem Benutzer eines anderen server-group Bereiches bereitgestellt wurde.

In einer zukünftigen Release werden einige dieser nicht adressierbaren Ressourcen möglicherweise adressierbar, aber nicht lesbar sein. Die Sicherheit des Servers wird dadurch nicht betroffen, da sie nicht aus Sicherheitsgründen nicht adressierbar waren. Red Hat empfiehlt, dass Sie sich beim verbergen von Informationen nicht auf die Nichtadressierbarkeit von Ressourcen verlassen, außer wenn die Nichtadressierbarkeit in einer Einschränkung der Vertraulichkeit definiert ist.

JBEAP-4434 - Fehler beim Start des Servers mit Konfigurationsdatei von EAP 6.4.7 und höher

Ändern Sie den Wert des xmlns Attributs auf dem root xml Element auf xmlns="urn:jboss:domain:1.7", bevor Sie es mit JBoss EAP7 benutzen.

Dies sollte gut funktionieren, außer Ihre Konfiguration enthält Elemente, die in der 1.8 Version des Schemas hinzugefügt wurden. Diese Elemente werden erwartungsgemäß nicht häufig verwendet.

JBEAP-4227 - JBoss LoginModules per CLI-Befehl neu anordnen.

Undertow

JBEAP-4255 - Ablaufprotokollierung zur Verarbeitung von Sicherheitseinschränkungen hinzufügen

Dieses Problem kann die Fehlerbehebung bei Sicherheitsproblemen erschweren, da wichtige Informationen u.U. nicht in den Protokolldateien der Instanz protokolliert werden.

Problemumgehung

Die einzig bekannte Fehlerumgehung ist derzeit der Versuch, mit Byteman die fehlenden Protokoll-Statements einzuspeisen. Weitere Informationen finden Sie unter https://access.redhat.com/solutions/31283.

JBEAP-2263 - Die Invalidierung einer SSO-Session auf einem anderen Knoten als bei der Erstellung der Session wird den Benutzer nicht ausloggen

JBEAP-4425 - EAP 7 HTTP Keep-Alive Performance ist im Vergleich zu EAP 6.4.7 für Standardkonfiguration standalone.xml und im Vergleich zur hohen Anzahl an Clients gesunken

JBEAP-4413 - Undertow mod_cluster: Multiinterface-Box: Manager-Adresse enthält immer den Hostnamen

JBEAP-4256 - Ablaufprotokollierung zum SSO-Code hinzufügen

In Situationen, in denen die Fehlerbehebung eines SSO-Problems erforderlich ist, kann die Lösung komplizierter ausfallen, da manche Statements, die zu einer leichteren Lösung beitragen würden, ggf. nicht protokolliert sind.

Problemumgehung

Die einzige Fehlerumgehung besteht derzeit darin, zu versuchen mit Byteman die fehlenden Protokoll-Statements einzuspeisen. Weitere Informationen finden Sie unter https://access.redhat.com/solutions/31283.

Protokollierung

JBEAP-4101 - LogContexts sind für EAR-Subdeployments nicht entfernt

JPA/Hibernate

JBEAP-1605 - Hibernate Validator kann annotierte und parametrisierte Typen nicht von Methodenparametern mittels IBM JDK prüfen

Bei der IBM JVM Implementierung wurde ein Problem festgestellt, das eine Prüfung von annotierten, parametrisierten Typen von Methodenparametern mittels Reflektion unmöglich macht, wenn sie auf einer IBM JVM laufen. Dies betrifft Hibernate Validator, die Implementierung von Bean Validation in JBoss EAP, insofern, dass benutzerdefinierte Validierungseinschränkungen, die auf type-use Annotationen bei Methodenparametern basieren, nicht funktionieren. Zum Beispiel:

public void addSomeInterestingStrings(List<@Interesting String> strings)

Wenn @Interesting als Prüfbeschränkung angesehen wird, wird diese Prüfbeschränkung bei der Überprüfung des »Strings«-Arguments nicht korrekt angewendet. Dies ist ein Problem der JVM-Implementierung, das IBM gemeldet wurde, und in einer zukünftigen Release von IBM Java behoben wird. Es betrifft keine anderen JVM-Implementierungen.

JBEAP-3707 - Der Oracle JDBC Treiber kann in manchen Fällen keine Entitäten mit Namen, die aus einem Zeichen bestehen, verarbeiten

In Oracle JDBC Treiber 12.1.0.2 wurde ein Fehler festgestellt, der bei dem Versuch ein PreparedStatement für eine Tabelle zu erstellen, deren Name nur ein Zeichen enthält, eine Ausnahme verursacht. Dies ist ein Fehler im JDBC Treiber, der Oracle gemeldet wurde und in einer Folgeversion des Treibers beseitigt wird.

Problemumgehung

Eine Fehlerumgehung besteht darin, keine Tabellen mit nur einem Zeichen im Namen zu verwenden, oder den Namen zu zitieren.

JBEAP-3993 - Benennungs-Kontext ist beim Start der Persistenzeinheit nicht eingerichtet

JBEAP-4475 - HHH-5393: Wiederholte Spalte bei Mapping mittels MapKeyColumn

JBEAP-4179 - HHH-10679: Unterauswahl wird nicht verwendet, wenn Batch nach ID geladen wird

Quickstarts

JBEAP-4500 - Wiederholtes Fehlschlagen von Quickstart ejb-multi-server Deployment mit ERROR MSC000001

Messaging (ActiveMQ Artemis, JMS)

JBEAP-4407 - Verbraucher-Absturz mit IndexOutOfBoundsException, wenn große Nachrichten von importierten Journalen gelesen werden

Wenn ActiveMQ Artemis Journal mittels import-journal CLI-Vorgang importiert wurde und das Journal große Nachrichten enthält, dann werden die Verbraucher, die diese großen Nachrichten empfangen, folgende Ausgabe erhalten:

java.lang.IndexOutOfBoundsException: readerIndex(22) + length(409600) exceeds writerIndex(3580): UnpooledHeapByteBuf(ridx: 22, widx: 3580, cap: 3580)
at io.netty.buffer.AbstractByteBuf.checkReadableBytes(AbstractByteBuf.java:1165)
at io.netty.buffer.AbstractByteBuf.readBytes(AbstractByteBuf.java:675)
at io.netty.buffer.AbstractByteBuf.readBytes(AbstractByteBuf.java:683)
at io.netty.buffer.WrappedByteBuf.readBytes(WrappedByteBuf.java:511)
...

Fehlerumgehung Die Fehlerumgehung besteht darin, JMS-Brücken zu verwenden. Weitere Informationen finden Sie im JBoss EAP Migrationshandbuch.

JBEAP-3998 - Live wird nach einem Failback nicht aktiv, wenn Sie Replication Journal verwenden
Wenn Sie Replication Journal benutzen, besteht das Risiko, dass der Live-Server nach einem Failback nicht aktiv wird.

JBEAP-4225 - Nachricht ging möglicherweise verloren bei Failover/Failback mittels normaler JMS-Transaktionen

JBEAP-3848 - Artemis Testsuite PagingTest#testDeletePhysicalPages schlägt fehl

JBEAP-3675 - Neuverteilung verliert große Nachrichten, wenn ein Server mit HA neu gestartet wird

JBEAP-2946 - Ausnahme bei Abonnent während Failback auf Replikation

Wenn Sie Replication-Journal mit großen Nachrichten verwenden, kann der Verbraucher folgende Ausnahme erhalten, was den Fehlschlag erzeugt:

00:31:52,730 Thread-535 ERROR [org.jboss.qa.hornetq.apps.clients.SubscriberClientAck:207] Exception was thrown during receiving messages:
java.lang.IndexOutOfBoundsException: readerIndex(22) + length(409600) exceeds writerIndex(3580): UnpooledHeapByteBuf(ridx: 22, widx: 3580, cap: 3580)
at io.netty.buffer.AbstractByteBuf.checkReadableBytes(AbstractByteBuf.java:1165)
at io.netty.buffer.AbstractByteBuf.readBytes(AbstractByteBuf.java:675)
at io.netty.buffer.AbstractByteBuf.readBytes(AbstractByteBuf.java:683)
at io.netty.buffer.WrappedByteBuf.readBytes(WrappedByteBuf.java:511)
at org.apache.activemq.artemis.core.buffers.impl.ChannelBufferWrapper.readSimpleStringInternal(ChannelBufferWrapper.java:86)
at org.apache.activemq.artemis.core.buffers.impl.ChannelBufferWrapper.readNullableSimpleString(ChannelBufferWrapper.java:68)
at org.apache.activemq.artemis.reader.TextMessageUtil.readBodyText(TextMessageUtil.java:37)
at org.apache.activemq.artemis.jms.client.ActiveMQTextMessage.doBeforeReceive(ActiveMQTextMessage.java:112)
at org.apache.activemq.artemis.jms.client.ActiveMQMessageConsumer.getMessage(ActiveMQMessageConsumer.java:204)
at org.apache.activemq.artemis.jms.client.ActiveMQMessageConsumer.receive(ActiveMQMessageConsumer.java:119)
at org.jboss.qa.hornetq.apps.clients.SubscriberClientAck.receiveMessage(SubscriberClientAck.java:326)
at org.jboss.qa.hornetq.apps.clients.SubscriberClientAck.run(SubscriberClientAck.java:169)
Exception in thread "Thread-535" java.lang.RuntimeException: Fatal exception was thrown in subscriber. Subscriber for node: 127.0.0.1

Clustering

JBEAP-4386 - session.invalidate() Verhalten nicht konform mit Servlet-Spezifikation im HA-Profil

JBEAP-3954 - EJB-Aufruf fehlgeschlagen auf der Komponente LocalStatefulSB: TimeoutException: Replikations-Timeout für X

JBEAP-3946 - TimeoutException: Kann keine Sperre beziehen nach 15 Sekunden in repl-async Stress Tests

JBEAP-3926 - Ausnahme »ArrayIndexOutOfBoundsException« bei Herunterfahren von EJB-Clients in 2-Cluster Umgebungen mit EJB Aufrufen

JBEAP-3779 - Fehler bei Ausführung des Befehls PrepareCommand/GetKeyValueCommand aufgrund eines Replikations-Timeouts

JBEAP-3696 - TimeoutException: Replikations-Timeout bei Bearbeiten der Anfrage

JBEAP-3583 - Ausnahmen in 2-Cluster EJB Aufruf während graceful Shutdown der Tests

JBEAP-2155 - EJB-Lookup schlägt fehl mit "Kein Cluster-Kontext verfügbar"

JBEAP-794 - WARN ISPN000197: Fehler beim Aktualisieren der Liste von Cluster-Mitgliedern beim Boot-Up

JBEAP-444 - WFLYEJB0467: Anfrage wurde abgelehnt, da der Container während des Herunterfahrens des Servers angehalten wurde

JBEAP-2072 - Standardmäßige Berechtigungsprüfung bei JGroups Nachrichtenbestätigung hinzufügen

JBEAP-4391 - Änderbare Sitzungsvariablen replizieren nicht ordnungsgemäß über non-tx Sitzungs-Cache

JBEAP-4128 - NPE während Session.requestDone(…​) in <ransaction mode="NONE"></transaction>

Lokalisierung

JBEAP-4350 - fr_FR Installer - Alle Strings 'Port Number' sollten auf Französisch auf jeder Seite vor 'ajp, http, …​' stehen.

JBEAP-4336 - ja_JP Installer - Nicht lokalisierte Seite 'Quickstarts' und Titelname.

JBEAP-4038 - zh_CN Installer - String 'For the list of supported drivers, please visit this link.' wird als unlesbarer Code oder quadratisches Feld angezeigt auf der Seite Configure Runtime -> JDBC Driver Setup.

JBEAP-4037 - ALL_LANG Installer - Seitentitel 'Installation Overview' ist nicht lokalisiert auf der Seite für Installationsübersicht.

JBEAP-4010 - ALL_LANG Installer - Nicht lokalisierte Strings im Warndialog zur Validierung auf der Seite für »Admin User Creation«.

JBEAP-4009 - zh_CN, ja_JP Installer - Chinesische und Japanische Elemente werden als quadratisches Feld im Dialogfeld »Sprache auswählen« angezeigt, wenn man mit chinesischem oder japanischem Locale im BS angemeldet ist.

Installer

JBEAP-4219 - Verknüpfungen werden nicht erstellt durch automatische Installation per Installationsskript

JBEAP-3724 - Unfreundliches Verhalten von jboss-cli und installer.jar bei HP-UX Boxes

JBEAP-1404 - IOException bei Installationsabbruch bei Windows

EJB

JBEAP-4167 - Server kann @Timeout Methode nicht aufrufen, nachdem 10 Methoden bei asynchronen Bean in IBM JDK aufgerufen wurde

JBEAP-3871 - EJBs zu schnell zugänglich (Spec Verstoß)

JBEAP-3665 - RollbackException wird nicht vom entfernten EJB-Client übertragen

JBEAP-3448 - SessionSynchronization Callbacks ermöglichen gleichzeitigen Zugriff auf SFSB

JBEAP-165 - Mögliches Problem mit Berichtausnahme bei Fehler während 2PC

Transaktionen

JBEAP-4036 - "number-of-application-rollbacks" Statistik wurde während einfachem Rollback mehrfach gezählt

JBEAP-2833 - Standardmäßiges Transaktions-Timeout wird für EJB-Bean bei einer zweiten Einstellung nicht angewendet

JBEAP-1913 - Absoluter Pfad für Speicherort des Objekts kann nicht definiert werden

JBEAP-3314 - Fehler bei Transaktionswiederherstellung, wenn entfernte EJB-Ressource beteiligt ist
Der Wiederherstellungsprozess einer Transaktion kann fehlschlagen, wenn er entfernte EJB-Ressourcen umfasst, die vielleicht abgestürzt sind. Dieses Problem tritt auf, wenn eine Verbindung zwischen dem Server und dem Client abbricht. Genauer gesagt werden der Server und der Client nicht automatisch miteinander kommunizieren, wenn der Client abstürzt und neu gestartet wird. In einem derartigen Szenario wird der Server nicht bemerken, dass der Client neu gestartet wurde, was bedeutet, dass der EJB tx Wiederherstellungsprozess nicht wissen wird, mit welchen EJB-Knoten kommuniziert werden muss.

Management CLI

JBEAP-3563 - jconsole "JBoss EAP CLI" Tab lädt nicht bei entfernter Verwendung

JBEAP-4415 - CLI: mod_cluster cipher-suite kann bei Windows nicht eingestellt werden

JBEAP-4412 - jboss-cli.bat: Einstellung von keystore-path in einem neuen Sicherheits-Bereich interpretiert \ (backslash) bei Windows-Pfaden

JBEAP-3724 - Unfreundliches Verhalten von jboss-cli und installer.jar bei HP-UX Boxes

RESTEasy

JBEAP-2963 - RESTEasy-Spring kann nicht mediaTypeMappings in ResteasyDeployment durch Bean-Einstellungen festlegen

JBEAP-3725 - Log-Ebene des Fehlers während Anfrage auf nicht existierendem REST Endpunkt

Patching

Remoting

JBEAP-2017 - Endpunkt kann vor Abschluss der doConnect-Aufgaben geschlossen werden, was zur Folge hat, dass AbstractHandleableCloseable.close endlos lange wartet

JBEAP-3602 - Unendliche Wartezeit in AbstractCloseableHandleable

Management Konsole

JBEAP-3940 - Deployment Scanner kann nicht in Web-Konsole hinzugefügt werden

Fügen Sie dies über das Management-CLI hinzu:

/subsystem=deployment-scanner/scanner=new-scanner:add(path=new_deployment_dir,relative-to=jboss.server.base.dir,scan-interval=5000)

JBEAP-2821 - Schaltfläche für »Verbindung testen« sollte aus dem Assistenten für Datenquelle erstellen aufgrund von unverständlichem Verhalten entfernt werden, das durch Neuladen nach Bearbeiten/Entfernen der Datenquelle erzeugt wurde

Server

JBEAP-4409 - Server, der Anfrage bearbeitet, wird nicht sofort angehalten, sondern wartet, bis die Bearbeitung der Anfragen abgeschlossen ist

Distribution

JBEAP-4254 - MIT-Lizenz - license.txt ist leer

Der Lizenz-Text lautet folgendermaßen:

jsoup Lizenz

Die jsoup Codebasis (einschließlich Quelle und kompilierte Pakete) wird unter der Open Source MIT Lizenz verteilt, wie unten beschrieben.

MIT Lizenz

Copyright © 2009 - 2013 Jonathan Hedley (jonathan@hedley.net)

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
JBEAP-2807 - Probleme mit jboss-eap-7.0/docs/licenses

Die Lizenzdatei cddl+gpl license - cddl+gpl_1_1.html ist leer.

Der Lizenz-Text lautet folgendermaßen:

COMMON DEVELOPMENT AND DISTRIBUTION LICENSE (CDDL)Version 1.1

1. Definitions.

    1.1. “Contributor” means each individual or entity that creates or contributes to the creation of Modifications.

    1.2. “Contributor Version” means the combination of the Original Software, prior Modifications used by a Contributor (if any), and the Modifications made by that particular Contributor.

    1.3. “Covered Software” means (a) the Original Software, or (b) Modifications, or (c) the combination of files containing Original Software with files containing Modifications, in each case including portions thereof.

    1.4. “Executable” means the Covered Software in any form other than Source Code.

    1.5. “Initial Developer” means the individual or entity that first makes Original Software available under this License.

    1.6. “Larger Work” means a work which combines Covered Software or portions thereof with code not governed by the terms of this License.

    1.7. “License” means this document.

    1.8. “Licensable” means having the right to grant, to the maximum extent possible, whether at the time of the initial grant or subsequently acquired, any and all of the rights conveyed herein.

    1.9. “Modifications” means the Source Code and Executable form of any of the following:

    A. Any file that results from an addition to, deletion from or modification of the contents of a file containing Original Software or previous Modifications;

    B. Any new file that contains any part of the Original Software or previous Modification; or

    C. Any new file that is contributed or otherwise made available under the terms of this License.

    1.10. “Original Software” means the Source Code and Executable form of computer software code that is originally released under this License.

    1.11. “Patent Claims” means any patent claim(s), now owned or hereafter acquired, including without limitation, method, process, and apparatus claims, in any patent Licensable by grantor.

    1.12. “Source Code” means (a) the common form of computer software code in which modifications are made and (b) associated documentation included in or with such code.

    1.13. “You” (or “Your”) means an individual or a legal entity exercising rights under, and complying with all of the terms of, this License. For legal entities, “You” includes any entity which controls, is controlled by, or is under common control with You. For purposes of this definition, “control” means (a) the power, direct or indirect, to cause the direction or management of such entity, whether by contract or otherwise, or (b) ownership of more than fifty percent (50%) of the outstanding shares or beneficial ownership of such entity.

2. License Grants.

    2.1. The Initial Developer Grant.

    Conditioned upon Your compliance with Section 3.1 below and subject to third party intellectual property claims, the Initial Developer hereby grants You a world-wide, royalty-free, non-exclusive license:

    (a) under intellectual property rights (other than patent or trademark) Licensable by Initial Developer, to use, reproduce, modify, display, perform, sublicense and distribute the Original Software (or portions thereof), with or without Modifications, and/or as part of a Larger Work; and

    (b) under Patent Claims infringed by the making, using or selling of Original Software, to make, have made, use, practice, sell, and offer for sale, and/or otherwise dispose of the Original Software (or portions thereof).

    (c) The licenses granted in Sections 2.1(a) and (b) are effective on the date Initial Developer first distributes or otherwise makes the Original Software available to a third party under the terms of this License.

    (d) Notwithstanding Section 2.1(b) above, no patent license is granted: (1) for code that You delete from the Original Software, or (2) for infringements caused by: (i) the modification of the Original Software, or (ii) the combination of the Original Software with other software or devices.

    2.2. Contributor Grant.

    Conditioned upon Your compliance with Section 3.1 below and subject to third party intellectual property claims, each Contributor hereby grants You a world-wide, royalty-free, non-exclusive license:

    (a) under intellectual property rights (other than patent or trademark) Licensable by Contributor to use, reproduce, modify, display, perform, sublicense and distribute the Modifications created by such Contributor (or portions thereof), either on an unmodified basis, with other Modifications, as Covered Software and/or as part of a Larger Work; and

    (b) under Patent Claims infringed by the making, using, or selling of Modifications made by that Contributor either alone and/or in combination with its Contributor Version (or portions of such combination), to make, use, sell, offer for sale, have made, and/or otherwise dispose of: (1) Modifications made by that Contributor (or portions thereof); and (2) the combination of Modifications made by that Contributor with its Contributor Version (or portions of such combination).

    (c) The licenses granted in Sections 2.2(a) and 2.2(b) are effective on the date Contributor first distributes or otherwise makes the Modifications available to a third party.

    (d) Notwithstanding Section 2.2(b) above, no patent license is granted: (1) for any code that Contributor has deleted from the Contributor Version; (2) for infringements caused by: (i) third party modifications of Contributor Version, or (ii) the combination of Modifications made by that Contributor with other software (except as part of the Contributor Version) or other devices; or (3) under Patent Claims infringed by Covered Software in the absence of Modifications made by that Contributor.

3. Distribution Obligations.

    3.1. Availability of Source Code.

    Any Covered Software that You distribute or otherwise make available in Executable form must also be made available in Source Code form and that Source Code form must be distributed only under the terms of this License. You must include a copy of this License with every copy of the Source Code form of the Covered Software You distribute or otherwise make available. You must inform recipients of any such Covered Software in Executable form as to how they can obtain such Covered Software in Source Code form in a reasonable manner on or through a medium customarily used for software exchange.

    3.2. Modifications.

    The Modifications that You create or to which You contribute are governed by the terms of this License. You represent that You believe Your Modifications are Your original creation(s) and/or You have sufficient rights to grant the rights conveyed by this License.

    3.3. Required Notices.

    You must include a notice in each of Your Modifications that identifies You as the Contributor of the Modification. You may not remove or alter any copyright, patent or trademark notices contained within the Covered Software, or any notices of licensing or any descriptive text giving attribution to any Contributor or the Initial Developer.

    3.4. Application of Additional Terms.

    You may not offer or impose any terms on any Covered Software in Source Code form that alters or restricts the applicable version of this License or the recipients' rights hereunder. You may choose to offer, and to charge a fee for, warranty, support, indemnity or liability obligations to one or more recipients of Covered Software. However, you may do so only on Your own behalf, and not on behalf of the Initial Developer or any Contributor. You must make it absolutely clear that any such warranty, support, indemnity or liability obligation is offered by You alone, and You hereby agree to indemnify the Initial Developer and every Contributor for any liability incurred by the Initial Developer or such Contributor as a result of warranty, support, indemnity or liability terms You offer.

    3.5. Distribution of Executable Versions.

    You may distribute the Executable form of the Covered Software under the terms of this License or under the terms of a license of Your choice, which may contain terms different from this License, provided that You are in compliance with the terms of this License and that the license for the Executable form does not attempt to limit or alter the recipient's rights in the Source Code form from the rights set forth in this License. If You distribute the Covered Software in Executable form under a different license, You must make it absolutely clear that any terms which differ from this License are offered by You alone, not by the Initial Developer or Contributor. You hereby agree to indemnify the Initial Developer and every Contributor for any liability incurred by the Initial Developer or such Contributor as a result of any such terms You offer.

    3.6. Larger Works.

    You may create a Larger Work by combining Covered Software with other code not governed by the terms of this License and distribute the Larger Work as a single product. In such a case, You must make sure the requirements of this License are fulfilled for the Covered Software.

4. Versions of the License.

    4.1. New Versions.

    Oracle is the initial license steward and may publish revised and/or new versions of this License from time to time. Each version will be given a distinguishing version number. Except as provided in Section 4.3, no one other than the license steward has the right to modify this License.

    4.2. Effect of New Versions.

    You may always continue to use, distribute or otherwise make the Covered Software available under the terms of the version of the License under which You originally received the Covered Software. If the Initial Developer includes a notice in the Original Software prohibiting it from being distributed or otherwise made available under any subsequent version of the License, You must distribute and make the Covered Software available under the terms of the version of the License under which You originally received the Covered Software. Otherwise, You may also choose to use, distribute or otherwise make the Covered Software available under the terms of any subsequent version of the License published by the license steward.

    4.3. Modified Versions.

    When You are an Initial Developer and You want to create a new license for Your Original Software, You may create and use a modified version of this License if You: (a) rename the license and remove any references to the name of the license steward (except to note that the license differs from this License); and (b) otherwise make it clear that the license contains terms which differ from this License.

5. DISCLAIMER OF WARRANTY.

    COVERED SOFTWARE IS PROVIDED UNDER THIS LICENSE ON AN “AS IS” BASIS, WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, WITHOUT LIMITATION, WARRANTIES THAT THE COVERED SOFTWARE IS FREE OF DEFECTS, MERCHANTABLE, FIT FOR A PARTICULAR PURPOSE OR NON-INFRINGING. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE COVERED SOFTWARE IS WITH YOU. SHOULD ANY COVERED SOFTWARE PROVE DEFECTIVE IN ANY RESPECT, YOU (NOT THE INITIAL DEVELOPER OR ANY OTHER CONTRIBUTOR) ASSUME THE COST OF ANY NECESSARY SERVICING, REPAIR OR CORRECTION. THIS DISCLAIMER OF WARRANTY CONSTITUTES AN ESSENTIAL PART OF THIS LICENSE. NO USE OF ANY COVERED SOFTWARE IS AUTHORIZED HEREUNDER EXCEPT UNDER THIS DISCLAIMER.

6. TERMINATION.

    6.1. This License and the rights granted hereunder will terminate automatically if You fail to comply with terms herein and fail to cure such breach within 30 days of becoming aware of the breach. Provisions which, by their nature, must remain in effect beyond the termination of this License shall survive.

    6.2. If You assert a patent infringement claim (excluding declaratory judgment actions) against Initial Developer or a Contributor (the Initial Developer or Contributor against whom You assert such claim is referred to as “Participant”) alleging that the Participant Software (meaning the Contributor Version where the Participant is a Contributor or the Original Software where the Participant is the Initial Developer) directly or indirectly infringes any patent, then any and all rights granted directly or indirectly to You by such Participant, the Initial Developer (if the Initial Developer is not the Participant) and all Contributors under Sections 2.1 and/or 2.2 of this License shall, upon 60 days notice from Participant terminate prospectively and automatically at the expiration of such 60 day notice period, unless if within such 60 day period You withdraw Your claim with respect to the Participant Software against such Participant either unilaterally or pursuant to a written agreement with Participant.

    6.3. If You assert a patent infringement claim against Participant alleging that the Participant Software directly or indirectly infringes any patent where such claim is resolved (such as by license or settlement) prior to the initiation of patent infringement litigation, then the reasonable value of the licenses granted by such Participant under Sections 2.1 or 2.2 shall be taken into account in determining the amount or value of any payment or license.

    6.4. In the event of termination under Sections 6.1 or 6.2 above, all end user licenses that have been validly granted by You or any distributor hereunder prior to termination (excluding licenses granted to You by any distributor) shall survive termination.

7. LIMITATION OF LIABILITY.

    UNDER NO CIRCUMSTANCES AND UNDER NO LEGAL THEORY, WHETHER TORT (INCLUDING NEGLIGENCE), CONTRACT, OR OTHERWISE, SHALL YOU, THE INITIAL DEVELOPER, ANY OTHER CONTRIBUTOR, OR ANY DISTRIBUTOR OF COVERED SOFTWARE, OR ANY SUPPLIER OF ANY OF SUCH PARTIES, BE LIABLE TO ANY PERSON FOR ANY INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES OF ANY CHARACTER INCLUDING, WITHOUT LIMITATION, DAMAGES FOR LOSS OF GOODWILL, WORK STOPPAGE, COMPUTER FAILURE OR MALFUNCTION, OR ANY AND ALL OTHER COMMERCIAL DAMAGES OR LOSSES, EVEN IF SUCH PARTY SHALL HAVE BEEN INFORMED OF THE POSSIBILITY OF SUCH DAMAGES. THIS LIMITATION OF LIABILITY SHALL NOT APPLY TO LIABILITY FOR DEATH OR PERSONAL INJURY RESULTING FROM SUCH PARTY'S NEGLIGENCE TO THE EXTENT APPLICABLE LAW PROHIBITS SUCH LIMITATION. SOME JURISDICTIONS DO NOT ALLOW THE EXCLUSION OR LIMITATION OF INCIDENTAL OR CONSEQUENTIAL DAMAGES, SO THIS EXCLUSION AND LIMITATION MAY NOT APPLY TO YOU.


8. U.S. GOVERNMENT END USERS.

    The Covered Software is a “commercial item,” as that term is defined in 48 C.F.R. 2.101 (Oct. 1995), consisting of “commercial computer software” (as that term is defined at 48 C.F.R. § 252.227-7014(a)(1)) and “commercial computer software documentation” as such terms are used in 48 C.F.R. 12.212 (Sept. 1995). Consistent with 48 C.F.R. 12.212 and 48 C.F.R. 227.7202-1 through 227.7202-4 (June 1995), all U.S. Government End Users acquire Covered Software with only those rights set forth herein. This U.S. Government Rights clause is in lieu of, and supersedes, any other FAR, DFAR, or other clause or provision that addresses Government rights in computer software under this License.

9. MISCELLANEOUS.

    This License represents the complete agreement concerning subject matter hereof. If any provision of this License is held to be unenforceable, such provision shall be reformed only to the extent necessary to make it enforceable. This License shall be governed by the law of the jurisdiction specified in a notice contained within the Original Software (except to the extent applicable law, if any, provides otherwise), excluding such jurisdiction's conflict-of-law provisions. Any litigation relating to this License shall be subject to the jurisdiction of the courts located in the jurisdiction and venue specified in a notice contained within the Original Software, with the losing party responsible for costs, including, without limitation, court costs and reasonable attorneys' fees and expenses. The application of the United Nations Convention on Contracts for the International Sale of Goods is expressly excluded. Any law or regulation which provides that the language of a contract shall be construed against the drafter shall not apply to this License. You agree that You alone are responsible for compliance with the United States export administration regulations (and the export control laws and regulation of any other countries) when You use, distribute or otherwise make available any Covered Software.

10. RESPONSIBILITY FOR CLAIMS.

    As between Initial Developer and the Contributors, each party is responsible for claims and damages arising, directly or indirectly, out of its utilization of rights under this License and You agree to work with Initial Developer and Contributors to distribute such responsibility on an equitable basis. Nothing herein is intended or shall be deemed to constitute any admission of liability.

GNU General Public License (GPL) Version 2, Juni 1991

Copyright (C) 1989, 1991 Free Software Foundation, Inc.
59 Temple Place, Suite 330, Boston, MA 02111-1307 USA

Everyone is permitted to copy and distribute verbatim copies
of this license document, but changing it is not allowed.

Preamble

The licenses for most software are designed to take away your freedom to share and change it. By contrast, the GNU General Public License is intended to guarantee your freedom to share and change free software--to make sure the software is free for all its users. This General Public License applies to most of the Free Software Foundation's software and to any other program whose authors commit to using it. (Some other Free Software Foundation software is covered by the GNU Library General Public License instead.) You can apply it to your programs, too.

When we speak of free software, we are referring to freedom, not price. Our General Public Licenses are designed to make sure that you have the freedom to distribute copies of free software (and charge for this service if you wish), that you receive source code or can get it if you want it, that you can change the software or use pieces of it in new free programs; and that you know you can do these things.

To protect your rights, we need to make restrictions that forbid anyone to deny you these rights or to ask you to surrender the rights. These restrictions translate to certain responsibilities for you if you distribute copies of the software, or if you modify it.

For example, if you distribute copies of such a program, whether gratis or for a fee, you must give the recipients all the rights that you have. You must make sure that they, too, receive or can get the source code. And you must show them these terms so they know their rights.

We protect your rights with two steps: (1) copyright the software, and (2) offer you this license which gives you legal permission to copy, distribute and/or modify the software.

Also, for each author's protection and ours, we want to make certain that everyone understands that there is no warranty for this free software. If the software is modified by someone else and passed on, we want its recipients to know that what they have is not the original, so that any problems introduced by others will not reflect on the original authors' reputations.

Finally, any free program is threatened constantly by software patents. We wish to avoid the danger that redistributors of a free program will individually obtain patent licenses, in effect making the program proprietary. To prevent this, we have made it clear that any patent must be licensed for everyone's free use or not licensed at all.

The precise terms and conditions for copying, distribution and modification follow.

TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION

0. This License applies to any program or other work which contains a notice placed by the copyright holder saying it may be distributed under the terms of this General Public License. The "Program", below, refers to any such program or work, and a "work based on the Program" means either the Program or any derivative work under copyright law: that is to say, a work containing the Program or a portion of it, either verbatim or with modifications and/or translated into another language. (Hereinafter, translation is included without limitation in the term "modification".) Each licensee is addressed as "you".

Activities other than copying, distribution and modification are not covered by this License; they are outside its scope. The act of running the Program is not restricted, and the output from the Program is covered only if its contents constitute a work based on the Program (independent of having been made by running the Program). Whether that is true depends on what the Program does.

1. You may copy and distribute verbatim copies of the Program's source code as you receive it, in any medium, provided that you conspicuously and appropriately publish on each copy an appropriate copyright notice and disclaimer of warranty; keep intact all the notices that refer to this License and to the absence of any warranty; and give any other recipients of the Program a copy of this License along with the Program.

You may charge a fee for the physical act of transferring a copy, and you may at your option offer warranty protection in exchange for a fee.

2. You may modify your copy or copies of the Program or any portion of it, thus forming a work based on the Program, and copy and distribute such modifications or work under the terms of Section 1 above, provided that you also meet all of these conditions:

    a) You must cause the modified files to carry prominent notices stating that you changed the files and the date of any change.

    b) You must cause any work that you distribute or publish, that in whole or in part contains or is derived from the Program or any part thereof, to be licensed as a whole at no charge to all third parties under the terms of this License.

    c) If the modified program normally reads commands interactively when run, you must cause it, when started running for such interactive use in the most ordinary way, to print or display an announcement including an appropriate copyright notice and a notice that there is no warranty (or else, saying that you provide a warranty) and that users may redistribute the program under these conditions, and telling the user how to view a copy of this License. (Exception: if the Program itself is interactive but does not normally print such an announcement, your work based on the Program is not required to print an announcement.)

These requirements apply to the modified work as a whole. If identifiable sections of that work are not derived from the Program, and can be reasonably considered independent and separate works in themselves, then this License, and its terms, do not apply to those sections when you distribute them as separate works. But when you distribute the same sections as part of a whole which is a work based on the Program, the distribution of the whole must be on the terms of this License, whose permissions for other licensees extend to the entire whole, and thus to each and every part regardless of who wrote it.

Thus, it is not the intent of this section to claim rights or contest your rights to work written entirely by you; rather, the intent is to exercise the right to control the distribution of derivative or collective works based on the Program.

In addition, mere aggregation of another work not based on the Program with the Program (or with a work based on the Program) on a volume of a storage or distribution medium does not bring the other work under the scope of this License.

3. You may copy and distribute the Program (or a work based on it, under Section 2) in object code or executable form under the terms of Sections 1 and 2 above provided that you also do one of the following:

    a) Accompany it with the complete corresponding machine-readable source code, which must be distributed under the terms of Sections 1 and 2 above on a medium customarily used for software interchange; or,

    b) Accompany it with a written offer, valid for at least three years, to give any third party, for a charge no more than your cost of physically performing source distribution, a complete machine-readable copy of the corresponding source code, to be distributed under the terms of Sections 1 and 2 above on a medium customarily used for software interchange; or,

    c) Accompany it with the information you received as to the offer to distribute corresponding source code. (This alternative is allowed only for noncommercial distribution and only if you received the program in object code or executable form with such an offer, in accord with Subsection b above.)

The source code for a work means the preferred form of the work for making modifications to it. For an executable work, complete source code means all the source code for all modules it contains, plus any associated interface definition files, plus the scripts used to control compilation and installation of the executable. However, as a special exception, the source code distributed need not include anything that is normally distributed (in either source or binary form) with the major components (compiler, kernel, and so on) of the operating system on which the executable runs, unless that component itself accompanies the executable.

If distribution of executable or object code is made by offering access to copy from a designated place, then offering equivalent access to copy the source code from the same place counts as distribution of the source code, even though third parties are not compelled to copy the source along with the object code.

4. You may not copy, modify, sublicense, or distribute the Program except as expressly provided under this License. Any attempt otherwise to copy, modify, sublicense or distribute the Program is void, and will automatically terminate your rights under this License. However, parties who have received copies, or rights, from you under this License will not have their licenses terminated so long as such parties remain in full compliance.

5. You are not required to accept this License, since you have not signed it. However, nothing else grants you permission to modify or distribute the Program or its derivative works. These actions are prohibited by law if you do not accept this License. Therefore, by modifying or distributing the Program (or any work based on the Program), you indicate your acceptance of this License to do so, and all its terms and conditions for copying, distributing or modifying the Program or works based on it.

6. Each time you redistribute the Program (or any work based on the Program), the recipient automatically receives a license from the original licensor to copy, distribute or modify the Program subject to these terms and conditions. You may not impose any further restrictions on the recipients' exercise of the rights granted herein. You are not responsible for enforcing compliance by third parties to this License.

7. If, as a consequence of a court judgment or allegation of patent infringement or for any other reason (not limited to patent issues), conditions are imposed on you (whether by court order, agreement or otherwise) that contradict the conditions of this License, they do not excuse you from the conditions of this License. If you cannot distribute so as to satisfy simultaneously your obligations under this License and any other pertinent obligations, then as a consequence you may not distribute the Program at all. For example, if a patent license would not permit royalty-free redistribution of the Program by all those who receive copies directly or indirectly through you, then the only way you could satisfy both it and this License would be to refrain entirely from distribution of the Program.

If any portion of this section is held invalid or unenforceable under any particular circumstance, the balance of the section is intended to apply and the section as a whole is intended to apply in other circumstances.

It is not the purpose of this section to induce you to infringe any patents or other property right claims or to contest validity of any such claims; this section has the sole purpose of protecting the integrity of the free software distribution system, which is implemented by public license practices. Many people have made generous contributions to the wide range of software distributed through that system in reliance on consistent application of that system; it is up to the author/donor to decide if he or she is willing to distribute software through any other system and a licensee cannot impose that choice.

This section is intended to make thoroughly clear what is believed to be a consequence of the rest of this License.

8. If the distribution and/or use of the Program is restricted in certain countries either by patents or by copyrighted interfaces, the original copyright holder who places the Program under this License may add an explicit geographical distribution limitation excluding those countries, so that distribution is permitted only in or among countries not thus excluded. In such case, this License incorporates the limitation as if written in the body of this License.

9. The Free Software Foundation may publish revised and/or new versions of the General Public License from time to time. Such new versions will be similar in spirit to the present version, but may differ in detail to address new problems or concerns.

Each version is given a distinguishing version number. If the Program specifies a version number of this License which applies to it and "any later version", you have the option of following the terms and conditions either of that version or of any later version published by the Free Software Foundation. If the Program does not specify a version number of this License, you may choose any version ever published by the Free Software Foundation.

10. If you wish to incorporate parts of the Program into other free programs whose distribution conditions are different, write to the author to ask for permission. For software which is copyrighted by the Free Software Foundation, write to the Free Software Foundation; we sometimes make exceptions for this. Our decision will be guided by the two goals of preserving the free status of all derivatives of our free software and of promoting the sharing and reuse of software generally.

NO WARRANTY

11. BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTY FOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE LAW. EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE PROGRAM IS WITH YOU. SHOULD THE PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING, REPAIR OR CORRECTION.

12. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR REDISTRIBUTE THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.

END OF TERMS AND CONDITIONS

How to Apply These Terms to Your New Programs

If you develop a new program, and you want it to be of the greatest possible use to the public, the best way to achieve this is to make it free software which everyone can redistribute and change under these terms.

To do so, attach the following notices to the program. It is safest to attach them to the start of each source file to most effectively convey the exclusion of warranty; and each file should have at least the "copyright" line and a pointer to where the full notice is found.

    One line to give the program's name and a brief idea of what it does.
    Copyright (C) <year> <name of author>

    This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version.

    This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.

    You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA

Also add information on how to contact you by electronic and paper mail.

If the program is interactive, make it output a short notice like this when it starts in an interactive mode:

    Gnomovision version 69, Copyright (C) year name of author Gnomovision comes with ABSOLUTELY NO WARRANTY; for details type `show w'. This is free software, and you are welcome to redistribute it under certain conditions; type `show c' for details.

The hypothetical commands `show w' and `show c' should show the appropriate parts of the General Public License. Of course, the commands you use may be called something other than `show w' and `show c'; they could even be mouse-clicks or menu items--whatever suits your program.

You should also get your employer (if you work as a programmer) or your school, if any, to sign a "copyright disclaimer" for the program, if necessary. Here is a sample; alter the names:

    Yoyodyne, Inc., hereby disclaims all copyright interest in the program `Gnomovision' (which makes passes at compilers) written by James Hacker.

    signature of Ty Coon, 1 April 1989
    Ty Coon, President of Vice

This General Public License does not permit incorporating your program into proprietary programs. If your program is a subroutine library, you may consider it more useful to permit linking proprietary applications with the library. If this is what you want to do, use the GNU Library General Public License instead of this License.

"CLASSPATH" EXCEPTION TO THE GPL VERSION 2

Certain source files distributed by Oracle are subject to the following clarification and special exception to the GPL Version 2, but only where Oracle has expressly included in the particular source file's header the words "Oracle designates this particular file as subject to the "Classpath" exception as provided by Oracle in the License file that accompanied this code."

Linking this library statically or dynamically with other modules is making a combined work based on this library.  Thus, the terms and conditions of the GNU General Public License Version 2 cover the whole combination.

As a special exception, the copyright holders of this library give you permission to link this library with independent modules to produce an executable, regardless of the license terms of these independent modules, and to copy and distribute the resulting executable under terms of your choice, provided that you also meet, for each linked independent module, the terms and conditions of the license of that module.  An independent module is a module which is not derived from or based on this library.  If you modify this library, you may extend this exception to your version of the library, but you are not obligated to do so.  If you do not wish to do so, delete this exception statement from your version.

Rechtlicher Hinweis

Copyright © 2017 Red Hat, Inc.
The text of and illustrations in this document are licensed by Red Hat under a Creative Commons Attribution–Share Alike 3.0 Unported license ("CC-BY-SA"). An explanation of CC-BY-SA is available at http://creativecommons.org/licenses/by-sa/3.0/. In accordance with CC-BY-SA, if you distribute this document or an adaptation of it, you must provide the URL for the original version.
Red Hat, as the licensor of this document, waives the right to enforce, and agrees not to assert, Section 4d of CC-BY-SA to the fullest extent permitted by applicable law.
Red Hat, Red Hat Enterprise Linux, the Shadowman logo, JBoss, OpenShift, Fedora, the Infinity logo, and RHCE are trademarks of Red Hat, Inc., registered in the United States and other countries.
Linux® is the registered trademark of Linus Torvalds in the United States and other countries.
Java® is a registered trademark of Oracle and/or its affiliates.
XFS® is a trademark of Silicon Graphics International Corp. or its subsidiaries in the United States and/or other countries.
MySQL® is a registered trademark of MySQL AB in the United States, the European Union and other countries.
Node.js® is an official trademark of Joyent. Red Hat Software Collections is not formally related to or endorsed by the official Joyent Node.js open source or commercial project.
The OpenStack® Word Mark and OpenStack logo are either registered trademarks/service marks or trademarks/service marks of the OpenStack Foundation, in the United States and other countries and are used with the OpenStack Foundation's permission. We are not affiliated with, endorsed or sponsored by the OpenStack Foundation, or the OpenStack community.
All other trademarks are the property of their respective owners.