CentOS Stream 9
Sponsored Link

OpenStack Dalmatian : How to use Swift2024/10/15

 

This section shows how to use Swift Storage from Clients.

This example is based on the environment like follows.

------------+--------------------------+------------
            |                          |
        eth0|10.0.0.30             eth0|10.0.0.50
+-----------+-----------+  +-----------+-----------+
|   [ dlp.srv.world ]   |  | [ network.srv.world ] |
|     (Control Node)    |  |      (Proxy Node)     |
|                       |  |                       |
|  MariaDB    RabbitMQ  |  |      Swift Proxy      |
|  Memcached  Nginx     |  |         Nginx         |
|  Keystone   httpd     |  |                       |
+-----------------------+  +-----------------------+

------------+--------------------------+--------------------------+-----------
        eth0|10.0.0.71             eth0|10.0.0.72             eth0|10.0.0.73
+-----------+-----------+  +-----------+-----------+  +-----------+-----------+
|  [snode01.srv.world]  |  |  [snode02.srv.world]  |  |  [snode03.srv.world]  |
|    (Storage Node#1)   |  |    (Storage Node#2)   |  |    (Storage Node#3)   |
|                       |  |                       |  |                       |
|     Swift-Account     |  |     Swift-Account     |  |     Swift-Account     |
|    Swift-Container    |  |    Swift-Container    |  |    Swift-Container    |
|     Swift-Object      |  |     Swift-Object      |  |     Swift-Object      |
+-----------------------+  +-----------------------+  +-----------------------+

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

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

+-------------+----------------------------------+
| Field       | Value                            |
+-------------+----------------------------------+
| description | Swift Service Project            |
| domain_id   | default                          |
| enabled     | True                             |
| id          | f3c20782c3fb45009f2e850026306db5 |
| is_domain   | False                            |
| name        | swiftservice                     |
| options     | {}                               |
| parent_id   | default                          |
| tags        | []                               |
+-------------+----------------------------------+

# create [swiftoperator] role

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

+-------------+----------------------------------+
| Field       | Value                            |
+-------------+----------------------------------+
| description | None                             |
| domain_id   | None                             |
| id          | 1e0f8417785344c5b407963dfa2a1651 |
| name        | swiftoperator                    |
| options     | {}                               |
+-------------+----------------------------------+

# add a user

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

+---------------------+----------------------------------+
| Field               | Value                            |
+---------------------+----------------------------------+
| default_project_id  | f3c20782c3fb45009f2e850026306db5 |
| domain_id           | default                          |
| email               | None                             |
| enabled             | True                             |
| id                  | c7bdde18ca9c47f69c5290cabb5274c0 |
| name                | swiftuser01                      |
| description         | None                             |
| password_expires_at | None                             |
+---------------------+----------------------------------+

# add the user to [swiftoperator] role

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

[root@client ~]#
dnf --enablerepo=centos-openstack-dalmatian,epel,crb -y install python3-openstackclient python3-keystoneclient python3-swiftclient
[3] Login as any user and load environment variables. ( it's just the value for a user added in [1] )
[cent@client ~]$
vi ~/keystonerc_swift
export OS_PROJECT_DOMAIN_NAME=Default
export OS_USER_DOMAIN_NAME=Default
export OS_PROJECT_NAME=swiftservice
export OS_USERNAME=swiftuser01
export OS_PASSWORD=userpassword
export OS_AUTH_URL=https://dlp.srv.world:5000
export OS_IDENTITY_API_VERSION=3
export PS1='[\u@\h \W(swift)]\$ '
[cent@client ~]$
chmod 600 ~/keystonerc_swift

[cent@client ~]$
source ~/keystonerc_swift

[cent@client ~(swift)]$
echo "source ~/keystonerc_swift " >> ~/.bash_profile
# show status

[cent@client ~(swift)]$
swift stat

               Account: AUTH_f3c20782c3fb45009f2e850026306db5
            Containers: 0
               Objects: 0
                 Bytes: 0
          Content-Type: text/plain; charset=utf-8
           X-Timestamp: 1728953209.36238
       X-Put-Timestamp: 1728953209.36238
                  Vary: Accept
            X-Trans-Id: tx5c18a5b995484fd9b2345-00670dbb79
X-Openstack-Request-Id: tx5c18a5b995484fd9b2345-00670dbb79
[4] Create a Container for saving files.
[cent@client ~(swift)]$
openstack container create test-container

+---------------------------------------+----------------+------------------------------------+
| account                               | container      | x-trans-id                         |
+---------------------------------------+----------------+------------------------------------+
| AUTH_f3c20782c3fb45009f2e850026306db5 | test-container | txc3bf6257ddf34162997a0-00670dbb8f |
+---------------------------------------+----------------+------------------------------------+

[cent@client ~(swift)]$
openstack container list

+----------------+
| Name           |
+----------------+
| test-container |
+----------------+
[5] Upload a file on localhost to the Container.
[cent@client ~(swift)]$
echo testfile > testfile.txt

[cent@client ~(swift)]$
openstack object create test-container testfile.txt

+--------------+----------------+----------------------------------+
| object       | container      | etag                             |
+--------------+----------------+----------------------------------+
| testfile.txt | test-container | e9409172a4036cc688f169c72131e921 |
+--------------+----------------+----------------------------------+

[cent@client ~(swift)]$
openstack object list test-container

+--------------+
| Name         |
+--------------+
| testfile.txt |
+--------------+
[6] Download a file from Swift Storage to localhost.
[cent@client ~(swift)]$
rm testfile.txt
[cent@client ~(swift)]$
openstack object save test-container testfile.txt

[cent@client ~(swift)]$
total 8
-rw-------. 1 cent cent 285 Oct 15 09:46 keystonerc_swift
-rw-r--r--. 1 cent cent   9 Oct 15 09:48 testfile.txt
[7] Delete a file on Swift Storage.
[cent@client ~(swift)]$
openstack object delete test-container testfile.txt

[cent@client ~(swift)]$
openstack object list test-container

# [testfile.txt] has been removed

[8] Delete a Container on Swift Storage.
[cent@client ~(swift)]$
openstack container delete test-container

[cent@client ~(swift)]$
openstack container list

# [test-container] has been removed
Matched Content