Freigeben über


Globaler Assemblycache

Aktualisiert: November 2007

Jeder Computer, auf dem die Common Language Runtime installiert ist, besitzt einen computerweiten Codecache, den so genannten globalen Assemblycache. Im globalen Assemblycache werden Assemblys gespeichert, die speziell für die gemeinsame Verwendung durch mehrere Anwendungen auf dem Computer vorgesehen sind.

Geben Sie Assemblys nur dann durch eine Installation im globalen Assemblycache frei, wenn dies unbedingt erforderlich ist. Wenn die Freigabe einer Assembly nicht unbedingt erforderlich ist, empfiehlt es sich, die Assemblyabhängigkeiten privat zu halten und Assemblys im Anwendungsverzeichnis abzulegen. Assemblys müssen außerdem nicht im globalen Assemblycache installiert sein, um für COM-Interop oder nicht verwalteten Code verfügbar zu sein.

Hinweis:

Es gibt Szenarien, in denen eine Assembly ausdrücklich nicht im globalen Assemblycache installiert werden soll. Wenn Sie eine der Assemblys, aus denen eine Anwendung besteht, im globalen Assemblycache ablegen, können Sie die Anwendung anschließend weder replizieren noch installieren, indem Sie mit dem xcopy-Befehl das Anwendungsverzeichnis kopieren. Sie müssen die Assembly zusätzlich in den globalen Assemblycache verschieben.

Es gibt mehrere Möglichkeiten für die Bereitstellung einer Assembly im globalen Assemblycache:

  • Die Verwendung eines Installationsprogramms, das für die Zusammenarbeit mit dem globalen Assemblycache entworfen wurde. Das ist die bevorzugte Option für die Installation von Assemblys im globalen Assemblycache.

  • Die Verwendung des Entwicklertools Global Assembly Cache-Tool (Gacutil.exe) aus Windows Software Development Kit (SDK).

  • Das Verschieben von Assemblys in den Cache durch einen Drag & Drop-Vorgang in Windows Explorer.

    Hinweis:

    Bei Bereitstellungsszenarien sollten Sie Assemblys mit Windows Installer 2.0 im globalen Assemblycache installieren. Da weder Windows Explorer noch das Global Assembly Cache-Tool die Assemblyverweiszählung und andere von Windows Installer bereitgestellte Funktionen unterstützen, sollten Sie beide nur in Entwicklungsszenarien verwenden.

Administratoren verwenden zum Schutz des Verzeichnisses systemroot oftmals eine Zugriffssteuerungsliste (ACL – Access Control List), um Schreib- und Ausführungszugriffe zu kontrollieren. Da der globale Assemblycache in einem Unterverzeichnis des Verzeichnisses systemroot installiert ist, erbt er die ACL dieses Verzeichnisses. Aus diesem Grund empfiehlt es sich, nur Benutzern mit Administratorrechten das Löschen von Dateien aus dem globalen Assemblycache zu gestatten.

Alle Assemblys, die im globalen Assemblycache bereitgestellt werden, müssen starke Namen besitzen. Beim Hinzufügen einer Assembly zum globalen Assemblycache werden Integritätsprüfungen für alle Dateien vorgenommen, aus denen die Assembly besteht. Diese Integritätsprüfungen werden vom Cache durchgeführt, um sicherzustellen, dass eine Assembly nicht manipuliert wurde (z. B. wenn eine Datei geändert wurde, aber das Manifest diese Änderung nicht widerspiegelt).

Siehe auch

Konzepte

Assemblys mit starkem Namen

Weitere Ressourcen

Assemblys in der Common Language Runtime (CLR)

Arbeiten mit Assemblys und dem globalen Assemblychache