Serverless Scala
by
arai-yusuke
Link
Embed
Share
Beginning
This slide
Copy link URL
Copy link URL
Copy iframe embed code
Copy iframe embed code
Copy javascript embed code
Copy javascript embed code
Share
Tweet
Share
Tweet
Slide 1
Slide 1 text
SERVERLESS SCALA Lightweight Use Of Scala On AWS Yusuke A. / Classmethod, Inc.
Slide 2
Slide 2 text
WHOAMI Yusuke Arai Server App Programmer / AWS Solutions Architect http://dev.classmethod.jp/author/arai-yusuke/
Slide 3
Slide 3 text
クラスメソッドでは、iOS / Android ネイティブアプリの 受託開発を行っています。 バックエンドチー ムは、 アプリのバックエンドになる API サー バー の開発を行います。API サー バー は、AWS 上 で動作するPlay Scala アプリとして開発されます。
Slide 4
Slide 4 text
クラスメソッドのバックエンドチー ムは、 普段Play や Akka などのエコシステムやDDD の手法を用いた開発を行 っています。 ですが、 今日はその話ではなく……
Slide 5
Slide 5 text
Scala を始めるにあたって壁になりがちな" ある部分" を サクっと乗り越えるためのお話をします。
Slide 6
Slide 6 text
SCALA 初学者のぶつかる壁( 例) エコシステム(Play) が関数型の語法を用いる JSON Reads / Writes (Type class, Applicative) Iteratee / Enumerator 初学者に優しくないSlick3 のモナり具合 JVM アプリについて学ぶ必要がある DevOps はElastic Beanstalk やHeroku ならある程度は ラップされているけど、 あくまで「 ある程度」 であ って、 程なくしてJVM への理解を要求される。 公開したいならEC2 なりVPS なりのリソー スが必要
Slide 7
Slide 7 text
SCALA 初学者が本当に思っていること はわからないので、 自分が初学者の頃に感じていたこと 言語を学んだは良いが何をすればいいのかわからない 何をしようと思っても難易度が高い Rails のような親しみ安さがない 取り敢えず何か小さいアプリ作ってみたい そしてそれをサクッと公開してみたい
Slide 8
Slide 8 text
突然ですが、AWS Lambda をご存知ですか?
Slide 9
Slide 9 text
AWS LAMBDA Function as a Service 実行可能なコー ドを用意してLambda Function を作成 イベントソー ス( 着火剤) を用意し、Function を実行 処理結果を受け取ることができる (AWS ネイティブ的に使おうとするならもっと色々 機能があります!)
Slide 10
Slide 10 text
AWS LAMBDA の特徴 実行リクエスト秒数とリクエスト数に対する課金 待機時間にはお金がかからない EC2 だとt2.micro 一ヶ月で15$ 前後かかる Lambda なら使われなければお金はかからない さらにAWS の無期限無料枠がある 100 万リクエスト/ 月まで無料 最大で320 万秒コンピュー ティング時間/ 月まで無料
Slide 11
Slide 11 text
突然ですが、Amazon API Gateway をご存知ですか?
Slide 12
Slide 12 text
AMAZON API GATEWAY 複数のバックエンドリソー スをIntegrate してREST API としてHTTPS で公開できる バックエンドリソー スとして以下が利用可能 AWS Lambda その他のアプリケー ション(HTTP) モック AWS Lambda がバックエンドリソー スとして扱えるこ とが大きなポイントで、 これによってEC2 なしでも標 準的なREST API が構築可能となった。
Slide 13
Slide 13 text
AWS Lambda は Node, Python, Java で動きます。
Slide 14
Slide 14 text
Scala でも動きます。
Slide 15
Slide 15 text
百聞は一見に如かず、 ですよね?
Slide 16
Slide 16 text
Live Coding & Demo code are also available at GitHub Repo https://github.com/kawashirosan/scala-fukuoka-lambda
Slide 17
Slide 17 text
続くみなさんのセッションで学ぶことを生かしつつ よく利用するチャットツー ル(Typetalk, Slack, LINE, chatwork, etc) とのインテグレー ションをサクッと作っ てみると、 きっと楽しいと思います!
Slide 18
Slide 18 text
デモが終わって時間があれば触れたいこと Apex AWS Lambda のデプロイ管理ツー ル。Golang 製 サー バー レスアー キテクチャの利点 フルマネー ジドなら可用性を考えなくていい サー バー レスアー キテクチャでの永続化層 フルマネー ジドならDynamoDB Lambda VPC を使うならRDS, Elasticache, and so on サー バー レスアー キテクチャの未来 大規模アプリを作る妄想をする Micorservices の先で、 モノリシックの対極 現時点では難易度かなり高く現実的ではない
Slide 19
Slide 19 text
今日のまとめ AWS Lambda / Amazon API Gateway を使ったサー バー レス環境で、 手軽に・ 安く・ 明日から稼働するアプリ をScala で作ってみよう! Scala アプリ開発の学習環境としても、 個人~ 小規模ア プリのデプロイ先としても、AWS Lambda / API Gateway はおすすめできます。 Scala にもサー バー レスアー キテクチャにも興味を持っ ていただけたら、 そして身近に感じていただけたら嬉 しいです
Slide 20
Slide 20 text
ご清聴ありがとうございました。 Demo code are available at GitHub Repo https://github.com/kawashirosan/scala-fukuoka-lambda