ECS: Konfigurieren und Testen von s3cmd mit ECS
Summary: In diesem Wissensdatenbank-Artikel wird erläutert, wie Sie s3cmd-Tools mit ECS konfigurieren.
Instructions
Installation und Konfiguration
1. Laden Sie das s3cmd-Tool aus dem Abschnitt "Weitere Informationen" herunter.
2. Extrahieren und installieren Sie das s3cmd-Tool:
Befehle:
# sudo tar xzf s3cmd-2.4.0.tar.gz # sudo python setup.py install
3. Führen Sie die s3cmd-Konfiguration aus:
Befehl:
# s3cmd --configured
Beispiel:
Enter new values or accept defaults in brackets with Enter. Refer to user manual for detailed description of all options. Access key and Secret key are your identifiers for Amazon S3. Leave them empty for using the env variables. Access Key [XXXX]: objectuser for that bucket Secret Key [XXX]: secret key Default Region [US]: Use "s3.amazonaws.com" for S3 Endpoint and not modify it to the target Amazon S3. S3 Endpoint [XXXXX]: XX,XX.XX.XXX:9020 Use "%(bucket)s.s3.amazonaws.com" to the target Amazon S3. "%(bucket)s" and "%(location)s" vars can be used if the target S3 system supports dns based buckets. DNS-style bucket+hostname:port template for accessing a bucket [%(bucket)s.s3.amazonaws.com]: Encryption password is used to protect your files from reading by unauthorized persons while in transfer to S3 Encryption password: Path to GPG program [/usr/bin/gpg]: When using secure HTTPS protocol all communication with Amazon S3 servers is protected from 3rd party eavesdropping. This method is slower than plain HTTP, and can only be proxied with Python 2.7 or newer Use HTTPS protocol [Yes]: No On some networks all internet access must go through a HTTP proxy. Try setting it here if you can't connect to S3 directly HTTP Proxy server name: New settings: Access Key:XXXXX Secret Key: XXXXXXXXX Default Region: US S3 Endpoint: XX.XX.XX.XXX:9020 DNS-style bucket+hostname:port template for accessing a bucket: %(bucket)s.s3.amazonaws.com Encryption password: Path to GPG program: /usr/bin/gpg Use HTTPS protocol: False HTTP Proxy server name: HTTP Proxy server port: 0 Test access with supplied credentials? [Y/n] Please wait, attempting to list all buckets... Success. Your access key and secret key worked fine :-) Now verifying that encryption works... Not configured. Never mind. Save settings? [y/N] y Configuration saved to '/home/admin/.s3cfg'
4. Führen Sie s3cmd aus, um alle Buckets aufzulisten:
Befehl:
# s3cmd ls
Beispiel:
admin@ecsnode:~/mrx> s3cmd ls 2024-06-05 06:54 s3://bucket 2024-05-01 15:46 s3://s3cmd_bucket 2024-05-09 11:56 s3://s3cmd_bucket1 2024-05-08 09:18 s3://winscp
5. Listen Sie den Inhalt des Buckets auf (er ist jetzt leer, nachdem er konfiguriert wurde):
Befehl:
admin@ecsnode:~/mrx> s3cmd ls s3://s3cmd_bucket admin@ecsnode:~/mrx>
6. Erstellen Sie eine Datei und laden Sie sie in den Bucket hoch:
Befehl:
# touch addressbook.xml
Beispiel:
admin@ecsnode:~/mrx> s3cmd put addressbook.xml s3://s3cmd_bucket upload: 'addressbook.xml' -> 's3://s3cmd_bucket/addressbook.xml' [1 of 1] 0 of 0 0% in 0s 0.00 B/s done
7. Listen Sie die Inhalte des Buckets auf:
Befehl:
# s3cmd ls s3://s3cmd_bucket
Beispiel:
admin@ecsnode:~/mrx> s3cmd ls s3://s3cmd_bucket 2024-07-03 11:36 0 s3://s3cmd_bucket/addressbook.xml admin@ecsnode8:~/mrx>
8. Lesen Sie die Datei aus dem Bucket:
Befehl:
# s3cmd get s3://s3cmd_bucket/addressbook.xml
admin@ecsnode:~/mrx> s3cmd get s3://s3cmd_bucket/addressbook.xml download: 's3://s3cmd_bucket/addressbook.xml' -> './addressbook.xml' [1 of 1] 0 of 0 0% in 0s 0.00 B/s done
Schreibleistungstest mithilfe von PUT.
1. Erstellen Sie eine Datei:
Befehl:
# sudo fallocate -l 10G random10GB.bin
2. Verwenden Sie den Befehl "time", der die Dauer des Schreibens von Datei random10BG.bin in die s3cmd_bucket überwacht:
Befehl:
# time ./s3cmd put <file> s3://<bucket>
Beispiel:
admin@ecsnode:~> # time ./s3cmd put random10GB.bin s3://s3cmd_bucket outputs: upload: 'random10GB.bin' -> 's3://s3cmd_bucket/random10GB.bin' [part 683 of 683, 10MB] [1 of 1] 10485760 of 10485760 100% in 0s 57.68 MB/s done real 3m8.872s user 1m29.483s sys 0m19.052s
So berechnen Sie die Antwortzeit bei Schreibvorgängen:
- 3 Minuten 8 Sekunden = 188 Sekunden
- 10240 MB / 188 = 54 MB/s (Megabyte pro Sekunde) ist die Upload-Geschwindigkeit.
Leseleistungstest mithilfe von GET.
Verwenden Sie den Befehl "time", der die Dauer des Lesevorgangs überwacht:
Befehl:
# s3time s3cmd get s3://<bucket/>/<file>
Beispiel:
admin@ecsnode:~> s3time s3cmd get s3://s3cmd_bucket/random10GB.bin If 's3time' is not a typo you can use command-not-found to lookup the package that contains it, like this: cnf s3time admin@ecsnode8:~> time s3cmd get s3://s3cmd_bucket/random10GB.bin download: 's3://s3cmd_bucket/random10GB.bin' -> './random10GB.bin' [1 of 1] 10737418240 of 10737418240 100% in 38s 263.31 MB/s done real 0m39.172s user 0m23.688s sys 0m12.637s
So berechnen Sie die Leseantwortzeit:
- 39 Sekunden
- 10240 MB / 39 = 262,6 MB/s (Megabyte pro Sekunde) ist die Download-Geschwindigkeit.
Additional Information
Laden Sie das s3cmd-Tool unten herunter:
https://s3tools.org/downloadTestreferenz:
https://geekmungus.co.uk/?p=4018