Where do you get Google Bigquery usage info (mainl

2020-08-19 07:30发布

问题:

I know that BigQuery offers the first "1 TB of data processed" per month for free but I can't figure out where to look on my dashboard to see my monthly usage. I used to be able to "revert" to the old dashboard which had the info but for the past couple of weeks the "old dashboard" isn't accessible.

回答1:

From the Google Cloud Console overview page for your project, click on the "details" section on the top-right, next to the charge estimate :

You'll get an estimate of the charges for the current month for each service and item in the service, including Big Query analysis :

If you want to track this usage, you can also export the data into CSV every day by going in the Billing settings and enable the usage export feature. Do not worry about the fact that it only mentions Compute Engine, it actually works for other services also.

You can also access directly the billing history by clicking on the billing account link :

You will get a detailed bill with the usage info :



回答2:

Post GCP Console Redesign Answer

The GCP console was redesigned and now the other answer here no longer applies, but it is still possible to view your usage by going to IAM & Admin -> Quotas.

What you're looking for is "Big Query API: Query usage per day". It doesn't seem possible to view your usage over 30 days unfortunately, but you can see your current usage (per day) and your peak usage over the past 7 days. You can also set a daily quota. If you're just working infrequently or doing a lot in one day, you can set a quota to 1 TiB and prevent yourself from blowing your whole allocation in one day.

You can try sending feedback about these limitations, like I did, by clicking the question mark at the top right and then send feedback.



回答3:

Might be related to How can I monitor incurred BigQuery billings costs (jobs completed) by table/dataset in real-time?

If you are fine by using BigQuery itself to get that information (instead of using a UI), you can use something like this:

DECLARE gb_divisor INT64 DEFAULT 1024*1024*1024;
DECLARE tb_divisor INT64 DEFAULT gb_divisor*1024;
DECLARE cost_per_tb_in_dollar INT64 DEFAULT 5;
DECLARE cost_factor FLOAT64 DEFAULT cost_per_tb_in_dollar / tb_divisor;

SELECT
 ROUND(SUM(total_bytes_processed) / gb_divisor,2) as bytes_processed_in_gb,
 ROUND(SUM(IF(cache_hit != true, total_bytes_processed, 0)) * cost_factor,4) as cost_in_dollar,
 user_email,
FROM (
  (SELECT * FROM `region-us`.INFORMATION_SCHEMA.JOBS_BY_USER)
  UNION ALL
  (SELECT * FROM `other-project.region-us`.INFORMATION_SCHEMA.JOBS_BY_USER)
)
WHERE
  DATE(creation_time) BETWEEN DATE_SUB(CURRENT_DATE(), INTERVAL 30 DAY) and CURRENT_DATE()
GROUP BY 
  user_email
  • Open in BigQuery UI
  • Explanation
  • Please consider the caveats I mentioned in my answer here