Global Assembly Cache

Der Global Assembly Cache (GAC; deutsch „Globaler Assembly-Zwischenspeicher“) ist ein Verfahren des .NET-Frameworks, um Versionskonflikte zwischen Programmbibliotheken zu vermeiden.

Identität und Installation im GAC

Die Identität einer Assembly setzt sich aus fünf Komponenten zusammen: dem Namen, der Dateiversion, der Sprachversion, dem öffentlichen Schlüsseltoken und der Prozessorarchitektur, für die die Assembly übersetzt wurde. Die Identität der Assembly wird über einen so genannten „starken Namen“ gesichert. Dabei wird der Name durch die Signierung der Assembly mit einem öffentlichen Schlüssel geschützt. Es ist möglich, eine Assembly durch Signierung mit unterschiedlichen Schlüsseln mehrfach im GAC zu installieren. Somit kann z. B. ein Softwarehersteller eine quelloffene Bibliothek verändern (patchen) und mit seinen eigenen Keys signieren. Diese Assembly kann dann trotz gleichen Namens und Versionsnummer im GAC neben der ursprünglichen Assembly installiert werden. Lokalisierte Versionen wie z. B. für Deutsch oder Französisch (DE, FR) sind ebenso Teil der Identität der Assembly wie die Optimierung auf eine Prozessorplattform (CIL(MSIL), x86, x64).

Der GAC ermöglicht somit die systemweite Bereitstellung von Assemblies, ohne Namenskonflikte der zugrundeliegenden Dateien (DLLs oder EXEs) in Kauf zu nehmen. Die sogenannte „DLL Hell“ wurde durch die Einführung des GAC konsequent umgangen.

Die Installation der Dateien im GAC geschieht üblicherweise über den Windows Installer, kann aber auch manuell mit Hilfe des Programmes GACUTIL.exe erfolgen. Auf die Verzeichnisse des GAC kann nur mit Administratorrechten schreibend zugegriffen werden, sodass zur Installation von Dateien im GAC Administratorrechte erforderlich sind.

Implementierung des GAC unter Windows

Ansicht des GAC in der Explorer-Erweiterung und im tatsächlichen Dateisystem

Dateisystem

Bis zur .NET Version 2.0 werden die gemeinsam genutzten Assemblies in einem speziellen Verzeichnis (%SystemRoot%\assembly) installiert und verwaltet. Ab .NET Version 3.0 wird das Verzeichnis %SystemRoot%\Microsoft.NET\assembly verwendet. Dieses enthält weitere Unterverzeichnisse für die jeweilige Prozessorarchitektur (z. B. GAC, GAC_32, GAC_64, GAC_MSIL) und die eigentlichen Assembly-Namen. Die Verzeichnisse mit den Assembly-Namen enthalten Unterverzeichnisse mit der Assemblyversion und dem öffentlichen Schlüssel. Der Zugriff auf die passende Assemblyversion ist also über einen Verzeichnisbaum möglich.

Explorer-Erweiterung

Der Windows-Explorer verfügt über ein spezielles Interface zur Anzeige von Assemblies, den Assembly Cache Viewer. Beim Ansteuern des %SystemRoot%\assembly Verzeichnisses werden dem Benutzer alle installierten Assemblies mit Version, Kultur, Schlüsseltoken und Prozessorarchitektur angezeigt. Das Interface erlaubt auch eine Installation per Drag and Drop. Diese Interface funktioniert jedoch nur bis zur .NET Version 2.0.