CentOS 7
Sponsored Link

OpenStack Liberty : How to use Swift2015/11/18

 
This section shows how to use Swift Storage from Clients.
This section shows how to use Swift Storage from Clients.
This example shows to configure like the environment below.
                                    |
     +------------------+           |           +-----------------+
     | [ Control Node ] |10.0.0.30  |  10.0.0.50|  [ Proxy Node ] |
     |     Keystone     |-----------+-----------|                 |
     +------------------+           |           +-----------------+          +----------------+
                                    |                               10.0.0.20|  [ ClientPC ]  |
        +---------------------------+--------------------------+-------------|                |
        |                           |                          |             +----------------+
        |10.0.0.71                  |10.0.0.72                 |10.0.0.73 
+-------+----------+       +--------+---------+       +--------+---------+
| [Storage Node#1] |       | [Storage Node#2] |       | [Storage Node#3] |
|                  |-------|                  |-------|                  |
+------------------+       +------------------+       +------------------+

[1] Add a user for using Swift on Keystone Control Node.
By the way, if you'd like to use Swift Quickly, it's unnecessarry to add a new user, it's posibble to use with existing admin or swift user on Keystone.
# add swiftservice project

[root@dlp ~(keystone)]#
openstack project create --description "Swift Service Project" swiftservice

+-------------+----------------------------------+
| Field       | Value                            |
+-------------+----------------------------------+
| description | Swift Service Project            |
| domain_id   | default                          |
| enabled     | True                             |
| id          | 420ffd46dd764eadb46bdb1509f17b49 |
| is_domain   | False                            |
| name        | swiftservice                     |
| parent_id   | None                             |
+-------------+----------------------------------+

# add swiftoperator role

[root@dlp ~(keystone)]#
openstack role create swiftoperator

+-------+----------------------------------+
| Field | Value                            |
+-------+----------------------------------+
| id    | 0851fa7ca9514fa7aa5ff96dd33a9261 |
| name  | swiftoperator                    |
+-------+----------------------------------+

# add a user

[root@dlp ~(keystone)]#
openstack user create --domain default --project swiftservice --password userpassword user01

+--------------------+----------------------------------+
| Field              | Value                            |
+--------------------+----------------------------------+
| default_project_id | 420ffd46dd764eadb46bdb1509f17b49 |
| domain_id          | default                          |
| enabled            | True                             |
| id                 | ed9c121f195544809bce0f51a65d2447 |
| name               | user01                           |
+--------------------+----------------------------------+

# add the user in swiftoperator role

[root@dlp ~(keystone)]#
openstack role add --project swiftservice --user user01 swiftoperator
[2] Work on a Client from here and later.
Install Keystoneclient, Swiftclient on a Client first.
# install from Liberty, EPEL

[root@client ~]#
yum --enablerepo=centos-openstack-liberty,epel -y install python-keystoneclient python-swiftclient
[3] Load environment variables first. ( it's just the value for a user added in [1] )
[root@client ~]#
vi ~/keystonerc_swift
export OS_PROJECT_DOMAIN_ID=default
export OS_USER_DOMAIN_ID=default
export OS_PROJECT_NAME=swiftservice
export OS_TENANT_NAME=swiftservice
export OS_USERNAME=user01
export OS_PASSWORD=userpassword
export OS_AUTH_URL=http://10.0.0.30:35357/v3
export OS_IDENTITY_API_VERSION=3
export OS_AUTH_VERSION=3
export PS1='[\u@\h \W(swift)]\$ '
[root@client ~]#
chmod 600 ~/keystonerc_swift

[root@client ~]#
source ~/keystonerc_swift

[root@client ~(swift)]#
echo "source ~/keystonerc_swift " >> ~/.bash_profile
# display status (it's not need to care the Warning below)

[root@client ~(swift)]#
swift stat

/usr/lib/python2.7/site-packages/keystoneclient/service_catalog.py:196: UserWarning: 
Providing attr without filter_value to get_urls() is deprecated as of the 1.7.0 release 
and may be removed in the 2.0.0 release. Either both should be provided or neither should be provided.
  'Providing attr without filter_value to get_urls() is '

        Account: AUTH_420ffd46dd764eadb46bdb1509f17b49
     Containers: 0
        Objects: 0
          Bytes: 0
X-Put-Timestamp: 1447855359.56587
    X-Timestamp: 1447855359.56587
     X-Trans-Id: tx84e1138929b540049828b-00564c84ff
   Content-Type: text/plain; charset=utf-8
[4] Create a Container for saving files.
By the way, the same Warings are displayed every time on swift command, if you feel troublesome, add " 2>/dev/null" to the tail of every command to redirect.
[root@client ~(swift)]#
swift post test_container

[root@client ~(swift)]#
swift list

test_container    
# just created

[5] Upload a file on local to the Container.
# upload test.txt

[root@client ~(swift)]#
swift upload test_container test.txt

test.txt
[root@client ~(swift)]#
swift list test_container

test.txt    
# just uploaded

[6] Download a file from Swift Storage to local.
# remove a file on local

[root@client ~(swift)]#
rm test.txt
[root@client ~(swift)]#
swift download test_container test.txt

test.txt [auth 0.243s, headers 0.497s, total 0.497s, 0.000 MB/s]
[root@client ~(swift)]#
total 12
-rw-------. 1 root root 985 Jan  8  2015 anaconda-ks.cfg
-rw-------  1 root root 335 Nov 18 23:03 keystonerc_swift
-rw-r--r--  1 root root  10 Nov 18 23:05 test.txt
[7] Delete a file on Swift Storage.
[root@client ~(swift)]#
swift delete test_container test.txt

test.txt
[root@client ~(swift)]#
swift list test_container

test2.txt    
# test.txt is just deleted

[8] Delete a Container on Swift Storage.
[root@client ~(swift)]#
swift delete test_container

[root@client ~(swift)]#
swift list

# just deleted
Matched Content