- 追加された行はこの色です。
- 削除された行はこの色です。
* Eucalyptus(Version 1.5.2) + Euca2ools + Elasticfox で作るプライベートクラウド環境 [#w1980722]
Eucalyptus Version 1.5.2 と Euca2ools のリリースを祝って、オープンソースソフトウェアのみでプライベートクラウドを構築してみようかと思います。
# ちなみに、apt-getでインストール可能なEucalyptus(1.5~bzr266-0ubuntu2)は、1.5rc1ベースとなります。
** 環境 [#m655d6a8]
今回は以下のような環境を想定
- サーバ1
-- 役割:
--- クラウドコントローラ(Cloud Controller[eucalyptus-cloud])
--- クラスターコントローラ(Cluster Controller[eucalyptus-cc])
--- ノードコントローラ(Node Controller[eucalyptus-nc])
- サーバ2
-- 役割:
--- ノードコントローラ(Node Controller[eucalyptus-nc])
※ Ubuntuのドキュメントとはことなり、Front-End(サーバ1)にもノードとしての役割(仮想サーバを動作させる)を与えました。
https://help.ubuntu.com/community/Eucalyptus
** 用意するもの [#b56e7f3f]
Intel VT または AMD-V 対応のPC x 2台
# BIOSでVirtualzationが無効になっている場合があるので、有効にしておきましょう。
** Ubuntu 9.04 Server Edition のインストール [#gee79a8e]
[[Ubuntu 9.04 Server Edition のダウンロード方法]]
CD-ROMからブートさせ、Ubuntu 9.04 Server Edition のインストールする。
Language: 日本語
キーボドレイアウト: Japan - OADG 109A
タイムゾーン: Asia/Japan
ホスト名: front.eucaly.jp (サーバ1)
node.eucaly.jp (サーバ2)
ネットワーク設定: サーバ1はインストール時にネットワークの設定を固定IPでしておきます。
ディスク全体を使いLVMをセットアップ
自動的にアップデートしない
ソフトウェア選択: DNS server, Mail Server OpenSSH server, Virtaul Machine host
ユーザ: eucaly
パスワード: ********
※ループデバイスを増やしておきます。
You should have at least 32 loop devices
※デフォルトでFWが有効なので、PCから
8443番ポートにアクセスできるように設定しましょう。
** Eucalyptus Version 1.5.2 + Euca2ools のインストール [#yaece731]
必要なパッケージの自動インストールが可能なようにサーバはインターネットへアクセス可能な状態にしておきます。
Eucalyptusのダウンロードページ( http://open.eucalyptus.com/downloads )から、
下記の2つをダウンロードし、サーバにアップロードします。
- Eucalyptus Binaries → 32bit/64bit → Ubuntu-Jaunty
- Euca2ools Binaries → 32bit/64bit → Ubuntu-Jaunty
Ubuntuの64bit版の場合(例)
ce /home/eucaly
wget http://open.eucalyptus.com/downloads/125 -O euca2ools-1.0-ubuntu-amd64.tar.gz
wget http://open.eucalyptus.com/downloads/113 -O eucalyptus-1.5.2-ubuntu-amd64.tar.gz
解凍
tar xvfz eucalyptus-1.5.2-ubuntu-amd64.tar.gz
tar xvfz euca2ools-1.0-ubuntu-amd64.tar.gz
sources.listへ追加
sudo -s
echo 'deb file:///home/eucaly/eucalyptus-1.5.2-ubuntu-amd64 ./' >> /etc/apt/sources.list
echo 'deb file:///home/eucaly/euca2ools-1.0-ubuntu-amd64 ./' >> /etc/apt/sources.list
apt-get update
Eucalyptusのインストール(サーバ1の場合)
apt-get install eucalyptus-cloud
apt-get install eucalyptus-cc
apt-get install eucalyptus-nc
Eucalyptusのインストール(サーバ2の場合)
apt-get install eucalyptus-nc
最初に実行した場合は必要なパッケージも併せてインストールされるため大量にインストールされます。~
また、下記の出力がでますが「y」を入力し進みます。~
警告: 以下のパッケージは認証されていません!
eucalyptus-gl eucalyptus-cc
検証なしにこれらのパッケージをインストールしますか [y/N]? y
上記の警告にyesと答えるのが面倒な場合には、"--force-yes"を付けます。(非奨励)~
apt-get install eucalyptus-cloud --force-yes
続いて、Euca2ools をインストールします。
apt-get install euca2ools
** クラスターの作成 [#o3f99aea]
クラスターの作成
euca_conf -addcluster test-cluster localhost
** WebUIへログイン [#t015840c]
https://(サーバ1のIPアドレス):8443/
username: admin
Password: admin
ログイン後、パスワードの変更を求められるので任意のものに変更します。
次に、メールアドレスの入力を求められます。クラウドのサインアップメッセージのあて先やfrom欄として用いられるものでなので、適切なメールアドレスを入力します。
(/etc/eucalyptus/cloud.d/eucalyptus-web.propertiesにて変更可能です。)
Walrus URLの入力を行います。WalrusはS3互換のEucalyptusのストレージサービスです。
(ホスト名が設定されている場合は、変えておくといいでしょう。)
http://(サーバ1のIPアドレス):8773/services/Walrus
最初は、「Configuration」タブが表示されます。
必要に応じて「Cloud configuration」「Walrus configuration」
「Clusters」「VM Types」の設定を変更するといいでしょう。
「Credentials」「Images」「Users」「Configuration」「Extras」
タブも確認しておきましょう。
特に、「Extras」タブでは、Eucalyptusから承認されたイメージとして、
下記のイメージがダウンロードできるので便利です。
-- CentOS 5.3 x86_64(euca-centos-5.3-x86_64.tar.gz)
-- Debian 5.0 (lenny) x86_64(euca-debian-5.0-x86_64.tar.gz)
-- Fedora 10 x86_64(euca-fedora-10-x86_64.tar.gz)
-- Ubuntu 9.04 (jaunty) x86_64(euca-ubuntu-9.04-x86_64.tar.gz)
また、「Users」タブにて利用者ユーザを作っておくといいです。
** ノードの登録 [#t3c1c652]
ホスト名が引けない場合は、予め/etc/hostsに記載しておきます。
vi /etc/hosts
※例:
(サーバ1のIPアドレス) front.eucaly.jp front
(サーバ2のIPアドレス) node.eucaly.jp node
ノード追加
sudo euca_conf -addnode front.eucaly.jp
sudo euca_conf -addnode node.eucaly.jp
ノード追加の再にエラーがでるので各ノードでログイン可能なように設定しておきます。
sudo -u eucalyptus mkdir -p ~eucalyptus/.ssh
sudo -u eucalyptus tee ~eucalyptus/.ssh/authorized_keys > /dev/null <<EOT
(省略)
EOT
eucalyptus.confの確認
cat /etc/eucalyptus/eucalyptus.conf |grep VNET_BRIDGE
VNET_BRIDGE="br0" ← br0になっていることを確認しておく
** イメージの登録 [#t3c1c652]
サーバ1にて実施
EucalptusのWebUI
Credentials → X.509 certificate → Download Certificateから
アクセスに利用する証明書をダウンロードし、サーバ1にアップします。
FTPでアップ
apt-get install unzip
unzip euca2-admin-x509.zip
source eucarc
http://www.eucalyptussoftware.com/downloads/eucalyptus-images/euca-ubuntu9.04-x86_64.tar.gzをダウンロード
mkdir images
cd images
wget http://www.eucalyptussoftware.com/downloads/eucalyptus-images/euca-ubuntu-9.04-x86_64.tar.gz
tar xvfz euca-ubuntu-9.04-x86_64.tar.gz
cd euca-ubuntu-9.04-x86_64
euca-bundle-image -i euca-ubuntu-9.04-x86_64/kvm-kernel/vmlinuz-2.6.28-11-generic --kernel true
euca-upload-bundle -b ubuntu-kernel-bucket -m /tmp/vmlinuz-2.6.28-11-generic.manifest.xml
euca-register ubuntu-kernel-bucket/vmlinuz-2.6.28-11-generic.manifest.xml
出力された、EKIを登録する。
export EKI=eki-********
echo $EKI
euca-bundle-image -i euca-ubuntu-9.04-x86_64/kvm-kernel/initrd.img-2.6.28-11-generic --ramdisk true
euca-upload-bundle -b ubuntu-ramdisk-bucket -m /tmp/initrd.img-2.6.28-11-generic.manifest.xml
euca-register ubuntu-ramdisk-bucket/initrd.img-2.6.28-11-generic.manifest.xml
出力された、ERIを登録する。
export ERI=eri-********
echo $ERI
euca-bundle-image -i euca-ubuntu-9.04-x86_64/ubuntu.9-04.x86-64.img --kernel $EKI --ramdisk $ERI
euca-upload-bundle -b ubuntu-image-bucket -m /tmp/ubuntu.9-04.x86-64.img.manifest.xml
euca-register ubuntu-image-bucket/ubuntu.9-04.x86-64.img.manifest.xml
出力された、EMIを登録する。
export EMI=eri-********
echo $EMI
** インスタンスの起動 [#ka36caae]
euca-add-keypair mykey > ~/.euca/mykey.priv chmod 0600 ~/.euca/mykey.priv
euca-run-instances $EMI -k mykey
** Eucalyptus対応のElasticfoxの作成 (検証中) [#ee2b3e80]
https://code.launchpad.net/~soren/elasticfox/elasticfox.eucalyptus
の内容だけでは、サーバまたはPCの時刻変更が必要、AMIが表示されないという
問題があり止まっておりましたが、suzdalenator氏より以下の修正情報とそのパッチを頂きました。(感謝感激)
パッチについて公開可能とのことでしたので、本ページにて公開させていだきます。
ご提供ありがとうございます。(早速検証の方も進めたいと思います。)
ご提供ありがとうございます。
(早速検証をしましたが、インスタンスの起動・再起動・停止、AMIの確認、
key作成、EIPの操作、EBS(createとattach)は問題なく行えました。)
*** Eucalyptusブランチ(elasticfox.eucalyptus)用パッチ(xpi同梱) [#y86f1804]
http://eucalyptus-users.jp/files/elasticfox-1.7-eucalyptus-1.5.2.patch.zip
修正箇所
- リクエストパラメータの時間情報文字列(ISO-8601形式)の最後の"Z"を外す。何故か付いているとEucalyptusが受け付けない。
- HTTPヘッダの"Content-Type"と"Content-Length"が、何故か外れていたので付け加える。
- インスタンス起動時のリクエストパラメータで、イメージID名が"a[krm]i-"になっていたのを、"e[krm]i-"に変える。
- インスタンスでのSSH接続で、接続先インスタンス名の値がAWSのホスト名前提なのを、IPアドレスのみでも対応可能にした。
*** メイントランク最新版(1.7.000108)用パッチ(xpi同梱) [#nee69441]
http://eucalyptus-users.jp/files/elasticfox_eucalyptus-20090826.zip
修正箇所
- リクエストパラメータの時間情報文字列(ISO-8601形式)の最後の"Z"削除
- Endpoint URL が Eucalyptus の場合には、ec2のAPIバージョンを、"2009-07-15"から"2009-03-01"に戻す。(Amazon と Eucalyptus で利用可能に)
- インスタンスのSSH接続の対応
** 雑記 [#o0f90be6]
*** versionファイル [#z4170315]
/etc/eucalyptus/eucalyptus-version ファイルがないので作っておく。
echo 1.5.2 > /etc/eucalyptus/eucalyptus-version
# euca_conf -version
Eucalyptus version: 1.5.2
*** ftpサーバのインストール [#t3bf33aa]
sudo apt-get install vsftpd
sudo vi /etc/vsftpd.conf
#anonymous_enable=YES
local_enable=YES
write_enable=YES
local_umask=022
service vsftpd restart