Die vorliegende Übersetzung wurde maschinell erstellt. Im Falle eines Konflikts oder eines Widerspruchs zwischen dieser übersetzten Fassung und der englischen Fassung (einschließlich infolge von Verzögerungen bei der Übersetzung) ist die englische Fassung maßgeblich.
Verwendung der AWS Secrets Manager Agent
So funktioniert der Secrets Manager Agent
Der AWS Secrets Manager Agent ist ein clientseitiger HTTP-Dienst, mit dem Sie standardisieren können, wie Sie Secrets aus Secrets Manager in Ihren Computerumgebungen verwenden. Sie können ihn mit den folgenden Diensten verwenden:
-
AWS Lambda
-
Amazon Elastic Container Service
-
Amazon Elastic Kubernetes Service
-
Amazon Elastic Compute Cloud
Der Secrets Manager Agent ruft Secrets ab und speichert sie im Speicher, sodass Ihre Anwendungen Secrets von localhost abrufen können, anstatt Secrets Manager direkt aufzurufen. Der Secrets Manager Agent kann nur Geheimnisse lesen — er kann sie nicht ändern.
Der Secrets Manager Agent ist Open Source. Der Quellcode, die Installationsanweisungen und die neuesten Versionsinformationen sind unter verfügbar GitHub
Wichtig
Der Secrets Manager Agent verwendet die AWS Anmeldeinformationen aus Ihrer Umgebung, um Secrets Manager aufzurufen. Es bietet Schutz vor Server Side Request Forgery (SSRF), um die Sicherheit geheimer Daten zu verbessern. Der Secrets Manager Agent verwendet standardmäßig den ML-KEM Post-Quantum-Schlüsselaustausch als Schlüsselaustausch mit der höchsten Priorität.
Grundlegendes zum Secrets Manager Agent-Caching
Der Secrets Manager Agent verwendet einen In-Memory-Cache, der zurückgesetzt wird, wenn der Secrets Manager Agent neu gestartet wird. Er aktualisiert in regelmäßigen Abständen zwischengespeicherte geheime Werte auf der Grundlage der folgenden Kriterien:
-
Die Standard-Aktualisierungsfrequenz (TTL) beträgt 300 Sekunden
-
Sie können die TTL mithilfe einer Konfigurationsdatei ändern
-
Die Aktualisierung erfolgt, wenn Sie nach Ablauf der TTL ein Geheimnis anfordern
Anmerkung
Der Secrets Manager Agent beinhaltet keine Cache-Invalidierung. Wenn ein Geheimnis rotiert, bevor der Cache-Eintrag abläuft, gibt der Secrets Manager Agent möglicherweise einen veralteten geheimen Wert zurück.
Der Secrets Manager Agent gibt geheime Werte im gleichen Format zurück wie die Antwort vonGetSecretValue. Geheime Werte werden im Cache nicht verschlüsselt.
Den Secrets Manager Agent erstellen
Bevor Sie beginnen, stellen Sie sicher, dass Sie die Standard-Entwicklungstools und Rust-Tools für Ihre Plattform installiert haben.
Anmerkung
Um den Agenten mit aktivierter fips Funktion auf macOS zu erstellen, ist derzeit die folgende Problemumgehung erforderlich:
-
Erstellen Sie eine Umgebungsvariable namens
SDKROOT, die auf das Ergebnis der Ausführung gesetzt istxcrun --show-sdk-path
Installieren Sie den Secrets Manager Agent
Wählen Sie Ihre Computerumgebung aus den folgenden Installationsoptionen aus.
Rufen Sie Geheimnisse mit dem Secrets Manager Agent ab
Um ein Geheimnis abzurufen, rufen Sie den lokalen Secrets Manager Agent-Endpunkt mit dem geheimen Namen oder ARN als Abfrageparameter auf. Standardmäßig ruft der Secrets Manager Agent die AWSCURRENT Version des Secrets ab. Um eine andere Version abzurufen, verwenden Sie entweder den VersionStage- oder den VersionID-Parameter.
Wichtig
Um den Secrets Manager Agent zu schützen, müssen Sie jeder Anfrage einen SSRF-Token-Header beifügen:X-Aws-Parameters-Secrets-Token. Der Secrets Manager Agent lehnt Anfragen ab, die diesen Header nicht haben oder die ein ungültiges SSRF-Token haben. Sie können den Namen des SSRF-Headers in der anpassen. Den Secrets Manager Agent konfigurieren
Erforderliche Berechtigungen
Der Secrets Manager Agent verwendet das AWS SDK für Rust, das die AWS Credential Provider Chain verwendet. Die Identität dieser IAM-Anmeldeinformationen bestimmt die Berechtigungen, die der Secrets Manager Agent zum Abrufen von Geheimnissen hat.
-
secretsmanager:DescribeSecret -
secretsmanager:GetSecretValue
Weitere Informationen zu Berechtigungen finden Sie unter Referenz zu Berechtigungen für AWS Secrets Manager.
Wichtig
Nachdem der geheime Wert in den Secrets Manager Agent abgerufen wurde, kann jeder Benutzer mit Zugriff auf die Rechenumgebung und das SSRF-Token aus dem Secrets Manager Agent-Cache auf das Geheimnis zugreifen. Weitere Informationen finden Sie unter Sicherheitsüberlegungen.
Beispielanfragen
Den RefreshNow-Parameter verstehen
Der Secrets Manager Agent verwendet einen In-Memory-Cache, um geheime Werte zu speichern, die er regelmäßig aktualisiert. Standardmäßig erfolgt diese Aktualisierung, wenn Sie nach Ablauf der Gültigkeitsdauer (Time to Live, TTL), in der Regel alle 300 Sekunden, ein Geheimnis anfordern. Dieser Ansatz kann jedoch manchmal zu veralteten Geheimwerten führen, insbesondere wenn ein Geheimnis rotiert, bevor der Cache-Eintrag abläuft.
Um diese Einschränkung zu umgehen, unterstützt der Secrets Manager Agent einen Parameter, der refreshNow in der URL aufgerufen wird. Sie können diesen Parameter verwenden, um eine sofortige Aktualisierung des Werts eines Geheimnisses zu erzwingen, den Cache zu umgehen und sicherzustellen, dass Sie über die aktuellsten Informationen verfügen.
- Standardverhalten (ohne
refreshNow) -
-
Verwendet zwischengespeicherte Werte, bis TTL abläuft
-
Aktualisiert Geheimnisse erst nach TTL (Standard 300 Sekunden)
-
Kann veraltete Werte zurückgeben, wenn die Geheimnisse rotieren, bevor der Cache abläuft
-
- Verhalten mit
refreshNow=true -
-
Umgeht den Cache vollständig
-
Ruft den neuesten geheimen Wert direkt aus Secrets Manager ab
-
Aktualisiert den Cache mit dem neuen Wert und setzt die TTL zurück
-
Stellt sicher, dass Sie immer den aktuellsten geheimen Wert erhalten
-
Force-refresh ein geheimer Wert
Wichtig
Der Standardwert von refreshNow ist false. Wenn auf gesetzttrue, überschreibt es die in der Secrets Manager Agent-Konfigurationsdatei angegebene TTL und führt einen API-Aufruf an Secrets Manager durch.
Mithilfe von Rollenverkettung können Sie geheime Daten kontenübergreifend abrufen
Die Rollenverkettung ermöglicht es dem Secrets Manager Agent, Geheimnisse von anderen AWS Konten abzurufen, indem er mithilfe von IAM-Rollen annimmt. AWS STS AssumeRole Der Secrets Manager Agent erstellt und speichert einen separaten Caching-Client für jeden eindeutigen Rollen-ARN. Jeder Rollenclient verwaltet seinen eigenen unabhängigen Cache, sodass derselbe geheime Schlüssel, der mit unterschiedlichen Rollen abgerufen wurde, separate Cache-Einträge hat.
Erforderliche Berechtigungen
Um die Rollenverkettung verwenden zu können, benötigen Sie Folgendes:
-
Die Umgebungsanmeldedaten des Secrets Manager Agents müssen über
sts:AssumeRoleBerechtigungen für den ARN der Zielrolle verfügen. -
Die Zielrolle muss über
secretsmanager:GetSecretValuesecretsmanager:DescribeSecretBerechtigungen für die Secrets verfügen, auf die Sie zugreifen möchten. -
Die Vertrauensrichtlinie der Zielrolle muss es der Identität des Secrets Manager Agents ermöglichen, sie anzunehmen.
Kontenübergreifende Geheimnisse abrufen
Fügen Sie den roleArn Abfrageparameter in Ihre Anfrage an den Secrets Manager Agent ein, um anzugeben, welche Rolle beim Abrufen von Geheimnissen übernommen werden soll.
Konfiguration und Grenzen der Rollenverkettung
Konfigurieren Sie die Rollenverkettung mit der max_roles Option in Ihrer TOML-Konfigurationsdatei. Dadurch wird die maximale Anzahl gleichzeitig angenommener Rollen im Bereich von 1 bis 20 festgelegt. Die Standardeinstellung ist 20.
Wichtig
Angenommene Rollen werden nicht aus dem Rollencache des Secrets Manager Agents entfernt. Sobald die maximale Anzahl von Rollen erreicht ist, werden Anfragen mit neuen Rollen-ARNs mit einem 400 Fehler zurückgewiesen, bis der Secrets Manager Agent neu gestartet wird.
Fehlerantworten bei der Rollenverkettung
400-
Das
roleArnFormat ist ungültig oder die maximale Anzahl angenommener Rollen wurde erreicht. 403-
Der AWS STS
AssumeRole-Aufruf ist fehlgeschlagen. Stellen Sie sicher, dass die Vertrauensrichtlinie der Zielrolle es der Identität des Secrets Manager Agents erlaubt, diese anzunehmen.
Pre-fetch Geheimnisse beim Start
Standardmäßig ruft der Secrets Manager Agent Secrets bei Bedarf ab, wenn Ihre Anwendung sie anfordert. Beim Pre-Fetching lädt der Secrets Manager Agent beim Start bestimmte Secrets in den Cache, sodass Ihre Anwendung sofort darauf zugreifen kann, ohne auf den ersten API-Aufruf warten zu müssen. Pre-fetching wird als Hintergrundaufgabe ausgeführt — der Secrets Manager Agent beginnt sofort mit der Annahme von Anfragen und blockiert nicht, wenn der Prefetch abgeschlossen ist.
Sie können Geheimnisse, die vorab abgerufen werden sollen, auf zwei Arten angeben:
-
Explizite Geheimnisse — Listet bestimmte geheime IDs oder ARNs auf.
-
Tag-based Entdeckung — Entdecken Sie Geheimnisse anhand des Tag-Schlüssels. Der Secrets Manager Agent ruft alle Secrets ab, die das angegebene Tag haben.
Erforderliche Berechtigungen
Zusätzlich zu den Standardberechtigungen für das Abrufen von Geheimnissen ist für den Vorabruf Folgendes erforderlich:
-
secretsmanager:BatchGetSecretValue— Für alle Pre-Fetch-Operationen erforderlich. -
secretsmanager:ListSecrets— Nur erforderlich, wenn die Tag-basierte Erkennung verwendet wird.
Konfigurieren des Vorabrufs
Fügen Sie Ihrer TOML-Konfigurationsdatei einen [prefetch] Abschnitt hinzu. Die folgenden Optionen sind verfügbar:
cache_buffer_ratio-
Der maximale Teil des Caches, der pro Client beim Pre-Fetch gefüllt werden soll, liegt im Bereich von 0,1 bis 1,0. Die Standardeinstellung ist 0,8. Wenn das Pufferlimit erreicht ist, beendet der Secrets Manager Agent das Vorabrufen der verbleibenden Geheimnisse — er entfernt keine vorhandenen Cache-Einträge. Secrets, die beim Pre-Fetch nicht geladen wurden, sind weiterhin auf Anfrage verfügbar.
max_jitter_seconds-
Eine zufällige Verzögerung in Sekunden, bevor der Vorabruf beginnt, im Bereich 0 bis 10. Der Standardwert ist 0. Verwenden Sie diese Option, um synchronisierte, flottenweite API-Aufrufe zu verhindern, wenn mehrere Agenten gleichzeitig starten.
Beispiel Pre-fetch Konfiguration mit expliziten Geheimnissen
[prefetch] cache_buffer_ratio = 0.6 max_jitter_seconds = 5 secrets = [ { secret_id = "arn:aws:secretsmanager:us-west-2:123456789012:secret:MySecret-AbCdEf" }, { secret_id = "MyOtherSecret" }, ]
Beispiel Pre-fetch Konfiguration mit tagbasierter Erkennung
[prefetch] cache_buffer_ratio = 0.8 filter_tags = [ { key = "Environment" }, { key = "Team" }, ]
Sie können auch explizite Geheimnisse und tagbasierte Erkennung in derselben Konfiguration kombinieren. Für kontoübergreifendes Prefetching fügen Sie das Feld hinzu. role_arn Weitere Informationen finden Sie unter Mithilfe von Rollenverkettung können Sie geheime Daten kontenübergreifend abrufen.
Beispiel Pre-fetch Konfiguration mit kontenübergreifendem Zugriff
[prefetch] cache_buffer_ratio = 0.6 max_jitter_seconds = 5 secrets = [ { secret_id = "arn:aws:secretsmanager:us-west-2:123456789012:secret:MySecret-AbCdEf" }, { secret_id = "cross-account-secret", role_arn = "arn:aws:iam::987654321098:role/SecretAccessRole" }, ] filter_tags = [ { key = "Environment" }, { key = "Team", role_arn = "arn:aws:iam::987654321098:role/SecretAccessRole" }, ]
Den Secrets Manager Agent konfigurieren
Um die Konfiguration des Secrets Manager Agent zu ändern, erstellen Sie eine TOML-Konfigurationsdatei./aws_secretsmanager_agent --config
config.toml dann auf.
Konfigurationsoptionen
log_level-
Die Detailebene, die in den Protokollen für den Secrets Manager Agent gemeldet wird: DEBUG, INFO, WARN, ERROR oder NONE. Die Standardeinstellung ist INFO.
log_to_file-
Ob in einer Datei protokolliert werden soll oder stdout/stderr:
trueoderfalse. Der Standardwert isttrue. http_port-
Der Port für den lokalen HTTP-Server im Bereich 1024 bis 65535. Die Standardeinstellung ist 2773.
region-
Die AWS Region, die für Anfragen verwendet werden soll. Wenn keine Region angegeben ist, bestimmt der Secrets Manager Agent die Region aus dem SDK. Weitere Informationen finden Sie unter Geben Sie Ihre Anmeldeinformationen und die Standardregion an im AWS SDK for Rust Developer Guide.
ttl_seconds-
Die TTL in Sekunden für die zwischengespeicherten Elemente im Bereich 0 bis 3600. Die Standardeinstellung ist 300. 0 gibt an, dass kein Caching stattfindet.
cache_size-
Die maximale Anzahl von Geheimnissen, die im Cache gespeichert werden können, liegt im Bereich von 1 bis 1000. Der Standardwert ist 1000.
ssrf_headers-
Eine Liste von Header-Namen, die der Secrets Manager Agent auf das SSRF-Token überprüft. Die Standardeinstellung ist "X-Aws-Parameters-Secrets-Token, X-Vault-Token“.
ssrf_env_variables-
Eine Liste von Umgebungsvariablennamen, die der Secrets Manager Agent in sequentieller Reihenfolge nach dem SSRF-Token sucht. Die Umgebungsvariable kann das Token oder einen Verweis auf die Tokendatei enthalten, wie in:.
AWS_TOKEN=file:///var/run/awssmatokenDie Standardeinstellung ist "AWS_TOKEN, AWS_SESSION_TOKEN, AWS_CONTAINER_AUTHORIZATION_TOKEN“. path_prefix-
Das URI-Präfix, das verwendet wird, um festzustellen, ob es sich bei der Anfrage um eine pfadbasierte Anfrage handelt. Die Standardeinstellung ist „/v1/“.
max_conn-
Die maximale Anzahl von Verbindungen von HTTP-Clients, die der Secrets Manager Agent zulässt, im Bereich von 1 bis 1000. Die Standardeinstellung ist 800.
max_roles-
Die maximale Anzahl gleichzeitiger IAM-Rollen für den kontoübergreifenden Zugriff liegt im Bereich von 1 bis 20. Die Standardeinstellung ist 20. Weitere Informationen finden Sie unter Mithilfe von Rollenverkettung können Sie geheime Daten kontenübergreifend abrufen.
Optionale Funktionen
Der Secrets Manager Agent kann mit optionalen Funktionen erstellt werden, indem das --features Flag an übergeben wirdcargo build. Die verfügbaren Funktionen sind:
Build-Funktionen
prefer-post-quantum-
Stellt
X25519MLKEM768den Schlüsselaustausch-Algorithmus mit der höchsten Priorität her. Andernfalls ist er verfügbar, hat aber nicht die höchste Priorität.X25519MLKEM768ist ein hybrider, postquantensicherer Schlüsselaustausch-Algorithmus. fips-
Schränkt die vom Agenten verwendeten Verschlüsselungssammlungen auf Chiffren ein. FIPS-approved
Protokollierung
- Lokale Protokollierung
-
Der Secrets Manager Agent protokolliert Fehler lokal in der Datei
logs/secrets_manager_agent.logoder in, stdout/stderr abhängig von derlog_to_fileKonfigurationsvariablen. Wenn Ihre Anwendung den Secrets Manager Agent aufruft, um ein Geheimnis zu erhalten, werden diese Aufrufe im lokalen Protokoll angezeigt. Sie erscheinen nicht in den CloudTrail Protokollen. - Rotation der Protokolle
-
Der Secrets Manager Agent erstellt eine neue Protokolldatei, wenn die Datei 10 MB erreicht, und speichert insgesamt bis zu fünf Protokolldateien.
- AWS Dienstprotokollierung
-
Das Protokoll geht nicht an Secrets Manager, CloudTrail, oder CloudWatch. Anfragen zum Abrufen von Geheimnissen vom Secrets Manager Agent werden in diesen Protokollen nicht angezeigt. Wenn der Secrets Manager Agent Secrets Manager aufruft, um ein Geheimnis zu erhalten, wird dieser Anruf CloudTrail mit einer Benutzer-Agent-Zeichenfolge aufgezeichnet, die enthält
aws-secrets-manager-agent.
Sie können die Protokollierungsoptionen in der konfigurierenDen Secrets Manager Agent konfigurieren.
Sicherheitsüberlegungen
- Domäne des Vertrauens
-
Bei einer Agentenarchitektur ist die Vertrauensdomäne der Ort, an dem der Agentenendpunkt und das SSRF-Token zugänglich sind, was normalerweise der gesamte Host ist. Die Vertrauensdomäne für den Secrets Manager Agent sollte mit der Domäne übereinstimmen, in der die Secrets Manager Manager-Anmeldeinformationen verfügbar sind, um den gleichen Sicherheitsstatus aufrechtzuerhalten. Auf Amazon EC2 wäre die Vertrauensdomäne für den Secrets Manager Agent beispielsweise dieselbe wie die Domäne der Anmeldeinformationen, wenn Rollen für Amazon EC2 verwendet werden.
Wichtig
Sicherheitsbewusste Anwendungen, die noch keine Agentenlösung verwenden, bei der die Secrets Manager Manager-Anmeldeinformationen für die Anwendung gesperrt sind, sollten die Verwendung der sprachspezifischen AWS SDKs oder Caching-Lösungen in Betracht ziehen. Weitere Informationen finden Sie unter Geheime Informationen abrufen.