17
2

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 3 years have passed since last update.

LIFULLその2Advent Calendar 2020

Day 3

カスタムコスト管理を設定してBigQueryを安心して使おう

Last updated at Posted at 2020-12-03

#はじめに
こんにちは!
世界中のあらゆる「LIFE」を、安心と喜びで「FULL」にする
LIFULLのエンジニアの高澤です。

数あるクラウドサービスの中でも私が最も推しているサービスが、GCPのBigQuery。LIFULL社内でもログ分析や集計目的など広く使われています。
はやい、安い、うまい、のこのサービスですが、
従量課金であること、課金の仕組みがややわかりにくいことで、敬遠している方もいるでしょう。
恐る恐る触っている人も結構いるのではないでしょうか。

そんな方にも「安心」してBigQueryを使ってもらうために、
カスタムコスト管理による従量課金制限の仕方を紹介します。

#BigQueryの課金について
BigQueryの課金のほとんどはクエリ実行による従量課金です。
課金については別の記事で説明書いているのでそちらをみていただくと
ざっくりとした全体感がわかると思います。
気になる人はぜひ読んでみてください。

Qiita: BigQueryの課金についてざっくり5分で理解する
https://qiita.com/laha/items/60c5a6fdd0696027a5a9

#カスタムコスト管理って?
GCPのAPIには利用量やリクエスト数の割り当てを制限することができる機能があります。
BigQueryもこの割り当てを制限することで課金上限を超えるクエリの実行を制限することができます。
https://cloud.google.com/bigquery/docs/custom-quotas?hl=ja

##主な設定の種類
####プロジェクトレベルでの制限
設定できる制限は全ユーザーの利用量の合計

  • プロジェクト単位で利用できる1日あたりの合計クエリ量で制限
  • プロジェクト単位で利用できる1日あたりの合計リクエスト数で制限

####ユーザーレベルでの制限
設定できる制限はユーザー単位での利用量の合計

  • プロジェクト内でユーザー単位で利用できる1日あたりの合計クエリ量
  • プロジェクト内でユーザー単位で利用できる1日あたりの合計リクエスト数

#カスタムコストの設定方法
ここでは利用用途が一番多い、クエリ量の割り当てについて設定方法を紹介していきます。

###1. GCPコンソールのダッシュボードを開く
ダッシュボードにアクセスします
https://console.cloud.google.com/home/dashboard
この時、設定したいプロジェクトを選択しておく

###2. 左上のナビゲーションメニューから > 管理 > 割り当てを選択する
管理が見つからない場合は「IAMと管理」 > 「割り当て」を選択する

スクリーンショット 2020-12-03 21.30.36.png

###3. APIの一覧からBigQueryAPIを選択する

サービスでフィルタすると見つけやすいです
スクリーンショット 2020-12-03 21.33.24.png

bigqueryをキーワードに指定し、BigQuery APIを選択
スクリーンショット 2020-12-03 21.33.43.png

###3. 上限名 「Query usage /日」「Query usage /日 /ユーザー」をそれぞれ選択し、グローバルにチェックを入れる
スクリーンショット 2020-12-03 21.34.54.png

スクリーンショット 2020-12-03 21.34.29.png

スクリーンショット 2020-12-03 21.34.39.png

###4. 「割り当てを編集」をクリック
ページ上部の割り当てを編集をクリックする
スクリーンショット 2020-12-03 21.35.05.png

###5. リクエスト先を確認し、自分の連絡先を入力
リクエスト先にBigQuery管理者の氏名とメールアドレスが表示される。
一番したの欄に自分の連絡先を入力し、次へ

###6. それぞれのQuery制限に割り当て上限を設定する
Query usage/日 はプロジェクト全体での上限
Query usage /日 /ユーザー はユーザー毎の上限

スクリーンショット 2020-12-03 21.36.31.png
単位はTiB。小数点で入力することでGiB単位の制限も可能

###7. 割り当て変更後を確認
この時、削減量が大きいと警告が出るのでよく確認して次に進む
スクリーンショット 2020-12-03 21.37.14.png

###8. 割り当て完了
お疲れ様でした。設定値が最後に表示されるので確認して設定完了です。
スクリーンショット 2020-12-03 21.37.38.png

#制限後の動作を確認してみる

####制限を超えるクエリ処理量を処理しようとすると
スクリーンショット 2020-12-03 20.48.42.png

####カスタム割り当てを超えて実行できないエラーメッセージが表示される
スクリーンショット 2020-12-03 20.49.37.png

#制限のリセットについて
日単位での制限を設定しましたが、リセットされるのは太平洋標準時の0時だそうです。
日本時間に換算すると 17時くらいですね。
上の例で言うと10GiBいっぱいまで利用して制限かかっても17時でリセットされ、また10GiB分使えるようになります。

#最後に
いかがでしたでしょうか。
制限をつけることで意図せず高額な請求を防げるので、だいぶ気軽に安心してBigQueryを利用できるようになったかと思います。
ぜひカスタムコスト管理を設定の上、BigQueryをどんどん利用していってください。

そういえば LIFULL AdventCalendarその1の方でもBigQuery利用した記事のようです。
よかったらそちらもどうぞ

LIFULL AdventCalendarその1
https://qiita.com/advent-calendar/2020/lifull

LIFULL AdventCalendarその2
https://qiita.com/advent-calendar/2020/lifull2

17
2
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
17
2

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?