CentOS Stream 8
Sponsored Link

OpenStack Xena : Swift 利用方法2021/11/24

 
OpenStack Object Storage(Swift)の利用方法です。
当例では以下のような環境を例に Swift サービスを設定します。
------------+--------------------------+-------------+-----
            |                          |             |
        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] Control ノードの Keystone に Swift を利用できるユーザーを登録します。
新規にユーザーを作成せずとも既存の admin ユーザーや swift ユーザーでも操作は可能です。
# [swiftservice] プロジェクト作成

[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        | []                               |
+-------------+----------------------------------+

# [SwiftOperator] ロール作成

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

+-------------+----------------------------------+
| Field       | Value                            |
+-------------+----------------------------------+
| description | None                             |
| domain_id   | None                             |
| id          | 65c5d71cf65e49fc85f66146a79759e9 |
| name        | SwiftOperator                    |
| options     | {}                               |
+-------------+----------------------------------+

# ユーザー作成

[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                             |
+---------------------+----------------------------------+

# ユーザーを [SwiftOperator] に加える

[root@dlp ~(keystone)]#
openstack role add --project swiftservice --user swiftuser01 SwiftOperator
[2] 以降、Swift ストレージを利用したい任意のクライアントホスト上で操作します。
Keystoneclient, Swiftclient をインストールしておきます。
# Xena, EPEL, PowerTools からインストール

[root@client ~]#
dnf --enablerepo=centos-openstack-xena,powertools,epel -y install python3-openstackclient python3-keystoneclient python3-swiftclient
[3] 環境変数を事前に読み込んでおきます ( [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
# 動作確認

[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] ファイルを保存するコンテナを作成します。
[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] ローカルにあるファイルを作成したコンテナにアップロードします。
# [testfile.txt] をアップロード

[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] Swift ストレージからファイルをローカルにダウンロードします。
# ローカルのテストファイルを一旦削除

[root@client ~(swift)]#
rm testfile.txt
[root@client ~(swift)]#
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] ストレージ上のファイルの削除です。
[root@client ~(swift)]#
openstack object delete test-container testfile.txt

[root@client ~(swift)]#
openstack object list test-container

# [testfile.txt] は削除された

[8] ストレージ上のコンテナの削除です。
[root@client ~(swift)]#
openstack container delete test-container

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

# [test-container] は削除された
関連コンテンツ