Create a cost estimate report
Introductionโ
Infracost is a tool that enables developers to analyze their cloud cost estimates using their Terraform templates. Nebari wraps the infracost
command-line interface, which is free and open-source, to provide cost estimates for your Nebari deployments across major cloud providers.
In this tutorial you'll learn to generate a cost report for your Nebari deployment, which you can share with other users and groups through an Infracost link. You will also be looking into how Infracost can be configured on your local machine.
Infracost natively supports Amazon Web Services, Azure, and Google Cloud Platform. For this tutorial, we will be using the Google Cloud Platform (GCP) deployment to generate the cost report.
Step 1- Setting up Infracostโ
To install the
infracost
command-line interface, run the following command on your terminal:curl -fsSL https://raw.githubusercontent.com/infracost/infracost/master/scripts/install.sh | sh
The script downloads the CLI based on your operating-system/architecture and installs it under
/usr/local/bin
.After installation, you can verify
infracost
was successfully installed via the following command:infracost --version
Next, you'll need to configure the API key for Infracost to enable generating cost reports and dashboards. Nebari's cost estimate feature requires this API key. To generate the key, run the following command on your terminal:
infracost register
You will then need to validate your API key with the following command:
infracost configure get api_key
You are now ready to run the cost estimate tool.
Step 2 - Generating the cost estimatesโ
To generate the cost estimate, run the following command:
nebari cost-estimate
The Nebari cost estimate tool will look for the stages
directory within your deployment file structure and analyze the Terraform templates to generate a cost report. It will consist of two tables describing the cost and resources breakdown, a publicly-accessible Infracost dashboard URL, and additional documentation on the edge cases that the cost estimate tool currently misses.
The report should look something like this:
Cost Breakdown
โโโโโโโโโโโโโโโโโโโโโโณโโโโโโโโโโโ
โ Name โ Cost ($) โ
โกโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโฉ
โ Total Monthly Cost โ XX โ
โ Total Hourly Cost โ XX โ
โโโโโโโโโโโโโโโโโโโโโโดโโโโโโโโโโโ
Resource Breakdown
โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโณโโโโโโโโโ
โ Name โ Number โ
โกโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโฉ
โ Total Detected Costs โ X โ
โ Total Supported Resources โ X โ
โ Total Un-Supported Resources โ X โ
โ Total Non-Priced Resources โ X โ
โ Total Usage-Priced Resources โ X โ
โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโดโโโโโโโโโ
Access the dashboard here:
https://dashboard.infracost.io/share/XXXXXXXXXX
Nebari relies upon node pools which is a usage resource that doesn't get captured in
the above report. A general node pool will always have one node running will add
an additional charge. Please check with your cloud provider to see the
associated costs with node pools.
โข Total Monthly Cost: The total monthly cost of the deployment of supported
resources.
โข Total Hourly Cost: The total hourly cost of the deployment of supported
resources.
โข Total Detected Costs: The total number of resources detected by Infracost.
โข Total Supported Resources: The total number of resources supported by
Infracost.
โข Total Unsupported Resources: The total number of resources unsupported by
Infracost.
โข Total Non-Priced Resources: The total number of resources that are not
priced.
โข Total Usage-Priced Resources: The total number of resources that are priced
based on usage.
You can share the URL of your Infracost dashboard https://dashboard.infracost.io/share/XXXXXXXXXX
across your team for better insights into your cloud costs breakdown.
note
The Infracost dashboards are enabled by default for users. This is done via the Infracost's INFRACOST_ENABLE_DASHBOARD
environment variable, which is set true
by default.
You can run the Nebari cost estimate tool outside your Nebari directory by specifying the location of your deployment's stages directory:
# where your deployment stage directory is <path-to-stages>
nebari cost-estimate --path=<path-to-stages>
A note on node pools costsโ
The cost estimate report is statically analyzed via Terraform templates stored in the stages
subdirectory. The actual cloud costs are subject to change. Nebari relies upon node pools, a useful resource that doesn't get captured in the above report. A general node pool will always have one node running - which incurs in an additional cost.
For example, using a m5.2xlarge
instance type on AWS for the general node pool (currently the default) will cost $276.84 additional per month. Please check with your cloud provider to see the associated costs with node pools.