X Server

X Server
Logo des X Window Systems
GNOME 2.18.1
KDE 4.2
Xfce 4.4

Das X Window System (auch: X Version 11, X11, X) ist ein Netzwerkprotokoll und eine Software, die Fenster auf Bitmap-Displays auf den meisten Unix-artigen Betriebssystemen und OpenVMS ermöglicht. X11 wurde auf allen gebräuchlichen Betriebssystemen implementiert.

Es stellt einen Standardbaukasten und das Protokoll zum Bau einer grafischen Benutzeroberfläche zur Verfügung. Dazu gehören Zeichnen und Bewegen von Fenstern auf dem Bildschirm, sowie das Behandeln der Benutzereingaben mit Maus und Tastatur. X schreibt keine spezielle Benutzerschnittstelle vor, sondern überlässt dies seinen Client-Programmen. Deshalb können X-basierte Umgebungen in ihrem Aussehen sehr variieren. Mithilfe von Desktop Environments – die bekanntesten, KDE, GNOME und Xfce rechts abgebildet – wird dem entgegengewirkt. Endanwender kommen auf modernen Unix-Desktops mit den Kernprogrammen des X Window Systems kaum noch in Berührung.

Frühere Anzeigeprotokolle konnten nur eingebaute oder direkt angeschlossene Anzeigen verwalten. In Erweiterung dazu wurde X spezifisch als Client-Server-System entworfen, was neben der lokalen auch eine netzwerktransparente Verwendung ermöglicht.

Die X.Org Foundation betreut heute das Projekt und hat am 6. September 2007 die Version 7.3 der Referenzimplementierung als freie Software unter der MIT-Lizenz herausgegeben. Eine weitere, in den 1990ern weit verbreitete Implementierung ist XFree86.

Inhaltsverzeichnis

Geschichte von X

X wurde 1984 im Projekt Athena in Zusammenarbeit des MIT, der Digital Equipment Corporation und IBM entwickelt. Die erste Version wurde im Juni 1984 freigegeben, im September 1987 folgte die Version X11.

Als 1988 der Erfolg immer größer wurde, wurde das nicht-kommerzielle X-Konsortium gegründet, das die weitere Entwicklung übernahm. Es veröffentlichte verschiedene Versionen, die letzte große war X11R6 1994. Danach übernahm The Open Group die Entwicklung und Standardisierung. In der gleichen Zeit erreichte die freie X-Implementierung XFree86 einen immer größeren Bekanntheitsgrad und wurde zum De-facto-Standard der X-Implementierung. 2003 aber gab es projektinterne und lizenzrechtliche Probleme bei XFree86, die im Endeffekt zur Auflösung des Entwicklerteams führten. Unter dem Dach der daraufhin neu gegründeten X.Org-Foundation wurde fortan eine Abspaltung des alten XFree86 weiterentwickelt und trat unter dem Namen X.Org-Server größtenteils in dessen Fußstapfen. Seit etwa 2005 gilt er als der meistverbreitete X-Server und damit die meistverbreitete X-Implementierung.

Technik

Der X-Server steuert die Ein- und Ausgabegeräte, wie unter anderem Zeigegeräte (z. B. Maus), Tastatur, Bildschirm und Grafikkarte. Dazu kommuniziert er in der Theorie mit dem Betriebssystem-Kernel, in der Praxis wird der Kernel aber auch umgangen. Das zugrundeliegende Konzept ist eine Erweiterung des Terminal-Konzeptes auf grafische Benutzeroberflächen: Ein Programm verlässt sich für die grafische Eingabe (Maus) und Ausgabe (Fenstertechnik) auf die Dienste eines anderen dafür spezialisierten Programms (X-Server), die Kommunikation läuft immer über das Netzwerk.

