Sheepdog/デザイン
の編集
http://eucalyptus.linux4u.jp/wiki/index.php?Sheepdog%2F%E3%83%87%E3%82%B6%E3%82%A4%E3%83%B3
[
トップ
] [
編集
|
差分
|
バックアップ
|
添付
|
リロード
] [
新規
|
一覧
|
単語検索
|
最終更新
|
ヘルプ
] [
リンク元
]
-- 雛形とするページ --
BracketName
Ceph/install
Ceph/memo
Ceph/mount
Ceph/概要
ChangeLog_v1.5.2
CloudStack
CloudStack/インストール方法
CloudStack/ネットワーク解説
CloudStack/ネットワーク設定
CloudStack/メモ
CloudStack/仮想マシン
CloudStack/初期設定
CloudStack/概要
Doc/EucalyptusImageManagement_v1.5.2
Documents
DynamicDNSGuide
Elasticfox
Euca2ools と EC2 Tools との違い
Euca2oolsCentosInstall
Euca2oolsGuide
Euca2oolsImageManagement
Euca2oolsInstallJaunty
Euca2oolsLennyInstall
Euca2oolsNetworking
Euca2oolsOpensuseInstall
Euca2oolsSourceInstall
Euca2oolsSqueezeInstall
Euca2oolsStorage
Euca2oolsUsing
Euca2oolsVmControl
Eucalyptus (OSS Elastic Computing) 日本語情報
Eucalyptus + Euca2ools + Elasticfox で作るプライベートクラウド環境
Eucalyptus - OSS Elastic Computing
Eucalyptus - Ubuntu 9.04 で作るプライベートクラウド環境
Eucalyptus 1.5.2
Eucalyptus 日本語情報 wiki - OSS Elastic Computing
Eucalyptus-Upgrade-1.6.1
Eucalyptus-Upgrade-1.6.2
EucalyptusAdministratorGuide_v1.5.2
EucalyptusAdministratorGuide_v1.6
EucalyptusAdvanced_v1.6
EucalyptusBlockStoreInteracting_v1.5.2
EucalyptusConfiguration_v1.5.2
EucalyptusFeatures_v1.5.2
EucalyptusGettingStarted_v1.5.2
EucalyptusImageManagement_v1.5.2
EucalyptusImageManagement_v1.6
EucalyptusInstall_v1.5.2
EucalyptusInstall_v1.6
EucalyptusInstallationCentos_v1.5.2
EucalyptusInstallationCentos_v1.6
EucalyptusInstallationDebianLenny_v1.5.2
EucalyptusInstallationDebianSqueeze_v1.5.2
EucalyptusInstallationDebianSqueeze_v1.6
EucalyptusInstallationOpensuse_v1.5.2
EucalyptusInstallationOpensuse_v1.6
EucalyptusInstallationUbuntuJaunty_v1.5.2
EucalyptusInstallationUbuntuJaunty_v1.6
EucalyptusKnownBugs_v1.5.2
EucalyptusKnownBugs_v1.5.2)
EucalyptusManagement_v1.5.2
EucalyptusManagement_v1.6
EucalyptusMonitoring_v1.6
EucalyptusNetworking_v1.5.2
EucalyptusNetworking_v1.6
EucalyptusOverview
EucalyptusPrerequisites_v1.5.2
EucalyptusRocksInstallation_v1.5.2
EucalyptusSourceCodeInstallation_v1.5.2
EucalyptusTroubleshooting_v1.5.2
EucalyptusTroubleshooting_v1.6
EucalyptusUpgrade_v1.5.2
EucalyptusUserGuide_v1.5.2
EucalyptusUserImageCreatorGuide_v1.5.2
EucalyptusWalrusInteracting_v1.5.2
FAQ
FormattingRules
FrontPage
Help
Hibari
Hibari/インストール
Hibari/データモデル
Hibari/データ操作
Hibari/特徴
InterWiki
InterWikiName
InterWikiSandBox
Links
MenuBar
OpenNebula/その他
OpenNebula/クラスタノードの構築
OpenNebula/ゲストOSのネットワークの設定
OpenNebula/ゲストOSの構築
OpenNebula/フロントエンドノードの構築
OpenNebula/仮想ネットワークの構築
OpenNebula/概要
OpenStack
PHP
Presentations
PressRelease/2010_Feb_9
PukiWiki
PukiWiki/1.4
PukiWiki/1.4/Manual
PukiWiki/1.4/Manual/Plugin
PukiWiki/1.4/Manual/Plugin/A-D
PukiWiki/1.4/Manual/Plugin/E-G
PukiWiki/1.4/Manual/Plugin/H-K
PukiWiki/1.4/Manual/Plugin/L-N
PukiWiki/1.4/Manual/Plugin/O-R
PukiWiki/1.4/Manual/Plugin/S-U
PukiWiki/1.4/Manual/Plugin/V-Z
RHEL5 にセットアップ(RPM)
RecentDeleted
RightScale
S3_Compatibility_1.5.2
SandBox
Scalaris/JSON APIの利用
Scalaris/Java-API用CLIツール
Scalaris/インストール方法
Scalaris/分散環境の設定
Scalaris/利用方法
Scalaris/概要
Sheepdog/インストール方法
Sheepdog/インストール方法(SL6)
Sheepdog/デザイン
Sheepdog/ユーザ会
Sheepdog/利用方法
Sheepdog/問題点
Sheepdog/概要
Swift/Rings
Swift/memo
Swift/インストール方法
Swift/サーバの起動とテスト
Swift/メッセージの流れ
Swift/使い方
Swift/概要
Swift/設定ファイルの作成
Swift/起動用スクリプトの作成
ToolsEcosystem
ToolsEcosystem_EC2Dream
ToolsEcosystem_Elasticfox
ToolsEcosystem_boto
ToolsEcosystem_cloud42
ToolsEcosystem_right_aws
ToolsEcosystem_s3cmd
ToolsEcosystem_s3fs
ToolsEcosystem_tAWS
ToolsEcosystem_typica
UEC/CDInstall
UEC/CreateYourImage
Ubuntu 9.04 Server Edition のダウンロード方法
Ubuntu Enterprise Cloud 入門
Ubuntu Enterprise Cloudで作るプライベートクラウド環境
Ubuntu/Eucalyptus
Ubuntu/Eucalyptus+bridge
Ubuntu/Eucalyptus+environment
Ubuntu/KVM
Ubuntu/libvirt
Ubuntu/ubuntu-vm-builder
UbuntuEnterpriseCloud
WikiEngines
WikiName
WikiWikiWeb
YukiWiki
backup-eucalyptus-16
configuration
first-time-setup-16
hypervisor-configuration
installation-distribution-specific-binary-packages
installing-eucalyptus-source-16
s3curl
sample-s3cmd-config
sample-s3cmd-config-s3
トラブル事例
[[Sheepdog/概要]] *デザイン [#bc2f7969] sheepdogのアーキテクチャは完全なSymmetric,つまり左右対称です.~ メタサーバのような中心ノードが存在しません.~ このようなシステム構成は次のような特徴と持ちます. -性能と容量における直線的なスケーラビリティを持っている.~ クラスタ環境により高い性能,またはより大きなストレージ容量が必要である場合、単純に新しいマシンをクラスタ環境に加えることによって、Sheepdogは直線的に性能,ストレージ容量の増加が可能です.~ -NSPOFである.~ NSPOFとは,No Single Point Failureの略でノードが1つ壊れただけで全体が停止することがないようなシステムであることを意味します.~ つまり,ノードが故障しても,データは他のマシンを通してアクセス可能です.~ -簡単な管理が可能である.~ クラスタ環境の構築に関するコンフィグファイルが殆どありません.~ 管理者が新たに加えられたノードでSheepdogプログラムを実行するとき,Sheepdogは自律的に加えられたノードを検出して、クラスタのメンバとして構成し始めます.~ *アーキテクチャ [#oaa70c02] Sheepdogは,Sheepdogクライアント(qemuブロックドライバ)に簡単なKeyValueInterfaceを提供するストレージシステムです.~ Sheepdogは複数のノードから構成されます.~ #ref(virtual-infrastructure.png) Sheepdogは1ノード(collieと呼ばれる)とパッチを適用したQEMU/KVMから構成されます.~ #ref(components.png) *Virtual Disk Image (VDI) [#t5c369af] SheepdogクライアントはVMイメージを固定サイズオブジェクトに分割します.(デフォルトで4MB).~ そして、分配されたストレージシステムにオブジェクトを保存します.~ 各オブジェクトは、グローバルにユニークな64bit IDによって決定されて,複数のノードにコピーされます. #ref(dvi.png) *オブジェクト [#ea66742e] Sheepdogオブジェクトは2つのタイプに分類されます. -VDI Object~ VDIオブジェクトはイメージ名,ディスクサイズ,作成時間などのVMイメージのためのメタデータを保持しています.~ -Data Object~ VMイメージはデータ・オブジェクトに分割されます.~ 通常,Sheepdogクライアントはこのオブジェクトにアクセスします.~ Sheepdogは,オブジェクトがどこに保存されるかを決定するのにconsistent hashを使用します.~ consistent hashは,ハッシュ表の機能性を提供するスキーマです.~ そして,ノードの参加か離脱がオブジェクトに関するマッピングをあまり変えません.~ 入出力負荷はノードの向こう側にハッシュ表を用いることでバランスをとっています.~ 手当たりしだいに分配するのではなく,インテリジェントにデータを分配するメカニズムは今後の活動です. 各ノードはリングそれ自身のIDに基づいているconsistent hashによって配置されます.~ どこにオブジェクトを保存するかを決定するために,SheepdogクライアントはオブジェクトIDを得て,リングに適合するポイントを発見し,時計回りにターゲットノードを決定します. #ref(consistent-hashing.png) * VDIの管理 [#qb80c7f6] 多くの場合,クライアントが同時に同じイメージにアクセスするのを許容しません. しかし,Sheepdogクライアントは独自にそれらのイメージにアクセスできます. しかし,いくつかのVDI操作(例えば,VDIをロックして,VDIのクローンを作る)には,排他的な全体的な情報のアップデートがあります. この可用性の高いシステムを実装するために,私たちはGroup communication systems(GCS)を使用します. Group communication systemsはメッセージの全ての命令などの提供を保証します. 私たちはcorosync,有名なGCSの1つを使用します. #ref(corosync.png)
タイムスタンプを変更しない
[[Sheepdog/概要]] *デザイン [#bc2f7969] sheepdogのアーキテクチャは完全なSymmetric,つまり左右対称です.~ メタサーバのような中心ノードが存在しません.~ このようなシステム構成は次のような特徴と持ちます. -性能と容量における直線的なスケーラビリティを持っている.~ クラスタ環境により高い性能,またはより大きなストレージ容量が必要である場合、単純に新しいマシンをクラスタ環境に加えることによって、Sheepdogは直線的に性能,ストレージ容量の増加が可能です.~ -NSPOFである.~ NSPOFとは,No Single Point Failureの略でノードが1つ壊れただけで全体が停止することがないようなシステムであることを意味します.~ つまり,ノードが故障しても,データは他のマシンを通してアクセス可能です.~ -簡単な管理が可能である.~ クラスタ環境の構築に関するコンフィグファイルが殆どありません.~ 管理者が新たに加えられたノードでSheepdogプログラムを実行するとき,Sheepdogは自律的に加えられたノードを検出して、クラスタのメンバとして構成し始めます.~ *アーキテクチャ [#oaa70c02] Sheepdogは,Sheepdogクライアント(qemuブロックドライバ)に簡単なKeyValueInterfaceを提供するストレージシステムです.~ Sheepdogは複数のノードから構成されます.~ #ref(virtual-infrastructure.png) Sheepdogは1ノード(collieと呼ばれる)とパッチを適用したQEMU/KVMから構成されます.~ #ref(components.png) *Virtual Disk Image (VDI) [#t5c369af] SheepdogクライアントはVMイメージを固定サイズオブジェクトに分割します.(デフォルトで4MB).~ そして、分配されたストレージシステムにオブジェクトを保存します.~ 各オブジェクトは、グローバルにユニークな64bit IDによって決定されて,複数のノードにコピーされます. #ref(dvi.png) *オブジェクト [#ea66742e] Sheepdogオブジェクトは2つのタイプに分類されます. -VDI Object~ VDIオブジェクトはイメージ名,ディスクサイズ,作成時間などのVMイメージのためのメタデータを保持しています.~ -Data Object~ VMイメージはデータ・オブジェクトに分割されます.~ 通常,Sheepdogクライアントはこのオブジェクトにアクセスします.~ Sheepdogは,オブジェクトがどこに保存されるかを決定するのにconsistent hashを使用します.~ consistent hashは,ハッシュ表の機能性を提供するスキーマです.~ そして,ノードの参加か離脱がオブジェクトに関するマッピングをあまり変えません.~ 入出力負荷はノードの向こう側にハッシュ表を用いることでバランスをとっています.~ 手当たりしだいに分配するのではなく,インテリジェントにデータを分配するメカニズムは今後の活動です. 各ノードはリングそれ自身のIDに基づいているconsistent hashによって配置されます.~ どこにオブジェクトを保存するかを決定するために,SheepdogクライアントはオブジェクトIDを得て,リングに適合するポイントを発見し,時計回りにターゲットノードを決定します. #ref(consistent-hashing.png) * VDIの管理 [#qb80c7f6] 多くの場合,クライアントが同時に同じイメージにアクセスするのを許容しません. しかし,Sheepdogクライアントは独自にそれらのイメージにアクセスできます. しかし,いくつかのVDI操作(例えば,VDIをロックして,VDIのクローンを作る)には,排他的な全体的な情報のアップデートがあります. この可用性の高いシステムを実装するために,私たちはGroup communication systems(GCS)を使用します. Group communication systemsはメッセージの全ての命令などの提供を保証します. 私たちはcorosync,有名なGCSの1つを使用します. #ref(corosync.png)
テキスト整形のルールを表示する