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
120
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
T3 Stack(応用編: Next Auth & SSRの実装紹介)
wheatandcat
1
29
App Routerの紹介
wheatandcat
0
17
Flutter × GraphQLでアプリを作ってみる
wheatandcat
0
38
T3 Stack + Supabaseでアプリを作ってみる
wheatandcat
0
83
Supabaseの紹介
wheatandcat
0
88
tRPCの紹介
wheatandcat
0
73
Plasmoの紹介
wheatandcat
0
48
Playwrightの紹介
wheatandcat
0
110
Vitestの紹介
wheatandcat
1
82
Other Decks in Programming
See All in Programming
データアナリストが行うDatabricksを活用したETLの自動化事例
shinoa
0
240
プールにゆこう
irof
2
120
Rails と人魚の話/rails-and-mermaid
sanfrecce_osaka
0
100
9年開発を牽引して見えてきた、共通化すべきものと個別でつくるもの ~プログラム言語~
shinout
1
640
Front-end application development, Symfony-style(s)
dunglas
2
1.9k
スクラムチームと認知負荷 - ニフティのスクラムトーク Vol2. / NIFTY Tech Talk #18
niftycorp
PRO
1
120
Zero Waste, Radical Magic, and Italian Graft – Quarkus Efficiency Secrets
hollycummins
0
200
DDDはなぜ難しいのか / 良いコードの定義と設計能力の壁
pospome
28
10k
Designing for tomorrow's programming workflows
honnibal
PRO
2
110
코틀린으로 멀티플랫폼 만들기
pangmoo
0
110
二郎系ラーメンのコールで学ぶ AST 解析
memory1994
PRO
7
1.6k
チーム力を高めるスクラム実践法:カンバン公開と課題攻略について - ニフティのスクラムトーク Vol. 2 - NIFTY Tech Talk #18
niftycorp
PRO
1
110
Featured
See All Featured
Designing Experiences People Love
moore
135
23k
A Tale of Four Properties
chriscoyier
150
22k
Producing Creativity
orderedlist
PRO
336
39k
What's in a price? How to price your products and services
michaelherold
237
11k
Optimising Largest Contentful Paint
csswizardry
7
2.3k
The Cult of Friendly URLs
andyhume
73
5.6k
Design and Strategy: How to Deal with People Who Don’t "Get" Design
morganepeng
114
18k
Atom: Resistance is Futile
akmur
258
25k
Practical Orchestrator
shlominoach
180
9.7k
CoffeeScript is Beautiful & I Never Want to Write Plain JavaScript Again
sstephenson
153
14k
Fight the Zombie Pattern Library - RWD Summit 2016
marcelosomers
226
16k
5 minutes of I Can Smell Your CMS
philhawksworth
199
19k
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
は、まだプレビューの状態なので注意
ご清聴ありがとうございました