Swift
Siehe auch
Swift ist ein verteilter Objekt-/Blob-Speicher. Das OpenStack Object Store-Projekt, bekannt als Swift, bietet eine Cloud-Speicher-Software, mit der grosse Datenmengen über eine einfache API gespeichert und abgerufen werden können. Swift ist auf Skalierbarkeit ausgelegt und auf Zuverlässigkeit, Verfügbarkeit und konkurrierende Zugriffe hin optimiert.
Tipp
Wer Infomaniak Swiss Backup mit Swift Storage und Cyberduck auf Mac oder Windows verwendet, muss die URL https://swift02-api.cloud.infomaniak.ch und diese „Project:Domain:Username“-Struktur verwenden: sb_project_SBI-AB123456:Default:SBI-AB123456
Installation
sudo dnf -y install python3-devel
pip3 install --user python-swiftclient
pip3 install --user python-keystoneclient
Verwendung
In den Beispielen wird der Infomaniak Swift Object-Storage verwendet.
Tipp
Der Umgang mit swift
wird bedeutend einfacher, wenn man vorher eine OpenStack.rc-Datei „sourced“, um sich damit die (nachfolgend gezeigten) tausend Parameter zu sparen. Ein Beispiel für solch eine rc-Datei findet sich weiter unten.
source path/to/openstack.rc
swift list --lh
Verzeichnis-Listing anzeigen (ohne .rc-File):
swift \
--os-auth-url=https://swiss-backup02.infomaniak.com/identity/v3 \
--os-username=SBI-AB123456 \
--os-password='mypassword' \
--auth-version=3 \
--os-tenant-name=sb_project_SBI-AB123456 \
--os-user-domain-name=default \
list --lh
Beispiel-Ausgabe mit Bedeutung:
count bytes modify-timestamp bucket-name
110 568M 2022-12-16 23:54:04 host.example.com
...
9.5K 37G
Swift-Container löschen:
swift \
--os-auth-url=https://swiss-backup02.infomaniak.com/identity/v3 \
--os-username=SBI-AB123456 \
--os-password='mypassword' \
--auth-version=3 \
--os-tenant-name=sb_project_SBI-AB123456 \
--os-user-domain-name=default \
delete \
mybucket
Quota für einen Container einrichten:
source path/to/openstack.rc
swift stat mybucket
# 5GB for example
swift post --meta 'quota-bytes: 5000000000' mybucket
swift stat mybucket
Quota für einen Container entfernen:
source path/to/openstack.rc
swift stat mybucket
swift post --meta 'quota-bytes: ' mybucket
swift stat mybucket
OpenStack.rc-Datei
export OS_AUTH_URL=https://api.pub1.infomaniak.cloud/identity/v3
export OS_PROJECT_NAME=PCP-ABCDEF1
export OS_PROJECT_DOMAIN_NAME=default
export OS_USERNAME=PCU-ABCDEF1
export OS_USER_DOMAIN_NAME=default
export OS_PROJECT_ID=07f32f66709d4de6aca23bad819ced3d
export OS_IDENTITY_API_VERSION=3
export OS_INTERFACE=public
export OS_REGION_NAME=dc3-a
# To avoid being prompted for your password each time,
# write your password below and uncomment the line
OS_PASSWORD='linuxfabrik'
[ -z "$OS_PASSWORD" ] && read -e -p "Please enter your OpenStack Password for project $OS_PROJECT_NAME as user $OS_USERNAME: " OS_PASSWORD
export OS_PASSWORD
Swift Cheat Sheet
# List containers/objects
swift list
swift list container_name
# Create a container with the default storage policy
swift post mybucket
# Set access list
swift post --read-acl 'project:*' test
swift post --write-acl 'project:linus' test
# Upload
swift upload mybucket ~/myfile.txt --object-name myobject
# Stats
swift stat mybucket
# Enable versioning
swift post --header "X-Versions-Enabled: true" mybucket
# List all versions of objects in mybucket
swift list --versions mybucket
# List all versions of objects in mybucket in JSON for later processing
swift list --json --versions mybucket > /tmp/all-objects.json
# Download
swift download mybucket myobject
# Download a specific version of an object in mybucket
# VERSION_ID is in the form of a timestamp in Unix epoch format
VERSION_ID=1681378321.87282
swift download --version-id $VERSION_ID mybucket myobject
# Limit listing operation using the prefix of object names
swift list --prefix 'tux.jpg' mybucket
# Limit delete operation using the prefix of object names
swift delete --prefix 'tux.jpg' mybucket
Umgang mit Object Versioning
Swift bietet die Option mehrere Versionen einer Datei zu behalten. Damit wird bei jeder Änderung der Datei eine Kopie erstellt, die als versteckte Datei im Object Store landet.
Um effizienter arbeiten zu können, zuerst alle Metadaten als JSON-File herunterladen, und dann Queries dagegen laufenzulassen:
swift list --json --versions mybucket > /tmp/all-objects.json
# list all "current" objects
jq '.[]|select(.is_latest == true )' /tmp/all-objects.json
# select all objects with name "urn:oid:10006490"
jq '.[]|select(.name == "urn:oid:10006490" )' /tmp/all-objects.json
Eine komplizierte Abfrage mit Argumenten:
# select the last object with name `objectName` since `restorePIT`
NAME=tux.jpg
jq \
--arg restorePIT $(date -d "2023-07-07T11:28:52" +%s) \
--arg objectName $NAME '[.[]|select((.name == $objectName ) and ((.version_id)|tonumber <= $restorePIT))]|max_by(.version_id|tonumber)' \
/tmp/all-objects.json
Erklärung des JQ-Statements '[.[]|select((.name == $objectName ) and ((.version_id)|tonumber <= $restorePIT))]|max_by(.version_id|tonumber)'
:
'
opening quote forjq
filter[
: pack the resulting object of filter in an array (is needed becausemax_by
function needs an array as input).[]
: list all objects from the input array (contents of/tmp/all-objects.json
)|select((.name == $objectName ) and ((.version_id)|tonumber <= $restorePIT))
:select all the objects where
.name
==objectName
(--arg objectName
)and
of which the
.version_id
converted to a number is smaller or equal torestorePIT
(--arg restorePIT
)
]
: closing bracket of the array (is needed becausemax_by
function needs an array as input)|max_by(.version_id|tonumber)
: select the object of which the.version_id
converted to a number is the highest of the input array of objects'
: closing quote forjq
filter
Built on 2025-01-06