Die Darstellung bei X ist die eines rastergrafikbasierten Fenstermanagers, der verschiedene Funktionen bereitstellt. Dazu gehört das Zeichnen und Bewegen der Fenster, die ereignisorientierte Handhabung eines Zeigergeräts, z. B. einer Maus, die Interprozesskommunikation und teilweise auch die Verwaltungsfunktionen für Druck und Audio-Ausgabe. X ist also ein Minimalsystem, bei dem zum Zeichnen lediglich Primitive wie Linien, Muster, etc. bereitgestellt werden.

Das eigentliche Aussehen und Verhalten des Fenstersystems wird deshalb nicht von X bestimmt, sondern von dem Fenstermanager, der wie eine normale Anwendung einfach als Client des X-Servers läuft. Für das Aussehen der Programme selbst ist er aber nicht verantwortlich, das übernimmt meistens das sog. Toolkit (eine spezielle Komponentenbibliothek), welches das Zeichnen und Verwalten der typischen Elemente einer grafischen Oberfläche wie z. B. Menüs und Buttons übernimmt. Siehe dazu auch Arbeitsoberfläche.

Kommunikationsmodell

X baut auf einem Client-Server-Modell auf:

  • Der X-Server läuft auf dem Rechner am Arbeitsplatz und stellt seine (grafischen) Dienste den X-Clients zur Verfügung. Er enthält den Grafikkartentreiber sowie Treiber für Tastatur, Maus und andere Eingabegeräte (wie z.B. Grafik-Tablets) und kommuniziert mit dem X-Client über das Netzwerk.
  • Der X-Client ist das Anwendungsprogramm, das die grafischen Ein/Ausgabe-Dienste des X-Servers benutzt. Er kann auf demselben, oder auch auf irgendeinem entfernten Rechner laufen (sofern eine Netzwerkverbindung zwischen beiden besteht). Der X-Client benutzt die Dienste des X-Servers, um eine grafische Darstellung zu erreichen, und empfängt von ihm die diversen Ereignisse (events) wie Tastenanschläge, Mausbewegungen, Klicks usw.

X-Terminal

Das in der Großrechner-Welt bekannte, textbasierte Terminal-System (dort meistens proprietäre wie IBM 5250 und 3270; unter Digitals VMS die bekannten seriellen Terminals wie z. B. VT100) erlebte seine grafische Weiterentwicklung zum X-Terminal; ein Rechner, auf dem nichts anderes als ein X-Server läuft. Diese X-Terminals werden häufig genutzt, um mit leistungsschwachen Rechnern auf rechenintensive Anwendungen zuzugreifen: Die Anwendung selbst läuft auf einem Server, das X-Terminal übernimmt nur die Anzeige der grafischen Oberfläche.

Mittlerweile hat es sich durchgesetzt, statt spezieller Hardware für X-Terminals auf Standard-Hardware von PCs zurückzugreifen. Mit dieser können die Funktionen von X-Terminals zum Beispiel in Form von Thin Client preiswert umgesetzt werden.

3D-Beschleunigung

Um schnelle 3D-Beschleunigung zu ermöglichen, stellt das X-Window-System die Schnittstelle Direct Rendering Infrastructure (DRI) bereit, über die Programme direkt auf die 3D-Hardware zugreifen können. Das geschieht bei freien Treibern durch die OpenGL-Implementierung Mesa 3D, im Fall von proprietären Treibern durch jeweils proprietäre Implementierungen von OpenGL.

Mit Hilfe von 3D-Erweiterungen wie AIGLX und XGL werden im X.org-Server darüber hinaus 3D-Effekte auf dem Desktop selbst unterstützt.

Stärken

Das X-System wurde von Anfang an für den effizienten Netzwerkbetrieb konzipiert. Die Kommunikation zwischen Client und Server läuft über ein standardisiertes Protokoll ab, das nur relativ geringe Transferraten benötigt. Der Quellcode des X-Systems ist zwar objektorientiert, aber dennoch in C geschrieben, so dass eine Übersetzung auf nahezu jedem Unix-Rechner möglich ist. Das X-System ist im Gegensatz zu aktuellen MS-Windows-Versionen kein Betriebssystem, weswegen ein Absturz von X in der Regel keinen Einfluss auf dessen Integrität hat. Weiterhin hat der Fenstermanager (die „Bedienoberfläche“) im Prinzip denselben Status wie ein X-Client: Man kann im laufenden Betrieb einen Fenstermanager durch einen anderen ersetzen. Bereits mit sehr kleinen Fenstermanagern (z. B. twm, ca. 140 KB) kann komfortabel gearbeitet werden.

