Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
Cloud Runの紹介
Search
Yohei Iino
July 19, 2022
Programming
0
130
Cloud Runの紹介
- Cloud Runの紹介
- GAE→Cloud Runへの移行
- Cloud Run Jobsの紹介
Yohei Iino
July 19, 2022
Tweet
Share
More Decks by Yohei Iino
See All by Yohei Iino
作成中のFlutterアプリの中間発表
wheatandcat
0
5
最近読んだ技術書を簡単紹介
wheatandcat
0
17
ユニバーサルリンク/アプリリンクを使ってQRコードでゲストログインできるようにする
wheatandcat
0
8
Firebase App Checkを実装したので紹介
wheatandcat
0
14
PlanetScaleの無料プランがなくなるので、NeonとTiDBを試してみた
wheatandcat
0
120
Flutter HooksとRiverpodの解説
wheatandcat
0
180
T3 Stack(応用編: Next Auth & SSRの実装紹介)
wheatandcat
1
200
App Routerの紹介
wheatandcat
0
56
Flutter × GraphQLでアプリを作ってみる
wheatandcat
0
210
Other Decks in Programming
See All in Programming
みんなでプロポーザルを書いてみた
yuriko1211
0
260
Make Impossible States Impossibleを 意識してReactのPropsを設計しよう
ikumatadokoro
0
170
Realtime API 入門
riofujimon
0
150
役立つログに取り組もう
irof
28
9.6k
CSC509 Lecture 12
javiergs
PRO
0
160
LLM生成文章の精度評価自動化とプロンプトチューニングの効率化について
layerx
PRO
2
190
Better Code Design in PHP
afilina
PRO
0
120
Enabling DevOps and Team Topologies Through Architecture: Architecting for Fast Flow
cer
PRO
0
320
A Journey of Contribution and Collaboration in Open Source
ivargrimstad
0
890
3 Effective Rules for Using Signals in Angular
manfredsteyer
PRO
0
100
TypeScriptでライブラリとの依存を限定的にする方法
tutinoko
2
660
macOS でできる リアルタイム動画像処理
biacco42
9
2.4k
Featured
See All Featured
Testing 201, or: Great Expectations
jmmastey
38
7.1k
CSS Pre-Processors: Stylus, Less & Sass
bermonpainter
356
29k
How to Create Impact in a Changing Tech Landscape [PerfNow 2023]
tammyeverts
47
2.1k
GraphQLとの向き合い方2022年版
quramy
43
13k
Design and Strategy: How to Deal with People Who Don’t "Get" Design
morganepeng
126
18k
Large-scale JavaScript Application Architecture
addyosmani
510
110k
ピンチをチャンスに:未来をつくるプロダクトロードマップ #pmconf2020
aki_iinuma
109
49k
How to Ace a Technical Interview
jacobian
276
23k
Principles of Awesome APIs and How to Build Them.
keavy
126
17k
Templates, Plugins, & Blocks: Oh My! Creating the theme that thinks of everything
marktimemedia
26
2.1k
jQuery: Nuts, Bolts and Bling
dougneiner
61
7.5k
"I'm Feeling Lucky" - Building Great Search Experiences for Today's Users (#IAC19)
danielanewman
226
22k
Transcript
Cloud Run の紹介 Press Space for next page
自己紹介 📝 飯野陽平(wheatandcat ) 🏢 フリーランスエンジニア(シェアフル株式会社CTO ) 💻 Blog: https://www.wheatandcat.me/
🛠 今までに作ったもの memoir ペペロミア Atomic Design Check List
Cloud Run とは Cloud Run は、スケーラブルなインフラストラクチャ上でコンテナを直接実行できるマネー ジド コンピューティング プラットフォーム。 コンテナ
イメージをビルドしてデプロイして使用できる。 構成、スケーリングは設定で即座に変更可能。
実行形式 Cloud Run には以下の2 つの実行形式がある Cloud Run Service 主な用途: API
サーバー、web サイト、イベント処理 できること 自動スケーリング、各種スケーリングの設定 Cloud Run Jobs 主な用途: バッチ処理、ツール Cloud Run Service との差は以下の通り 設定タイムアウトの時間を最大1 時間まで設定可能 最大再試行回数を設定できる 並列処理
Cloud Run の使い方 Cloud Run では以下の2 つの方法でコンテナイメージの作成が可能。 Dockerfile を使用する Buildpacks
を使用する
Buildpacks とは Buildpacks は、ソースコードから読み取りベストプラクティスに則ってDockerfile を書かずにイメージを生成 してくれるツールで、現状だと以下のプラットフォームで対応している。 Go Node.js Python Java
.NET Core Learn More
Cloud Run Service をデプロイしてみる① 以下のチュートリアルをベースに、デプロイを紹介 Cloud Run に Go サービスをデプロイする
Cloud Run Service をデプロイしてみる② 以下のコマンドでイメージを作成 上記で、GCP のArtifact Registry にイメージが作成されるので、以下のコマンドでCloud Run
にデプロイ Learn More $ gcloud builds submit --pack image=IMAGE_URL $ gcloud run deploy $SERVICE_NAME \ --project=$PROJECT_ID \ --image=$IMAGE_URL \ --region=$REGION
環境変数の設定 環境変数の設定はコンソールから設定可能 環境変数の設定 環境変数で機密情報を設定する場合はSecret Manager の値をマウントできる。 シークレットを使用する
継続的デプロイの方法 GitHub Actions を使用して実装したので紹介 ▪ Cloud Run へ移行 https://github.com/wheatandcat/memoir-backend/pull/117/files
Cloud Run Jobs を試してみる① 以下のチュートリアルをベースに紹介 Cloud Run で Go ジョブをビルドして作成する
Cloud Run Jobs を試してみる② 以下のコマンドでイメージをデプロイ 以下のコマンドで作成したコンテナを使用してジョブを作成する 以下のコマンドで実行 $ gcloud builds
submit --pack image=gcr.io/PROJECT_ID/logger-job $ gcloud beta run jobs create $JOB_NAME \ --image gcr.io/PROJECT_ID/logger-job \ --tasks 50 \ --set-env-vars SLEEP_MS=10000 \ --set-env-vars FAIL_RATE=0.5 \ --max-retries 5 \ --region REGION $ gcloud beta run jobs execute $JOB_NAME
Cloud Run Jobs を試してみる③ 結果は、コンソールで確認できる
並列実行 以下の記事を元に紹介 Cloud Run jobs を解説する
Cloud Scheduler にJob を設定する 以下のチュートリアルをベースに紹介 スケジュールに従ってジョブを実行する URL には以下を設定する https://REGION-run.googleapis.com/apis/run.googleapis.com/v1/namespaces/PROJECT-ID/jobs/JOB-NAME:run
まとめ GCP の推しているサービスなだけあってスキの無い作りだった Cloud Run Jobs の登場でバッチ処理もカバーできるようになった Cloud Run Jobs
は、まだプレビューの状態なので注意
ご清聴ありがとうございました