Ubuntu 16.04
Sponsored Link

OpenStack Mitaka (三鷹) : Swift 利用方法2016/06/08

 
OpenStack Object Storage(Swift)の利用方法です。
ここでは以下のように、Control ノード、Proxy ノード、Storage ノードと、 計5台を使って Swift ストレージを構築しています。
例として、この Swift ストレージを、図の「10.0.0.20」のクライアントPCから利用します。
                                    |
     +------------------+           |           +-----------------+
     | [ 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] 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   | 780b41cee03242da9ec0c73e1a76dc6e |
| enabled     | True                             |
| id          | 76a2f2815b4f417392805cf5e4a1988f |
| is_domain   | False                            |
| name        | swiftservice                     |
| parent_id   | 780b41cee03242da9ec0c73e1a76dc6e |
+-------------+----------------------------------+

# SwiftOperator ロール作成

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

+-----------+----------------------------------+
| Field     | Value                            |
+-----------+----------------------------------+
| domain_id | None                             |
| id        | ec2aee6756bc465d93945b789c764251 |
| name      | SwiftOperator                    |
+-----------+----------------------------------+

# ユーザー作成

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

+--------------------+----------------------------------+
| Field              | Value                            |
+--------------------+----------------------------------+
| default_project_id | 76a2f2815b4f417392805cf5e4a1988f |
| domain_id          | 780b41cee03242da9ec0c73e1a76dc6e |
| enabled            | True                             |
| id                 | 72337fa9a78344479d289775517f5ac9 |
| name               | user01                           |
+--------------------+----------------------------------+

# ユーザーを SwiftOperator に加える

root@dlp ~(keystone)#
openstack role add --project swiftservice --user user01 SwiftOperator
[2] 以下からはクライアントPC上で操作します。
まずは Keystoneclient, Swiftclient をインストールしておきます。
root@client:~#
apt-get -y install python-keystoneclient python-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=user01
export OS_PASSWORD=userpassword
export OS_AUTH_URL=http://10.0.0.30:35357/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_76a2f2815b4f417392805cf5e4a1988f
     Containers: 0
        Objects: 0
          Bytes: 0
X-Put-Timestamp: 1465470037.82202
    X-Timestamp: 1465470037.82202
     X-Trans-Id: tx4760fc25a3b340839e663-0057594c55
   Content-Type: text/plain; charset=utf-8
[4] ファイルを保存するコンテナを作成します。
root@client ~(swift)#
swift post test_container

root@client ~(swift)#
swift list

test_container    
# 作成された

[5] ローカルにあるファイルを作成したコンテナにアップロードします。
# test.txt をアップロードしてみる

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

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

test.txt    
# アップロードされた

[6] Swift ストレージからファイルをローカルにダウンロードします。
# ローカルのファイルを一旦削除

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 335 Nov 18 23:03 keystonerc_swift
-rw-r--r--  1 root root  10 Nov 18 23:05 test.txt
[7] ストレージ上のファイルの削除です。
root@client ~(swift)#
swift delete test_container test.txt

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

test2.txt    
# test.txt は削除された

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

root@client ~(swift)#
swift list

# 削除された
関連コンテンツ