6
7

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 5 years have passed since last update.

Integration Architecture デザイナー進め方のポイント

Last updated at Posted at 2020-02-13

この記事の思い  

日本では情報が非常に少ないArchitecture系の資格で皆さん試行錯誤して学んでいる方が多いと思います。
海外サイト行けばまだ情報があるのですがね・・・。
1カ月程度勉強して、ようやく合格しましたので、折角なので私なりの進め方を公開して
スキルを習得する人や資格取得が増えてくれればと思います。
image.png

別途知識のポイントはアップしますが、この記事では情報が少なかった進め方のポイントをまとめました!

今後、1年をかけて他のArchitectureも取得していくつもりです。
随時更新していきたいと思います。

Integration Architecture デザイナーの知識体系を学ぶ為の基本方針

大前提

公式からインテグレーションのパターンと実践という素晴らしいドキュメントが公開されています!
設計パターンや採用する際のポイント、注意点が細かく書いてあり、こちらを読み進めて理解するのが近道かと思います。

基礎知識編

しかし、このドキュメントを理解するのに各種APIの仕組み、インテグレーションの各機能を
理解しないと正直何を言っているのかさっぱり分かりませんでした・・・。
その為、Trailheadや開発者ドキュメント等を活用して基礎知識をしっかりと確立させる必要があります。

応用編

基礎知識を理解した所でインテグレーションのパターンと実践を読みます。
1つ1つの単語の意味を理解している分、点と点が繋がって線として読みやすくなっているはずです。

発展編

その後、他にも知らない知識など無いか先人達のブログなどを読み進めて、自分の理解や知識を補いましょう。

余談

アーキテクチャTrailmixも日本語版が用意されています。
ただ、英語版動画やドキュメントがチェックだけなのでモチベーション的にやった感が出なく
今回は私なりのやり方で進めました。公式の方、すみません・・・。

基礎知識編:インテグレーションに使用されるAPIや標準機能を理解しよう

どんな応用も基礎がしっかりしていないと意味がありません!
まずは地道にインテグレーションに使用される各種API、機能の1つ1つしっかりと抑えましょう。

漏れているかもしれませんが、以下のAPIや機能をまずは把握しました。
まずはTrailheadを実施して概要把握しましょう。分からない所はHelpで。

API及び機能 TrailheadまたはHelp
SOAP API Trailhead
Help
詳細記事
REST API Trailhead
Help
詳細記事
BULK API Trailhead
Help
詳細記事
ストリーミングAPI Trailhead
Help
詳細記事
コールアウト Trailhead
Help
カスタムApexサービス Trailhead
Help(SOAP) Help(REST)
プラットフォームイベント Trailhead
Help詳細記事
ワークフロー/アウトバウンドメッセージ Help
トリガー/@futureメソッド Trailhead
Help
Canvas Help
Salesforce to Salesforce Help
Salesforce Connect(Lightning Connect) Trailhead
Help
データローダ Trailhead
Help
ETL(ミドルウェア) 参考ページ
ESB(ミドルウェア) 参考ページ

何となく把握するだけではなく、以下のポイントを覚えておきましょう。
これらを把握するだけでも次に読むインテグレーションのパターンと実践の内容とリンクするので整理し易いです。

  • インバウンド連携/アウトバウンド連携なのか?
  • 同期/非同期処理なのか?
  • 通信プロトコル(SOAP/REST/BAYEUX)は?
  • 扱うデータ量はどの程度なのか?

これらの機能がどのような仕組みで、どのような場面で使用するのか、何が出来るのかを叩きこみましょう。

応用編:「インテグレーションのパターンと実践」を理解しよう

基礎知識が出来た所でいよいよ応用です。
インテグレーションのパターンと実践を一度読んでみましょう。

ここで重要なのは以下のポイントに留意しつつ、知識を以下のポイントでカテゴライズしながら読み進める事です。
カテゴライズする事でアーキテクチャを選択する際にどのカテゴライズが適しているのか
自分の頭の中から引き出しやすくなりますよ。
また、読み進める中で基礎知識を曖昧に記憶していたりする所が出てくるので、
戻りながらまた進めるという感じで繰り返しやりました。

  • 基礎知識で覚えたAPIや機能がどのパターンに該当するのか?

  • リモートプロセスの呼び出し―要求と返信

  • リモートプロセスの呼び出し―ファイアアンドフォーゲット

  • バッチデータの同期

  • リモートコールイン

  • データの変更に基づくUIの更新

  • データ仮想化

  • 推奨ソリューションの適合度は?
     最適、良い、準最適で記載されている箇所と理由。
     稀に選択肢に複数正解があり、どれが最適か考えて回答する場合もあります。
     ある程度、公式の適合度を把握していると安心ですよ。

  • エラー処理と回復方法は?
     アウトバウンドメッセージは再送処理があったり、ストリーミングAPIはアトミックIDで再取得、
     同期処理は呼び出し元がエラー回復を行うといった事を把握します。

  • 考慮事項は?
     留意すべきガバナ制限を知っておく。
     例えば、SOAP APIで取得できるレコード件数は最大2000件、更新は200件とか。

  • セキュリティ関連の考慮は?
     双方向SSLやコールアウト時はApexCryptoで暗号化するとか。
     アウトバウンドメッセージはSalesforceのIPアドレスをホワイトリストに含めるとか。

  • 各パターンでミドルウェアを利用する際に重要な要素は?
     リモートプロセスの呼び出しーファイアアンドフォーゲットはキューイングとバッファリングが重要とか。
     他にもイベント処理、同期伝送プロトコル、非同期伝送プロトコル、抽出・加工・読み込み等、どのパターンでどれが重要か。把握しましょう。

このフェーズでは、そのアーキテクチャで出来る事だけではなく、最も重要な事は何が出来ないかを把握する事!
世の中には万能なアーキテクチャは存在しません。常にトレードオフの関係性があります。
実際に業務でアーキテクチャ設計する際にもトレードオフを意識した選択が必要となります。
実際の試験も出来ない事を理解しておくことで選択肢から外せますからね。

発展編:先人達のブログを読み漁ろう

その後、Integratoin Architectureを取得した国内、国外のアーキテクチャの方々のブログを読みました。

ここでポイントなのは、先人達が記載したポイントと自分の理解が一致しているか、体系化した知識に漏れがないか確認しましょう。
知らない箇所があれば基礎知識、応用に戻りポイントを抑えましょう。
私の場合、例えば差分データバックアップのインテグレーション方法などは先人達のブログから新たな方法を知る事が出来ました。

海外記事はGoogle先生に任せて日本語訳すればそこそこ読めますよ。
ファイアアンドフォーゲット=発火と忘れ、Apex=頂点なんて翻訳になりますが笑。
一部原文の方が理解しやすいでそこは臨機応変に切り分けましょう。
情報を入手しようとした場合、やはり圧倒的に海外の方が情報量が多いので情報入手源として外さないようにしましょう。

終わりに

これらの事を繰り返し行い、合格出来ました!(コンサルタントの方が難しかったかな)

試験としては難しい問題もありますが、出来る事、出来ない事を理解していれば
すぐ解答できる問題もたくさんあります。
その手の問題を逃さないよう、しっかり基礎知識はつけておきましょう。

また、実務においても、何となくの理解から確実な理解に繋がり
このスキルが今後の提案や構築にも活きてくるかと思います。

6
7
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
6
7

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?