Skip to content

Commit

Permalink
Merge pull request #248 from AmelieD455/main
Browse files Browse the repository at this point in the history
Löschen von S3 Objekten und Buckets mit s5cmd
  • Loading branch information
frosty-geek authored Dec 11, 2024
2 parents bf6f956 + cd141b6 commit 84a4bf0
Show file tree
Hide file tree
Showing 9 changed files with 513 additions and 217 deletions.
208 changes: 100 additions & 108 deletions content/de/storage-backup/plusbackup/tutorials/Setting up Plusbackup.md

Large diffs are not rendered by default.

Original file line number Diff line number Diff line change
Expand Up @@ -6,4 +6,6 @@ weight: 40
date: "2024-02-06"
---

Derzeit sind keine Probleme bekannt.
### Löschen per S3 User Portal eingeschränkt möglich

Das Löschen von Objekten und Buckets im S3 User Portal oder Tenant-Api ist ein durch den Hersteller niedrig priorisierter Hintergrundprozess. Dies kann dazu führen, dass die Operationen auch bei geringen Datenmengen eine lange Laufzeit aufweisen. Es empfiehlt sich das löschen per S3-Client API durchzuführen. Ein Beispiel können sie in den Tutorials finden (https://docs.plusserver.com/de/storage-backup/s3-storage/tutorials/)
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,7 @@ Beachten Sie bitte, dass diese Grenze nicht weiter erhöht werden kann.
- Object Lock Support
- Versionierung Support

### Bucket-Namen Features und Beschränkungen
## Bucket-Namen Features und Beschränkungen

- Ein Bucketname muss zwischen 3 (min) bis 63 (max) Zeichen lang sein. Der Suffix (-mirr / -repl) ist
davon abzuziehen
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,60 @@
---
title: "Löschen von S3 Objekten und Buckets mit s5cmd"
linkTitle: "Löschen von S3 Objekten und Buckets mit s5cmd"
type: "docs"
weight: 30
---



{{% alert title="Wichtig" color="warning" %}}
Voraussetzung für das Tutorial: die AWS Standard Credentials des Clients müssen hinterlegt sein (# vi .aws/credentials).

![Credentials]()
{{% /alert %}}

Bitte laden sie sich das aktuelle s5cmd release: https://github.com/peak/s5cmd/releases/latest

```
wget https://github.com/peak/s5cmd/releases/download/v2.2.2/s5cmd_2.2.2_Linux-64bit.tar.gz
tar -xvzf s5cmd_2.2.2_Linux-64bit.tar.gz
```


bash:
```
#!/bin/bash
AWS_PROFILE="root"
ENDPOINT_URL="https://s3.de-west-1.psmanaged.com"
# List of all buckets with s5cmd
buckets=$(s5cmd --profile $AWS_PROFILE --endpoint-url $ENDPOINT_URL ls | awk '{print $3}')
# Iterate over each bucket and delete all versions and then the bucket
for bucket in $buckets; do
echo "Clear and delete bucket: $bucket"
# Delete all versions in the bucket
s5cmd --profile $AWS_PROFILE --endpoint-url $ENDPOINT_URL rm --all-versions $bucket/*
# Delete the bucket
s5cmd --profile $AWS_PROFILE --endpoint-url $ENDPOINT_URL rb $bucket
done
echo "All buckets have been emptied and deleted."%
```
Powershell:
```
$ENDPOINT_URL="https://s3.de-west-1.psmanaged.com"
$CREDENTIALS_FILE=".\credentials"
$S3PROFILE="root"
$BUCKETS=(.\s5cmd.exe --credentials-file .\$CREDENTIALS_FILE --endpoint-url $ENDPOINT_URL --profile $S3PROFILE ls).split() | Select-String "s3://"
Write-Host "Existing Buckets: $BUCKETS"
foreach($BUCKET in $BUCKETS){
.\s5cmd.exe --credentials-file $CREDENTIALS_FILE --endpoint-url $ENDPOINT_URL --profile $S3PROFILE rm --all-versions $BUCKET/*
.\s5cmd.exe --credentials-file $CREDENTIALS_FILE --endpoint-url $ENDPOINT_URL --profile $S3PROFILE rb $BUCKET
Write-Host "deleted $BUCKET"
}
```
Original file line number Diff line number Diff line change
@@ -0,0 +1,98 @@
---
title: "User Guide - StorageGRID SSE / SSE-C"
linkTitle: "User Guide - StorageGRID SSE / SSE-C"
type: "docs"
weight: 30
description:
---
Diese Anleitung beschreibt, wie Sie sich als plusserver Kunde auf unserem StorageGRID SSE-C und SSE nutzen und testen können. SSE-C bedeutet dabei: Serverseitige Verschlüsselung mit dem von Ihnen bereitgestellten Schlüsseln (SSE-C).

SSE ermöglicht es Ihnen, ein Objekt zu speichern und es mit einem eindeutigen Schlüssel zu verschlüsseln, der von Ihnen zusammen mit dem Objekt bereitgestellt wird. Wenn das Objekt angefordert wird, muss derselbe Schlüssel angegeben werden, um das Objekt zu entschlüsseln und zurückzugeben.

{{% alert title="Hinweis zu SSE-C" %}}
Objekte welche mit SSE-C hochgeladen wurden, können nicht via Web Oberfläche heruntergeladen werden. Dies liegt daran, dass der Key dort nicht mitgegeben werden kann.
Daher wird dies mit einem 400er Fehler zurückgegeben. Die Datei kann über den S3-Client in Kombination mit dem Encryption Key allerdings abgerufen werden.
{{% /alert %}}

{{% alert title="Hinweis zu SSE-C" %}}
Metainformationen werden NIEMALS verschlüsselt. Dies liegt unter anderem daran, dass die Objektinformationen abrufbar sein müssen im Bezug auf verschlüsselung usw.
Dies lässt sich auch nicht ändern. Die Verschlüsselung der Datei ist hiervon unberührt. (Die Metainformationen können bspw. in Step 3 angeschaut werden.
{{% /alert %}}

## How to SSE-C

### Schritt 1: Erstelle einen Encryption Key

Beispiel:
```
openssl enc -aes-128-cbc -pass pass:secret -P
salt=E9DBB6603C7B3D2A
key=23832BAC16516152E560F933F261BF03
iv =71E87C0F6EC3C45921C2754BA131A315
```

### Schritt 2: Legen Sie ein Objekt mit dem generierten Schlüssel ab

Der Parameter ``--bucket`` ist der Bucket-Name, für den die PUT-Aktion ausgelöst wurde.


Parameter ``--key`` Objektschlüssel, für den die PUT-Aktion ausgelöst wurde.


Der Parameter ``--body`` steht für den Pfad zu einer Datei.

Beispiel:
```
aws s3api put-object --bucket <bucket> --key <file> --body "file" --sse-customer-algorithm AES256 --sse-customer-key
23832BAC16516152E560F933F261BF03 --endpoint-url https://s3.example.com --profile <profile>
```

### Schritt 3: Metadaten des Objektes anzeigen

Wenn der Customer Key nicht mitgeliefert wird, so kommt eine 404 Error Warnung zurück, statt des Objektes

```
aws s3api head-object --bucket <bucket> --key <file> --sse-customer-algorithm AES256 --sse-customer-key 23832BAC16516152E560F933F261BF03 --endpoint-url https://s3.example.com --profile <profile>
{
"AcceptRanges": "bytes",
"LastModified": "2022-05-02T19:20:02+00:00",
"ContentLength": 47,
"ETag": "\"f92ef20ab87e0e13951d9bee862e9f9a\"",
"ContentType": "binary/octet-stream",
"Metadata": {},
"SSECustomerAlgorithm": "AES256",
"SSECustomerKeyMD5": "rjGuMdjLpPV1eRuotNaPMQ=="
}
```
### Schritt 4: Objekt wieder herunterladen

Beispiel:
```
aws s3api get-object --bucket <bucket> --key <file> <file> --sse-customer-algorithm AES256 --sse-customer-key 23832BAC16516152E560F933F261BF03 --endpoint-url https://s3.example.com --profile <profile>
```

## How to SSE

Das gleiche gibt es natürlich auch ohne, das der Sie einen Key generieren müssen. StorageGrid kann diesen Key ebenfalls erzeugen und ihn nach korrekter Authentifizierung in sich selbst einspielen.
Hierfür ist folgende Anleitung.

### Schritt 1: Ein Objekt hochladen

Beispiel:
```
aws s3api put-object --bucket testbucket --key testfile --body "testfile" --server-side-encryption AES256 --endpoint-url https://de-2.s3.psmanaged.com --profile plusserver
```
### Schritt 2: Hiermit kann man sich die Metainformationen anzeigen lassen

Beispiel:
```
aws s3api head-object --bucket testbucket --key testfile --endpoint-url https://de-2.s3.psmanaged.com --profile plusserver
The following line should appear there:
"ServerSideEncryption": "AES256",
```
199 changes: 93 additions & 106 deletions content/en/storage-backup/plusbackup/tutorials/Setting up Plusbackup.md

Large diffs are not rendered by default.

Loading

0 comments on commit 84a4bf0

Please sign in to comment.