$30 off During Our Annual Pro Sale. View Details »

Go x AWSによるシンプルなサーバーレス実装

yukpiz
March 27, 2019

Go x AWSによるシンプルなサーバーレス実装

シューマイGo編の発表資料です。
登壇用とは別に読みやすいように間のスライドを省きました。

yukpiz

March 27, 2019
Tweet

More Decks by yukpiz

Other Decks in Technology

Transcript

  1. Go x AWSによる
    シンプルなサーバーレス実装
    Written by @yukpiz
    Mar 27, 2019
    #shuuumai #golang

    View Slide

  2. Who?
    Yuuki Zayasu(@yukpiz)
    リディッシュ株式会社 テックリード
    #golang #aws #engineers_lt(エンジニアの登壇を応援する会)
    釣り
    スノボ
    小型船舶操縦士1級
    第二種電気工事士
    生コン打設
    養鶏
    野菜栽培

    View Slide

  3. Who?
    Please follow me!
    @yukpiz
    https://labo.yukpiz.me

    View Slide

  4. Go言語への入り口
    Go言語
    触ったことありますか?

    View Slide

  5. Go言語への入り口
    Go言語に興味を持っている、もしくは普段使っている皆さんに
    少しでも知らなかった事を知って欲しい
    AWSと簡単に組み合わせて
    様々な使い方ができる事を知ってほしい
    是非、持ち帰って自分でGo言語を触ってみるキッカケにして欲しい

    View Slide

  6. Go言語への入り口
    コマンドラインツールを作る(urfave/cli等)
    A Tour of Goをやる(https://go-tour-jp.appspot.com/)
    Webフレームワークを使ってWebサイトを作る(gin, echo等)
    AWSを組み合わせてサービスを作ってみる(New!)
    DynamoDB, Lambda, SQS, API Gateway, ECS/EKS, EC2, etc...

    View Slide

  7. Go言語への入り口
    AWS Lambda

    View Slide

  8. Go言語への入り口
    機能を実装してクラウド上で実行可能(FaaS)
    Go言語(1.x Runtime)が使える
    様々なAWSの各種サービスと連携が可能
    API Gateway AWS IoT Alexa Skills Kit
    Alexa Smart Home Application Load Balancer CloudWatch Events
    CloudWatch Logs CodeCommit Cognito Sync Trigger
    DynamoDB Kinesis S3
    SNS SQS + Invoke Lambda

    View Slide

  9. 活用事例

    View Slide

  10. 活用事例
    サービス内メッセージの一斉配信サービス
    レストランに関連するデータの収集サービス
    SendGridを使ったメール配信サービス
    ...etc

    View Slide

  11. 活用事例
    配信予定時刻に処理を開始
    SQSで一定速度でLambdaに排出
    配信処理を担うLambda
    ユーザーの端末へ
    処理に失敗した配信レコード

    View Slide

  12. 活用事例
    各種サービスの制限について
    サービスごとに制限項目がある
    Lambdaなら実行時間や同時実行数など
    他のサービスと連携させる場合、その考慮も必要
    詳細は各種サービスのドキュメントに記載がある
    以下はLambdaの制限事項ドキュメント
    https://docs.aws.amazon.com/ja_jp/lambda/latest/dg/limits.html

    View Slide

  13. Go × Lambdaへの入り口
    デプロイツールの選定(Apex, Lamvery, Serverless Framework)
    実装したLambda関数をツールを使ってアップロードする
    LambdaはApex、それ以外のサービスはterraformに一元化
    関数の実装

    View Slide

  14. Go × Lambdaへの入り口
    必要なのは2パッケージ
    Lambda実行時に呼び出される関数
    発火元から受け取るイベント引数
    処理結果を返す
    errorインターフェース型

    View Slide

  15. Go × Lambdaへの入り口
    デプロイツールの選定(Apex, Lamvery, Serverless Framework)
    実装したLambda関数をツールを使ってアップロードする
    LambdaはApex、それ以外のサービスはterraformに一元化
    関数の実装
    Handlerの引数で受け取れるイベントはgodocで確認できる
    https://godoc.org/github.com/aws/aws-lambda-go/events
    AWSの各種サービスとの連携

    View Slide

  16. Go × Lambdaへの入り口
    Lambdaの発火元

    View Slide

  17. その他の用途
    BOTを作ってみよう!
    Slack BOTやTwitter BOTで遊んでみる
    API Gatewayと連携して、Webhook駆動のBOT
    Cloudwatchと連携して、定期実行するBOT

    View Slide

  18. 最後に
    Go言語入門の選択肢にAWS Lambdaを!
    連携できるサービスを組み合わせて、簡単に作ろう
    仕事じゃなくても、まずはプライベートの簡単なツールから!
    こういうのも作れそうとか面白いアイデア、是非教えてください

    View Slide

  19. Written by @yukpiz
    Mar 27, 2019
    #shuuumai #golang
    Slides Policy
    The Go gopher was designed by Renée French.
    #f3f3f3
    #434343 #da6272

    View Slide