ヤマムギ

growing hard days.

*

Going Serverless with AWS(AWS Summit Tokyo 2017)を聞いてきました

      2017/06/04


AWS Summit Tokyo 2017でセッション「Going Serverless with AWS」を聞いてきましたのでレポートというか記録です。

聞き間違えているところとかあればご指摘いただけると幸いです。

StepFunctionsは触り始めていたのですが、SAMはこのセッションではじめて聞きまして、これは使わないとな、と。

既存の処理をそのままの単位でサーバーレスにしてもあまり恩恵もなく、もしかしたらタイムアウトに引っかかる可能性もあり。
最小単位までマイクロサービス化して疎結合にすることで、修正時の影響を極端に減らし、スケールをやりやすくする、運用や保守がなくなるわけではない。

「減るもの(OS,ミドルウェア)」よりも「増えるもの(分散化、スケール、スピード)」に対してのメリットに着目して選択するべきと思いました。

以下メモです。

サーバレスとは?

  • サーバについて考えることなくアプリケーションをデプロイして実行すること
  • よりモジュール化されたアプリケーション開発に移行している、マイクロサービス化
  • 差別化がどこで、ではなく、何をするかになってきた
  • サーバの管理や保守を取り除くだけのものではない
  • アイドリングにお金を払う必要がない
    * 日経は画像加工をLambdaですることで10分の1までコストを下げた
  • リクエスト数に応じて分散化される
  • Lambda,S3,DynamoDB,API Gateway,,,,,,,,
  • 運用の複雑を解消
  • 開発者の生産性向上
  • 価値のスピード化、差別化
  • 静的、動的webサイト、Flask , Expressのためのパッケージ
  • チャットボット、Echo用Alexa Skill

サーバレスアプリケーション

  • 既存アプリの分解
  • コンポーネント群の通信
  • サービス境界の明確化
  • Step Functions パラレル、シリアルにアクテビティを実行

ベストプラクティス

  • S3,DynamoDB,ElastiCacheでステートの外部化
  • SAMテンプレートとして関数をエクスポート
  • AWS CodePipeline + SAM
  • AWS CodeStar
  • Dead Letter Queues
  • AWS X-Ray

Canonの取り組み

課題

  • レイヤ間の複雑性が増し、密結合化
  • レイヤ間のコミュニケーションコストが増加
  • テストの増大化
  • スピード感も低下

Conwayの法則

  • 連携不可
  • 組織のあり方がシステムに反映する
  • チームがレイヤーごとに分かれていく

MicroServicesの推進

  • レイヤーが横方向に肥大化するのを縦に分割することで防ぐ
  • シンプルな構成を保ちつつ分割する

データベースも分割する

  • ドメイン駆動設計(DDD)モデリング

注意点

  • Restful , DDDの視点で設計する
  • デプロイ自動化
  • 密結合しないように疎結合する

メリット

  • コード量、テスト工数、開発工数、運用、など様々な工数を削減できた
  • 組織、システムの硬直化、密結合を防げた

最後までお読みいただきましてありがとうございました!

【PR】 「AWS認定試験対策 AWS クラウドプラクティショナー」という本を書きました。

【PR】 「AWSではじめるLinux入門ガイド」という本を書きました。

i

【PR】 「ポケットスタディ AWS認定 デベロッパーアソシエイト」という本を書きました。

 - AWS , ,

ad

ad

  関連記事

Amzon Linux のApacheでRedmineとWordPressをバーチャルホストで共存する

EC2とRDSを節約しようと思いまして、Redmineを動かしてるとこに検証用W …

EC2 Instance Connect向けのセキュリティグループのソースにプレフィックスリストを

EC2 Instance Connect、便利ですね。 キーペア不要で、EC2イ …

Amazon EMR 「Hadoop を使用してビッグデータを分析」チュートリアルをやってみました

AWS認定データアナリティクス受験準備の一環で、Amazon EMRのチュートリ …

AWS AmplifyでTodoアプリを作るハンズオンをやってみました

【お手軽ハンズオンで AWS を学ぶ】AWS Amplify で Todo アプ …

Amazon Pinpoint Workshopの1(Eメール)

Amazon Pinpoint Workshop ここ数年、AWS re:Inv …

webフォームからの問い合わせをRedmineに自動登録して対応状況を管理する(API Gateway + Lambda)

先日、検証目的で作成したRedmineの冗長化の一機能として、webフォームから …

S3 VPCエンドポイント設定前と設定後を確認

S3のVPCエンドポイントを設定した際に、S3バケットのAPIエンドポイントへの …

API Gateway 作成済REST APIの定義をSwaggerの形式でエクスポート

SAMで似たようなAPIを作りたくて、エクスポートしました。 Swaggerは、 …

AWS Toolkit for Eclipseをセットアップする

AWSでそろそろ課金がされつつありますので、夜中はインスタンスを自動停止して朝自 …

AWS LambdaでS3 Select

RDSスナップショットをS3にエクスポートした、Parquetフォーマットのデー …