Object Storage command-line clientThe swift client is the command-line interface
(CLI) for the OpenStack Object Storage API and its extensions. This chapter documents
swift version 2.0.3.
For help on a specific swift
command, enter:
$swiftCOMMANDswift usage [--debug] [--info] [--quiet] [--auth <auth_url>]
[--auth-version <auth_version>] [--user <username>]
[--key <api_key>] [--retries <num_retries>]
[--os-username <auth-user-name>] [--os-password <auth-password>]
[--os-tenant-id <auth-tenant-id>]
[--os-tenant-name <auth-tenant-name>]
[--os-auth-url <auth-url>] [--os-auth-token <auth-token>]
[--os-storage-url <storage-url>] [--os-region-name <region-name>]
[--os-service-type <service-type>]
[--os-endpoint-type <endpoint-type>]
[--os-cacert <ca-certificate>] [--insecure]
[--no-ssl-compression]
<subcommand> ...Subcommandsdelete
Delete a container or objects within a container
download
Download objects from containers
list
Lists the containers for the account or the objects
for a container
post
Updates meta information for the account, container,
or object; creates containers if not present
stat
Displays information for the account, container,
or object
upload
Uploads files or directories to the given container
capabilities
List cluster capabilities
swift examples swift -A https://auth.api.rackspacecloud.com/v1.0 -U user -K api_key stat -v
swift --os-auth-url https://api.example.com/v2.0 --os-tenant-name tenant \
--os-username user --os-password password list
swift --os-auth-token 6ee5eb33efad4e45ab46806eac010566 \
--os-storage-url https://10.1.5.2:8080/v1/AUTH_ced809b6a4baea7aeab61a \
list
swift list --lhswift optional arguments--version
show program's version number and exit
-h, --help
show this help message and exit
-s, --snet
Use SERVICENET internal network
-v, --verbose
Print more info
--debug
Show the curl commands and results of all http queries
regardless of result status.
--info
Show the curl commands and results of all http
queries which return an error.
-q, --quiet
Suppress status output
-A AUTH, --auth=AUTH URL
for obtaining an auth token
-V AUTH_VERSION, --auth-version=AUTH_VERSION
Specify a version for authentication. Defaults to 1.0.
-U USER, --user=USER
User name for obtaining an auth token.
-K KEY, --key=KEY
Key for obtaining an auth token.
-R RETRIES, --retries=RETRIES
The number of times to retry a failed connection.
--os-username=<auth-user-name>
OpenStack username. Defaults to env[OS_USERNAME].
--os-password=<auth-password>
OpenStack password. Defaults to env[OS_PASSWORD].
--os-tenant-id=<auth-tenant-id>
OpenStack tenant ID. Defaults to env[OS_TENANT_ID]--os-tenant-name=<auth-tenant-name>
OpenStack tenant name. Defaults to
env[OS_TENANT_NAME].
--os-auth-url=<auth-url>
OpenStack auth URL. Defaults to env[OS_AUTH_URL].
--os-auth-token=<auth-token>
OpenStack token. Defaults to env[OS_AUTH_TOKEN]. Used
with --os-storage-url to bypass the usual
username/password authentication.
--os-storage-url=<storage-url>
OpenStack storage URL. Defaults to
env[OS_STORAGE_URL]. Overrides the storage url
returned during auth. Will bypass authentication when
used with --os-auth-token.
--os-region-name=<region-name>
OpenStack region name. Defaults to env[OS_REGION_NAME]--os-service-type=<service-type>
OpenStack Service type. Defaults to
env[OS_SERVICE_TYPE]--os-endpoint-type=<endpoint-type>
OpenStack Endpoint type. Defaults to
env[OS_ENDPOINT_TYPE]--os-cacert=<ca-certificate>
Specify a CA bundle file to use in verifying a TLS
(https) server certificate. Defaults to env[OS_CACERT]--insecure
Allow swiftclient to access servers without having to
verify the SSL certificate. Defaults to
env[SWIFTCLIENT_INSECURE] (set to 'true' to enable).
--no-ssl-compression
This option is deprecated and not used anymore. SSL
compression should be disabled by default by the
system SSL library
swift delete commandUsage: swift delete
Delete a container or objects within a container
Positional arguments<container>
Name of container to delete from
[object]
Name of object to delete. Specify multiple times
for multiple objects
Optional arguments--all
Delete all containers and objects
--leave-segments
Do not delete segments of manifest objects
--object-threads <threads>
Number of threads to use for deleting objects.
Default is 10
--container-threads <threads>
Number of threads to use for deleting containers.
Default is 10
swift download commandUsage: swift download
Download objects from containers
Positional arguments<container>
Name of container to download from. To download a
whole account, omit this and specify --all.
[object]
Name of object to download. Specify multiple times
for multiple objects. Omit this to download all
objects from the container.
Optional arguments--all
Indicates that you really want to download
everything in the account
--marker
Marker to use when starting a container or account
download
--prefix <prefix>
Only download items beginning with <prefix>
--output <out_file>
For a single file download, stream the output to
<out_file>. Specifying "-" as <out_file> will
redirect to stdout
--object-threads <threads>
Number of threads to use for downloading objects.
Default is 10
--container-threads <threads>
Number of threads to use for downloading containers.
Default is 10
--no-download
Perform download(s), but don't actually write anything
to disk
--header <header_name:header_value>
Adds a customized request header to the query, like
"Range" or "If-Match". This argument is repeatable.
Example --header "content-type:text/plain"
--skip-identical
Skip downloading files that are identical on both sides
swift list commandUsage: swift list
Lists the containers for the account or the objects for a container
Positional arguments[container]
Name of container to list object in
Optional arguments--long
Long listing format, similar to ls -l
--lh
Report sizes in human readable format similar to ls -lh
--totals
Used with -l or --lh, only report totals
--prefix
Only list items beginning with the prefix
--delimiter
Roll up items with the given delimiter. For containers
only. See OpenStack Swift API documentation for what
this means.
swift post commandUsage: swift post
Updates meta information for the account, container, or object.
If the container is not found, it will be created automatically.
Positional arguments[container]
Name of container to post to
[object]
Name of object to post. Specify multiple times
for multiple objects
Optional arguments--read-acl <acl>
Read ACL for containers. Quick summary of ACL syntax:
.r:*, .r:-.example.com, .r:www.example.com, account1,
account2:user2
--write-acl <acl>
Write ACL for containers. Quick summary of ACL syntax:
account1 account2:user2
--sync-to <sync-to>
Sync To for containers, for multi-cluster replication
--sync-key <sync-key>
Sync Key for containers, for multi-cluster replication
--meta <name:value>
Sets a meta data item. This option may be repeated.
Example: -m Color:Blue -m Size:Large
--header <header>
Set request headers. This option may be repeated.
Example -H "content-type:text/plain"
swift stat commandUsage: swift stat
Displays information for the account, container, or object
Positional arguments[container]
Name of container to stat from
[object]
Name of object to stat. Specify multiple times
for multiple objects
Optional arguments--lh
Report sizes in human readable format similar to ls -lh
swift upload commandUsage: swift upload
Uploads specified files and directories to the given container
Positional arguments<container>
Name of container to upload to
<file_or_directory>
Name of file or directory to upload. Specify multiple
times for multiple uploads
Optional arguments--changed
Only upload files that have changed since the last
upload
--skip-identical
Skip uploading files that are identical on both sides
--segment-size <size>
Upload files in segments no larger than <size> and
then create a "manifest" file that will download all
the segments as if it were the original file
--segment-container <container>
Upload the segments into the specified container. If
not specified, the segments will be uploaded to a
<container>_segments container so as to not pollute the
main <container> listings.
--leave-segments
Indicates that you want the older segments of manifest
objects left alone (in the case of overwrites)
--object-threads <threads>
Number of threads to use for uploading full objects.
Default is 10.
--segment-threads <threads>
Number of threads to use for uploading object segments.
Default is 10.
--header <header>
Set request headers with the syntax header:value.
This option may be repeated.
Example -H "content-type:text/plain".
--use-slo
When used in conjunction with --segment-size will
create a Static Large Object instead of the default
Dynamic Large Object.
--object-name <object-name>
Upload file and name object to <object-name> or upload
dir and use <object-name> as object prefix instead of
folder name