Durch den durchdachten, hierarchischen Aufbau des Systems ist beispielsweise folgendes möglich:

  • An einem X-Server mehrere Bildschirm-Arbeitsplätze betreiben.
  • Für Entwicklungs- und Testzwecke einen X-Server in einem Fenster eines anderen X-Servers laufen lassen.
  • Programme an einem Rechner mit völlig anderer Hard- und Software als dem Bedienrechner ausführen.

Die Weiterentwicklung von X läuft im Vergleich zur Hardware auf großen Zeitskalen und mit nur geringen Veränderungen ab. Kompatibilitätsprobleme treten daher nicht auf, wenn nur Standardbibliotheken verwendet werden. Allerdings benutzt ein großer Teil der X-Clients heute Erweiterungen wie Xft, XVideo oder Xinerama.

Die strikte Trennung des X Window Systems von der Benutzeroberfläche führt zu einem vergleichsweise flexiblen System, das aber auch sehr uneinheitlich erscheinen kann: Da das Design der Oberflächenelemente im Gegensatz zu Windows oder Mac OS nicht aus dem eingestellten Design des Haupt-Toolkits stammt, sondern es verschiedene Toolkits (unter anderem Qt und GTK+) mit verschiedenen Eigenschaften gibt, die verschiedene Designs verwenden, kann es durchaus vorkommen, dass jedes der genutzten Programme ein unterschiedliches Aussehen und Verhalten zeigt.

Ansätze zur Verbesserung

Übertragungsgeschwindigkeit

Es wurden mehrere Ansätze entwickelt, um die Übertragungsgeschwindigkeit zu verbessern:

  • Kompression der Übertragungsdaten,
  • anlegen eines Caches für schon übertragene Daten und
  • Reduzierung der Round Trip Time zwischen X-Client und X-Server durch effizientere Programmierung.

Mehrere Projekte versuchen, diese Techniken umzusetzen: die XCB-Bibliothek ist eine Neufassung der Xlib-Bibliothek, die im X-Server den Datenverkehr zwischen Client und Server regelt. Bei der Entwicklung von XCB wird insbesondere Wert auf eine gesteigerte Effizienz gelegt.

Einen hohen Bekanntheitsgrad hat ebenfalls das NX-Projekt der italienischen Firma NoMachine, das mit Hilfe eines Caches und Datenkompression X auch über Modem-Leitungen nutzbar macht.

In der Vergangenheit arbeitete auch das Low-Bandwidth-X-Projekt von Keith Packard in diesem Bereich. Es war gedacht, eine Erweiterung des X-Protokolls zu erstellen, um dessen Netzwerktransparenz auch für niedrige Bandbreiten nutzbar zu machen. Mit der Veröffentlichung der von X11R6.3 durch das X-Konsortium im Dezember 1996 wurde LBX eine volle Erweiterung des X-Protokolls. Da es aber nie großflächig genutzt wurde und auch nur für einen Teil der Probleme eine Lösung bieten konnte, wurde das Projekt im Laufe des Jahres 2000 von Keith Packard für tot erklärt [1].

Gesteigerte Einheitlichkeit

Eine gesteigerte Einheitlichkeit wurde ebenfalls von mehreren Projekten verfolgt. Ansätze waren die Erstellung einer Desktopoberfläche mit einheitlichen Oberflächenbibliotheken oder aber das Ersetzen von X durch ein auf höherem Niveau angelegtes System, das von Beginn an eine einheitliche Behandlung von Oberflächenelementen beinhaltete. Das Fresco-Projekt und das Y Window System entwickelten jeweils Lösungen, um den zweiten Ansatz umzusetzen, die Projekte ruhen aber zur Zeit.

