Ubuntu 14.04
Sponsored Link

OpenStack Icehouse : Swift 利用方法
2014/06/11
 
OpenStack Object Storage(Swift)の利用方法です。
ここでは以下のように、Control ノード、Proxy ノード、Storage ノードと、 計5台を使って Swift ストレージを構築しています。
例として、この Swift ストレージを、図の「10.0.0.20」のクライアントPCから利用します。
                                    |
     +------------------+           |           +-----------------+
     | [ Control Node ] |10.0.0.30  |  10.0.0.70|  [ 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)#
keystone tenant-create --name swiftservice --description "Swift Users Tenant" --enabled true

+-------------+----------------------------------+
|   Property  |              Value               |
+-------------+----------------------------------+
| description |        Swift Users Tenant        |
|   enabled   |               True               |
|      id     | e6e814b2cbc143f7991ed0613438611d |
|     name    |           swiftservice           |
+-------------+----------------------------------+

# swiftoperator ロール作成

root@dlp ~(keystone)#
keystone role-create --name swiftoperator

+----------+----------------------------------+
| Property |              Value               |
+----------+----------------------------------+
|    id    | 2c3b49e3cd8546bc977695997ee58a5b |
|   name   |          swiftoperator           |
+----------+----------------------------------+

# ユーザー作成

root@dlp ~(keystone)#
keystone user-create --tenant swiftservice --name user01 --pass userpassword --enabled true

+----------+----------------------------------+
| Property |              Value               |
+----------+----------------------------------+
|  email   |                                  |
| enabled  |               True               |
|    id    | a68557e54abc4a92b915efb4ee164f65 |
|   name   |              user01              |
| tenantId | e6e814b2cbc143f7991ed0613438611d |
| username |              user01              |
+----------+----------------------------------+

# ユーザーを swiftoperator に加える

root@dlp ~(keystone)#
keystone user-role-add --user user01 --tenant swiftservice --role swiftoperator

[2] 以下からはクライアントPC上で操作します。
まずは Keystoneclient, Swiftclient をインストールしておきます。
root@client:~#
apt-get -y install python-keystoneclient python-swiftclient
[3] 環境変数を事前に読み込んでおきます ( [1] で作成したユーザーの値 )
root@client:~#
vi ~/keystonerc_swift
export OS_USERNAME=user01
export OS_PASSWORD=userpassword
export OS_TENANT_NAME=swiftservice
export OS_AUTH_URL=http://10.0.0.30:35357/v2.0/
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_e6e814b2cbc143f7991ed0613438611d
    Containers: 0
       Objects: 0
         Bytes: 0
  Content-Type: text/plain; charset=utf-8
   X-Timestamp: 1402501124.33015
    X-Trans-Id: txd0ad784505d04456be71e-0053987804
X-Put-Timestamp: 1402501124.33015
[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.187s, headers 0.243s, total 0.244s, 0.000 MB/s]
root@client ~(swift)#
total 8
-rw------- 1 root root 173 Jun 12 00:25 keystonerc_swift
-rw-r--r-- 1 root root  14 Jun 12 00:41 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

     
# 削除された

関連コンテンツ