Recommended
PDF
Enterprise Cloud Design Pattern 前編:クラウドアーキテクチャ-の3要素
PDF
PPTX
Integral Technology 第2回ユーザカンファレンス 〜すべてをクラウドで解析するための方法〜
PDF
伸縮自在なデータセンターを実現するインタークラウド資源管理システム
PDF
[よくわかるクラウドデータベース] AWSデータベースアップデート 20140117
PDF
セミナー資料 2017年1月27日開催「クラウドCAEフェスティバル」
PDF
[よくわかるクラウドデータベース] CassandraからAmazon DynamoDBへの移行事例
PDF
やりたいことから考えるMicrosoft Azure 上の データストアの選び方とデータサイエンティスト向け活用法。KVSからDWHまで
PDF
Amazon Elastic MapReduce@Hadoop Conference Japan 2011 Fall
PDF
AWS Elastic MapReduce詳細 -ほぼ週刊AWSマイスターシリーズ第10回-
PPTX
セミナー資料「STAR-CCM+ クラウド活用ハンズオンセミナー with Rescale」
PDF
IBM版Hadoop - BigInsights/Big SQL (2013/07/26 CLUB DB2発表資料)
PDF
LAMMPS クラウド活用勉強会説明資料(Rescale編) 2017/01/24
PDF
Cloudian update (Japanese:日本語)
PDF
PDF
PPTX
PDF
20111130 10 aws-meister-emr_long-public
PDF
[db tech showcase Tokyo 2017] E23: クラウド異種データベース(AWS)へのデータベース移行時の注意点 ~レプリケーション...
PPTX
A 1-3 awsのクラウドデザインパターンをwindows-azureに持ってきてみた
PDF
Db2をAWS上に構築する際のヒント&TIPS 2020年6月版
PDF
事例から見るNoSQLの使い方 - db tech showcase Tokyo 2015 2015/06/11
PDF
[DI04] 使わないのはもったいない! プラネット スケールの NoSQL サービス「Azure Cosmos DB」を使いこなそう
PDF
20161005_Oracle/SQL Serverの AWS への移行 ~その選択肢と注意事項~ by 株式会社インサイトテクノロジー 宮地敬史
PDF
[DI06] 並列分散処理の考え方とオープンソース分散処理系の動向
PDF
[JAWSBigData#11]Cloudera on AWSと Amazon EMRを両方本番運用し 3つの観点から比較してみる
PDF
Aws summits2014 エンタープライズ向けawsbcpdr編
PPTX
Deep Learning on Rescale - Oct/11/2016 at Rescale night
PDF
Pycon APAC 2013 Windows Azure Session
PDF
[Azure Council Experts (ACE) 第7回定例会] Microsoft Azureアップデート情報 (2014/08/21-2014...
More Related Content
PDF
Enterprise Cloud Design Pattern 前編:クラウドアーキテクチャ-の3要素
PDF
PPTX
Integral Technology 第2回ユーザカンファレンス 〜すべてをクラウドで解析するための方法〜
PDF
伸縮自在なデータセンターを実現するインタークラウド資源管理システム
PDF
[よくわかるクラウドデータベース] AWSデータベースアップデート 20140117
PDF
セミナー資料 2017年1月27日開催「クラウドCAEフェスティバル」
PDF
[よくわかるクラウドデータベース] CassandraからAmazon DynamoDBへの移行事例
PDF
やりたいことから考えるMicrosoft Azure 上の データストアの選び方とデータサイエンティスト向け活用法。KVSからDWHまで
What's hot
PDF
Amazon Elastic MapReduce@Hadoop Conference Japan 2011 Fall
PDF
AWS Elastic MapReduce詳細 -ほぼ週刊AWSマイスターシリーズ第10回-
PPTX
セミナー資料「STAR-CCM+ クラウド活用ハンズオンセミナー with Rescale」
PDF
IBM版Hadoop - BigInsights/Big SQL (2013/07/26 CLUB DB2発表資料)
PDF
LAMMPS クラウド活用勉強会説明資料(Rescale編) 2017/01/24
PDF
Cloudian update (Japanese:日本語)
PDF
PDF
PPTX
PDF
20111130 10 aws-meister-emr_long-public
PDF
[db tech showcase Tokyo 2017] E23: クラウド異種データベース(AWS)へのデータベース移行時の注意点 ~レプリケーション...
PPTX
A 1-3 awsのクラウドデザインパターンをwindows-azureに持ってきてみた
PDF
Db2をAWS上に構築する際のヒント&TIPS 2020年6月版
PDF
事例から見るNoSQLの使い方 - db tech showcase Tokyo 2015 2015/06/11
PDF
[DI04] 使わないのはもったいない! プラネット スケールの NoSQL サービス「Azure Cosmos DB」を使いこなそう
PDF
20161005_Oracle/SQL Serverの AWS への移行 ~その選択肢と注意事項~ by 株式会社インサイトテクノロジー 宮地敬史
PDF
[DI06] 並列分散処理の考え方とオープンソース分散処理系の動向
PDF
[JAWSBigData#11]Cloudera on AWSと Amazon EMRを両方本番運用し 3つの観点から比較してみる
PDF
Aws summits2014 エンタープライズ向けawsbcpdr編
PPTX
Deep Learning on Rescale - Oct/11/2016 at Rescale night
Viewers also liked
PDF
Pycon APAC 2013 Windows Azure Session
PDF
[Azure Council Experts (ACE) 第7回定例会] Microsoft Azureアップデート情報 (2014/08/21-2014...
PDF
[Azure Council Experts (ACE) 第4回定例会] Microsoft Azureアップデート情報 (2014/02/19-2014...
PDF
[Azure Council Experts (ACE) 第6回定例会] Microsoft Azureアップデート情報 (2014/06/18-2014...
PDF
[Azure Council Experts (ACE) 第8回定例会] Microsoft Azureアップデート情報 (2014/10/16-2014...
PDF
[Azure Council Experts (ACE) 第2回定例会] Windows Azureアップデート情報 (201311/24-2013/12...
PDF
[Azure Council Experts (ACE) 第3回定例会] Windows Azureアップデート情報 (2013/12/07-2014/0...
PDF
[Azure Council Experts (ACE) 第5回定例会] Microsoft Azureアップデート情報 (2014/04/16-2014...
PDF
[Azure Council Experts (ACE) 第9回定例会] Microsoft Azureアップデート情報 (2014/12/11-2015...
PDF
PDF
PPTX
推薦システムを構築する手順書 with Azure Machine Learning
Similar to Enterprise cloud design pattern 大量データ処理アーキテクチャの構築
PPTX
JAZUG クラウドデザインパターンのコードを覗く
PPTX
20180421 Azure Architecture Cloud Design Patterns
PPTX
クラウドデザイン パターンに見るクラウドファーストなアプリケーション設計 Data Management編
PDF
[AWS Summit 2012] クラウドデザインパターン#5 CDP バッチ処理編
PDF
PDF
2021/02/19 Alterbooth 多忙なアーキテクトのためのクラウド導入フレームワーク (CAF) ダイジェスト
PPTX
Azure Cloud Application Design and Implementation Guidance の紹介
PPTX
The Twelve-Factor App (2017)
PDF
de:code 2019 Cloud トラック 総まとめ!
PPTX
PDF
クラウドデザインパターンから始めるクラウドの利点と弱点の理解~提案から設計・開発・保守に活かす!~
PPTX
Real World Cloud Architectures ~CDPの概念と実装~
PDF
de:code 2019 Cloud トラック 総まとめ! 完全版
PDF
Okinawa Open Daysでの講演(OpenStackトレーニングなど)
PDF
20131212 morphlabs okinawa_presentation
PDF
Awsのクラウドデザインパターンをwindows azureに持ってきてみた
PDF
AWSクラウドデザインパターン(CDP) - 概要編 -
PDF
PDF
PDF
Awsのインフラをデザインパターン駆使して設計構築
More from 貴志 上坂
PPTX
Azure Api Management 俺的マニュアル 2020年3月版
PDF
開発者のための機械学習入門:Azure Machine Learning Studioで構造化データから予測分析
PPTX
開発者のための機械学習入門:Azure Machine Learning Studioで構造化データから予測分析
PPTX
Azure API Management 俺的マニュアル
PDF
PDF
2016-11-11 UMTP モデリングフォーラム2016 DDD実践のコツとazureによるモデル実装
PPTX
NS study8 DDD Microservices Azuer Service Fabric
PDF
始めよう! ドメイン駆動設計&マイクロサービス開発 ~C# と Azure Service Fabric で最高の DDD 開発を~
PPTX
PDF
アルゴリズムから学ぶAzure mlモジュールの使いこなし方 hd-insight編-
PDF
Azure Machine Learningによるレコメンデーションの設計&実装を公開!~朝日カルチャーセンターの事例から~
PDF
20150421 QCon Tokyo 2015 Azureが切り開く新時代のソフトウェア開発・設計
PDF
Moq & Fakes Framework を使った実践的ユニットテスト - BuildInsider
Enterprise cloud design pattern 大量データ処理アーキテクチャの構築 1. 2. 本日の内容
1. 前編の振り返り
2. ACEのご紹介
3. Cloud Design Pattern とは
4. 今回の大量データ処理の概要
5. Microsoft Azure におけるPaaSとScaling
6. Scalingを前提とした大量データ処理用アーキテクチャ
7. クラウド汎用パターン あらゆるプロジェクトで使用推奨
3. 4. トリニティで Cloud Design Pattern を支援
• 技術観点 3つと実現指向の アーキ・トレンド “トリニティ”
2014 (C) Arichika Taniguchi, All rights reserved.
• 入力と処理、出力の分割
• 長時間ロードの分割
非同期
• 疎結合での負荷移動の容易さ
• 負荷単位でのSLAと制御
運用性
• トランザクションの整合性
• 処理中の緩い整合性の許容
完全性
Business
Architect
Code
Architect
Infra(Model)
Architect
Science
5. 6. Microsoft Azure パートナーコンソーシアム
Azure Council Experts(略称:ACE/エース)アジュール評議会は、
Microsoft Azure を利用した技術やサービスを提供するリーディングカンパニー
が集結し、普及ならびに技術者の育成、ノウハウの共有などでコラボレーション
を展開するパートナーコンソーシアム。
顧客企業・団体技術者
一般社団法人 Azure Council Experts について
http://a-c-e.biz/
7. 8. スピーカー自己紹介
• 株式会社ネクストスケープ(ACE理事企業)
Microsoft Partner of the Year 2012
Windows Azure パートナー アワード 受賞
(日本13,000事業所中)
Microsoft Partner of the Year 2013
Windows Azure パートナー アワード(System Integrator) 受賞
(日本14,000事業所中)
2013 Microsoft Worldwide Partner Award
Cloud Partner of the Year 世界2位
(世界3,000事業所中)
こんな会社です
• 配信ソリューション
• Microsoft Azure導入支援
• DRMソリューション(PlayReady)
• システム・インテグレーション
• Sitecore(CMS)導入支援
9. 10. 11. Cloud Design Pattern とは
http://msdn.microsoft.com/en-us/library/dn568099.aspx
24のデザインパターン
10のガイダンス
コードサンプル
12. Cloud Design Pattern とは
10のガイダンス
24のデザインパターン
可用性 管理と監視
データ管理 パフォーマンスとスケーラビリティ
設計と実装 弾力性
メッセージング セキュリティ
⇒ 8つのカテゴリに分類
13. 14. 15. 16. 17. 18. Microsoft Azure におけるPaaSとScaling
• PaaSとは、アプリケーションが稼動するための基盤(Platform)がサービスとして提供されたもの。
アプリケーション
OS
仮想化
サーバー
ストレージ
ネットワーク
ミドルウェア
アプリケーション アプリケーション
オン・プレミス IaaS PaaS
Runtime
データ
OS
仮想化
サーバー
ストレージ
ネットワーク
ミドルウェア
Runtime
データ
OS
仮想化
サーバー
ストレージ
ネットワーク
ミドルウェア
Runtime
データ
アプリケーション
SaaS
OS
仮想化
サーバー
ストレージ
ネットワーク
ミドルウェア
Runtime
データ
ユーザーが管理
クラウドベンダーが管理ユーザーが管理
ユーザーが管理クラウドベンダーが管理
クラウドベンダーが管理
19. 20. 21. Microsoft Azure におけるPaaSとScaling
Microsoft AzureにおけるPaaS
• クラウドサービスという名称
• VisualStudioから簡単にデプロイ可能
• JenkinsなどのCIツールを使用したデプロイも可能(Azure Powershell使用)
• WebRole(Web用)と、WorkerRole(バッチ用)の2種類をホスト
• StagingとProduction環境
• Stagingにデプロイして稼働確認→Productionへスワップ!(ボタン一発)
• リモートデスクトップで接続可能
22. 23. 24. 25. 26. 27. 28. ScaleOutを前提とした大量データ処理用アーキテ
クチャ
使用した Cloud Design Pattern
競合する消費者パターン
スループット、スケーラビリティと可用性の向上と、作業負荷を最適化す
るために同時に複数のメッセージを処理することを可能にする
パイプとフィルターパターン
タスク要素のデプロイとスケーリング処理を別々に実行することにより、
パフォーマンス、スケーラビリティ、および再利用性を向上できる
リソース統合計算パターン
計算リソースの使用率を高め、クラウドでホストされるアプリケーション
の処理の実行に関連するコストと管理オーバーヘッドを減らすことができ
る
29. ScaleOutを前提とした大量データ処理用アーキテ
クチャ
• 競合する消費者パターン
• 概要
• スループット、スケーラビリティと可用性の向上と、作業負荷を最適化するために同時に複数のメッセージを処理することを可能にします。
• 戦略
• クラウドで実行されるアプリケーションが多数の要求を処理することを可能にします。
• 一般的な手法は、各要求を同期的に処理するのではなく、要求をメッセージングシステムを通して他の非同期にサービスに渡すことです。
• この戦略は、要求の処理中、アプリケーションのビジネス ロジックがブロックされないようにするのに役立ちます。
メッセージ Queue
アプリーケーションインスタンス
メッセージ生成
サービスインスタンス
メッセージ処理
30. パイプライン
ScaleOutを前提とした大量データ処理用アーキテ
クチャ
• パイプとフィルターパターン
• 概要
• 複雑な処理を実行するタスクを再利用可能な一連の個別要素に分解します。このパターンはタスク要素をデプロイとスケーリング処理を別々に実行
することによってパフォーマンス、スケーラビリティ、および再利用性を向上できます。
• 戦略
• 1 つのタスクを実行するそれぞれの個別のコンポーネント (またはフィルター) のセットに処理を分解します。
• 各コンポーネント(またはフィルター)が受信し、出力するデータの形式を標準化することで、パイプライン内で複数のコンポーネント(またはフィル
ター) を組み合わせることができる。
メッセージ Queue フィルター メッセージ Queue フィルター
31. ScaleOutを前提とした大量データ処理用アーキテ
クチャ
• リソース統合計算パターン
• 概要
• 複数のタスクまたは操作を 1 つの計算ユニットに統合します。このパターンはコンピューティング リソースの使用率を増加し、クラウドでホストさ
れるアプリケーションでの処理を実行するために必要なコストと管理オーバーヘッドを削減できます。
• 戦略
• タスクは、環境によって提供される機能に基づいて、様々な基準や機能に関連したコストに応じてグループ化することができます。
• 一般的なアプローチは、そのスケーラビリティ、有効期間、および処理の要件に関して同様のプロファイルを持っているタスクを探します。
• これらのタスクを一つのグループの単位としてスケールできます。
Task A
Task E
計算ユニット
計算ユニット
Task B
計算ユニット
Task C
計算ユニット
Task D
計算ユニット
Task A
Task E
計算ユニット
計算ユニット
Task B
Task C
Task D
32. 33. クラウド汎用パターン
あらゆるプロジェクトで使用推奨
• Retryパターン
• 概要
• クラウドでは一時的な障害は珍しくない。障害発生時にその影響を最小限に抑える。
• 戦略
• 障害を示すエラーが一時的でない、または繰り返し要求しても成功する可能性が無い場合 、アプリケーションは操作を中止し、適切な例外を報告す
る必要がある。 (例:資格情報が無効なため、何度挑戦しても失敗する)
• 報告された例外が通常は起こりえないものや極希少なものの場合、極めて異常な事情によってその例外が引き起されている可能性がある。(例:
ネットワークパケットの破損)このような場合は同一の障害が繰り返される可能性は低いし、再要求は恐らく成功するので直ちに再試行を行う。
• 障害の原因が一般的な接続の問題や接続先がビジー状態によるものの場合、接続時の問題が解決するか、接続先のタスクがクリアされるまで短時間
の待ち時間が必要な場合がある。このような場合、アプリケーションは要求を再試行する前に適切な時間を待つ必要がある。
アプリケーション サービス
1
500
2
500
3
200
34. クラウド汎用パターン
あらゆるプロジェクトで使用推奨
• Retryパターン実装例
private int retryCount = 3;
public async Task OperationWithBasicRetryAsync()
{
int currentRetry = 0;
for (; ;)
{
try
{
// 外部サービスの呼び出し.
await TransientOperationAsync();
// Return or break.
break;
}
catch (Exception ex)
{
Trace.TraceError("Operation Exception");
currentRetry++;
// 一時的なエラーか判定。
if (currentRetry > this.retryCount || !IsTransient(ex))
{
// 一時的なエラーではない場合、リトライしない
throw;
}
}
// リトライの待機。
Await.Task.Delay();
}
}
// リモートサービス非同期呼び出しメソッド.
private async Task TransientOperationAsync()
{
...
}
private bool IsTransient(Exception ex)
{
// 例外が一時的なものか判定
// 例外のタイプのチェックだけでよい場合もあるが、時には例外のプロパティ値のチェックも必要
if (ex is OperationTransientException)
return true;
var webException = ex as WebException;
if (webException != null)
{
// web exceptionのStatusが以下のStatus値のいずれかの場合、一時的なエラーとみなす
return new[] { WebExceptionStatus.ConnectionClosed,
WebExceptionStatus.Timeout,
WebExceptionStatus.RequestCanceled }.
Contains(webException.Status);
}
// 追加の例外チェックはここに実装
return false;
}
35. クラウド汎用パターン
あらゆるプロジェクトで使用推奨
• でもAzureのSDKを使用する場合は先ほどのような実装はしません
Storageアクセスの場合のRetry実装例
• 最初からRetryの仕組みが用意されています。
CloudStorageAccount storageAccount = new CloudStorageAccount(new StorageCredentials(Configs.StorageAccountNameSupply, Configs.StorageAccountKeySupply), true);
var client = storageAccount.CreateCloudBlobClient();
client.RetryPolicy = new Microsoft.WindowsAzure.Storage.RetryPolicies.ExponentialRetry(TimeSpan.FromSeconds(2), Configs.RetryMaxCount);
using Microsoft.Practices.EnterpriseLibrary.TransientFaultHandling;
・・・
var sqlConn = new SqlConnection(sqlConnString);
var policy = new RetryPolicy<SqlDatabaseTransientErrorDetectionStrategy>(retryCount: 3, initialInterval: TimeSpan.FromSeconds(30), increment: TimeSpan.FromSeconds(30));
sqlConn.OpenWithRetry(policy);
Microsoft Azure SQLの場合のRetry実装例
• Enterprise Library - Transient Fault Handling Application Block - Windows Azure SQL Database integration
• 拡張メソッドと実装済みの戦略が提供されています。
36. クラウド汎用パターン
あらゆるプロジェクトで使用推奨
エラーNo エラー内容
40501
10929
サービスは現在ビジー状態
10928 同時要求の最大制限が 180 を超えたため要求を拒否
10053 サーバーから結果を受信するときにトランスポート レベルのエラーが発生。クライアントが切断
10054 サーバーから結果を受信するときにトランスポート レベルのエラーが発生。サーバーが切断
10060 Socket接続エラー。サーバーが見つからない
40197 要求の処理中にソフトウェアやハードウェアのアップグレードのためのサービス停止、ハードウェア エラー、またはその他のフェールオーバーの問題が発生
40540 要求処理中にエラーに遭遇。再試行を。
40613 サーバー上のデータベースが使用不可
233 未サポートバージョンのSQLServerへ接続しようとした;サーバービジーで新しい接続を生成できなかった;メモリ不足で新しい接続を生成できなかった
64 接続は成功したが、ログインに失敗した
20 接続先のSQLServerインスタンスはencryptionをサポートしていない
SqlDatabaseTransientErrorDetectionStrategyが一時的なエラーである、と判定するエラーの種類
※TimeoutException も一時的なエラーと判定される
37. • 外部構成ストアパターン
• 概要
• 複数のアプリケーションやインスタンスで構成設定を共有する。
• 戦略
• 外部記憶装置に構成情報を格納し、迅速かつ効率的に読み取りおよび設定を更新するために使用できるインターフェイスを提供する。
• 外部ストアの種類は、アプリケーションのホスティング、ランタイム環境に依存する。
• クラウドでホストされているシナリオでは通常、クラウド ・ ベースのストレージ サービス。もしくはデータベース、他のシステムになる可能性もあ
る。
クラウド汎用パターン
あらゆるプロジェクトで使用推奨
Application
外部構成ストアApplication
Application
クラウド・ストレージ
データベース
代替オプション
38.