Ein anderer, aktiv verfolgter Ansatz ist der Versuch, durch gemeinsame Richtlinien für Benutzerschnittstellen und Verhaltensweisen der Software Einheitlichkeit zwischen den verschiedenen Toolkits zu erlangen. Dieser Ansatz wird vor allen Dingen im Rahmen des freedesktop.org-Projekts verfolgt und führte dort z.B. zu einheitlichen Standards für Icons.

Sonstiges

In den frühen 1990er-Jahren war die komplette X11-Distribution oft die größte Datei auf Unix-Rechnern. Da sie zudem frei war, wurde sie gerne als Mailbombe verwendet oder zumindest damit gedroht. Soll ich Dir ein X11R3 schicken war daher im Usenet ein Running-Gag, um Newbies auf Fehlverhalten hinzuweisen.

Siehe auch

Literatur

  • Xlib Programming Manual, O'Reilly & Associates, Inc. (Online-Version)

Weblinks

Einzelnachweise

  1. Keith Packard: "An LBX Postmortem", 2000


Wikimedia Foundation.

Игры ⚽ Нужно решить контрольную?

Schlagen Sie auch in anderen Wörterbüchern nach:

  • Server emulator — is a term that is used to refer to an internet server that mimics the behavior of another server that is usually more well known. This is implemented through cloning or reverse engineering of the original server. Other synonyms include server… …   Wikipedia

  • Server — may refer to:In computing: *Server (computing), a server application, operating system, computer, or appliance **Application server, a server dedicated to running certain software applications **Communications server, carrier grade computing… …   Wikipedia

  • Server Djeparov — Personal information Full name Server Resatovich Djeparov Date of birth 3 October 1982 ( …   Wikipedia

  • Server-side scripting — is a web server technology in which a user s request is fulfilled by running a script directly on the web server to generate dynamic HTML pages. It is usually used to provide interactive web sites, that interface to databases or other data stores …   Wikipedia

  • Server Side Includes — (SSI) is a simple interpreted server side scripting language used almost exclusively for the Web. The most frequent use of SSI is to include the contents of one or more files into a web page on a web server. For example, a web page containing a… …   Wikipedia

  • Server-side — refers to operations that are performed by the server in a client server relationship in computer networking.Typically, a server is a software program, such as a web server, that runs on a remote server, reachable from a user s local computer or… …   Wikipedia

  • server — serv‧er [ˈsɜːvə ǁ ˈsɜːrvər] also ˈfile ˌserver noun [countable] COMPUTING a powerful computer used to store large amounts of information and to connect other smaller computers in a network. The smaller computers are sometimes called client S …   Financial and business terms

  • Server Pages — are scripts that are embedded in HTML and processed on the server before the page is sent to the client s web browser. This concept is explained generally at Server side scripting.Examples of server pages implementations are:* Active Server Pages …   Wikipedia

  • Server Jung — Nawab Agha Mirza Beg Khan, Server Jung Bahadur (* 1848 in Delhi), war in der zweiten Hälfte des 19. Jahrhundert im indischen Fürstenstaat Hyderabad Lehrmeister des zukünftigen Diwan Salar Jung II. und des Nizam Asaf Jah VI. E …   Deutsch Wikipedia

  • Server-side JavaScript — (SSJS) refers to JavaScript that runs on server side. This term was coined because the language is predominantly used on the client side, i.e. client side JavaScript (CSJS).The first implementation of SSJS was Netscape s LiveWire, included in… …   Wikipedia

  • Server side includes — Les Server Side Includes, abrégés SSI, sont un langage de programmation fait pour être interprété par un serveur HTTP lorsqu il sert un document HTML. Ce langage tire son nom de sa principale utilisation : inclure plusieurs fichiers pour… …   Wikipédia en Français

Share the article and excerpts

Direct link
Do a right-click on the link above
and select “Copy Link”