OpenStack Xena : How to use Swift2021/11/24 |
This section shows how to use Swift Storage from Clients.
This example is based on the emvironment like follows.
------------+--------------------------+-------------+----- | | | eth0|10.0.0.30 eth0|10.0.0.50 | +-----------+-----------+ +-----------+-----------+ | | [ Control Node ] | | [ Proxy Node ] | | | | | | | | MariaDB RabbitMQ | | Swift Proxy | | | Memcached httpd | | | | | Keystone | | | | +-----------------------+ +-----------------------+ | | ------------+--------------------------+-------------+------------+------------ eth0|10.0.0.71 eth0|10.0.0.72 eth0|10.0.0.73 +-----------+-----------+ +-----------+-----------+ +-----------+-----------+ | [ 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 posibble 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 | 7557d2a0f80547a88e8089662dc87a3b | | 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 | 65c5d71cf65e49fc85f66146a79759e9 | | name | SwiftOperator | | options | {} | +-------------+----------------------------------+ # add a user [root@dlp ~(keystone)]# openstack user create --domain default --project swiftservice --password userpassword swiftuser01 +---------------------+----------------------------------+ | Field | Value | +---------------------+----------------------------------+ | default_project_id | 7557d2a0f80547a88e8089662dc87a3b | | domain_id | default | | enabled | True | | id | 1c8e386019a04736940be1c37f914c58 | | name | swiftuser01 | | options | {} | | 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. |
[root@client ~]# dnf --enablerepo=centos-openstack-xena,powertools,epel -y install python3-openstackclient python3-keystoneclient python3-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_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=http://10.0.0.30:5000/v3 export OS_IDENTITY_API_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
# show status [root@client ~(swift)]# swift stat Account: AUTH_7557d2a0f80547a88e8089662dc87a3b Containers: 0 Objects: 0 Bytes: 0 Content-Type: text/plain; charset=utf-8 X-Timestamp: 1637737423.45288 X-Put-Timestamp: 1637737423.45288 Vary: Accept X-Trans-Id: tx5cdd7ef5753c4ab18af0c-00619de3cf X-Openstack-Request-Id: tx5cdd7ef5753c4ab18af0c-00619de3cf |
[4] | Create a Container for saving files. |
[root@client ~(swift)]# openstack container create test-container +---------------------------------------+----------------+------------------------------------+ | account | container | x-trans-id | +---------------------------------------+----------------+------------------------------------+ | AUTH_7557d2a0f80547a88e8089662dc87a3b | test-container | tx77aebe9969514f03bb790-00619de3e4 | +---------------------------------------+----------------+------------------------------------+[root@client ~(swift)]# openstack container list +----------------+ | Name | +----------------+ | test-container | +----------------+ |
[5] | Upload a file on localhost to the Container. |
[root@client ~(swift)]# openstack object create test-container testfile.txt +--------------+----------------+----------------------------------+ | object | container | etag | +--------------+----------------+----------------------------------+ | testfile.txt | test-container | ac7013267693572108448338a12d0246 | +--------------+----------------+----------------------------------+[root@client ~(swift)]# openstack object list test-container +--------------+ | Name | +--------------+ | testfile.txt | +--------------+ |
[6] | Download a file from Swift Storage to localhost. |
[root@client ~(swift)]#
[root@client ~(swift)]# rm testfile.txt
openstack object save test-container testfile.txt [root@client ~(swift)]# total 12 -rw-------. 1 root root 1349 Feb 24 2021 anaconda-ks.cfg -rw-------. 1 root root 283 Nov 24 16:03 keystonerc_swift -rw-r--r--. 1 root root 1349 Nov 24 16:05 testfile.txt |
[7] | Delete a file on Swift Storage. |
[root@client ~(swift)]# openstack object delete test-container testfile.txt [root@client ~(swift)]# openstack object list test-container # [testfile.txt] has been removed |
[8] | Delete a Container on Swift Storage. |
[root@client ~(swift)]# openstack container delete test-container [root@client ~(swift)]# openstack container list # [test-container] has been removed
|
Sponsored Link |