OpenStack Icehouse : Swift 利用方法2014/06/28 |
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 | c2641bc0911b45da94847d39ec9162ad | | name | swiftservice | +-------------+----------------------------------+ # swiftoperator ロール作成 [root@dlp ~(keystone)]# keystone role-create --name swiftoperator +----------+----------------------------------+ | Property | Value | +----------+----------------------------------+ | id | ae90238094474365a37c98ce967cf059 | | name | swiftoperator | +----------+----------------------------------+ # ユーザー作成 [root@dlp ~(keystone)]# keystone user-create --tenant swiftservice --name user01 --pass userpassword --enabled true +----------+----------------------------------+ | Property | Value | +----------+----------------------------------+ | email | | | enabled | True | | id | 2d0ad7a14e7743bdbc933b561af7121b | | name | user01 | | tenantId | c2641bc0911b45da94847d39ec9162ad | | username | user01 | +----------+----------------------------------+ # ユーザーを swiftoperator に加える [root@dlp ~(keystone)]# keystone user-role-add --user user01 --tenant swiftservice --role swiftoperator |
[2] | 以下からはクライアントPC上で操作します。 まずは Keystoneclient, Swiftclient をインストールしておきます。 |
[root@client ~]# yum --enablerepo=openstack-icehouse,epel -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_c2641bc0911b45da94847d39ec9162ad Containers: 0 Objects: 0 Bytes: 0 Content-Type: text/plain; charset=utf-8 X-Timestamp: 1403960666.77571 X-Trans-Id: tx2efcb33efa27469288f9c-0053aebd5a X-Put-Timestamp: 1403960666.77571 |
[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)]# swift download test_container test.txt test.txt [auth 0.263s, headers 0.559s, total 0.559s, 0.000 MB/s] [root@client ~(swift)]# total 28 -rw-------. 1 root root 1047 May 20 2013 anaconda-ks.cfg -rw-r--r--. 1 root root 9169 May 20 2013 install.log -rw-r--r--. 1 root root 3161 May 20 2013 install.log.syslog -rw------- 1 root root 175 Jun 28 22:04 keystonerc_swift -rw-r--r-- 1 root root 28 Jun 28 22: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 # 削除された |
Sponsored Link |