Getting Started with Grafana

in Visualization , Monitoring and Observability

Getting Started with Grafana .jpg

Grafana is an open-source platform for monitoring and observability. It allows you to query, visualize, alert on and understand your metrics no matter where they are stored.

    Grafana is an open-source platform for monitoring and observability. It allows you to query, visualize, alert on and understand your metrics no matter where they are stored. Create, explore, and share dashboards with your team and foster a data driven culture. This article will outline how to install Grafana on your own. If you're looking to try it out without much setup, or if you're looking for industrial level service, start our free trial and get your dashboards up and running in minutes.

    But what do I use it for?

    Grafana helps you visualize metrics, send alerts and understand the metrics from various data sources with its plugin architecture. Let’s look at a few use cases. You can ...

    1. Visualize the machine’s CPU, memory, network and other resource utilization with Prometheus and Grafana.
    2. Visualize and alert for high number of incoming web requests in your web app.
    3. Monitor the health of the components of your platform like APIs, frontend apps, databases etc.

    And many more …

    Get Grafana up and running

    Grafana can be installed on various platforms using native packages. Here we will install it using Docker. Put GF_SECURITY_ADMIN_PASSWORD as the admin password you want to set at the time of installation (Don’t worry you can change it after the installation). Set GF_SERVER_ROOT_URL appropriately depending upon your reverse proxy or ingress configuration. Full configuration example can be found here.

    docker run \
    -d \
    -p 3000:3000 \
    --name=grafana \
    -e "GF_SERVER_ROOT_URL=http://localhost:3000" \

    For simplicity we are setting it to localhost. After running the command above you can open http://localhost:3000 in your browser and login with username admin and password set above.

    Grafana Dashboard.png

    Understanding Grafana

    Now that we have things up and running, let's understand the basic concepts of Grafana.

    Data Sources

    This is the most fundamental and important component responsible for pulling the data out of third party like Prometheus, Elasticsearch, Cloudwatch, Graphite, InfluxDB etc.

    Dashboards and Widgets

    A widget is a simple visualization panel for a single set of multiple metrics. There are many widgets like graphs, logs list, tables, heatmaps, singlestat and many more available through plugins. 

    A dashboard is a group of widgets, but it provides a lot more features like folders, variables (for changing visualizations throughout widgets), time ranges, and auto refresh of widgets.


    Grafana supports alerting on individual widgets based on rules defined by the user. Alerts can be sent to different channels, including Microsoft teams, Slack, email, Webhooks and PagerDuty.


    Plugins can be used to extend Grafana’s existing functionality, or add new data sources and widget types, which makes Grafana really extensible. Checkout the official plugin repository and instructions on how to install.


    Grafana provides user management with user permissions like editor, viewer or admin.

    Creating your first dashboard on Grafana

    Now that we know a bit about Grafana let’s create a dashboard on Grafana. For simplicity of not setting up more infrastructure we will use TestData data source from Grafana.

    Go to the plus icon on the left side on the homepage and create a dashboard with name Test Data Dashboard. Add a new panel and add a query.

    Test Data Dashboard.png

    Click on the query icon on left and add a default source (which is Grafana), it will add a random walk graph. 

    To customize the visualization click on the visualization icon and select graph type. There are several other options like line width, color, stacking etc. There are other types of visualizations such as Tables, Single Stats, Gauge etc. 

    Save the graph. It should look something like below.

    Test Dashboard 2.png

    Setting up alerts

    Visualizing metrics are really useful but nobody will be able to sit at a computer watching a dashboard 24/7!!! Alerts help to inform about critical metrics such as high memory usage. 

    Let’s set up a Slack alert on the dashboard we just built. Click on Alerting in the homepage and go to notification channels and add a new notification channel for slack, it requires credentials, slack channel name and username.

    PS: Test Data Source of Grafana does not support alerting.

    New notification channel.png

    After setting up an alert destination we will go to the widget’s alert icon to setup the alerts.


    We will setup the condition, i.e. if the average value in a 1 min time range is greater than 10 it will fire the alert. We also select where these alerts should be sent to, in this case it’s being sent to the Metricfire slack that we just added. There is a text field available to add any text that is related to these alerts, which can be added as template.

    Where to go from here 

    Congratulations!!! You have your first monitoring dashboard with Alerting set up. Now, there’s lots of things we can explore further about Grafana!

    Production setup

    General production setup is done with either k8s or docker swarm for high availability, since this is critical to monitoring. 

    A k8s deployment can be done via prometheus operator’s helm chart. This deploys complete prometheus + Grafana stack with pre-built k8s monitoring dashboards and alerts. 

    Common Patterns

    Grafana + Prometheus = ❤️. This is the most common combination for metrics reporting and alerting. Grafana is a great visualization tool but it doesn’t do data persistence, so Prometheus is generally used to collect metrics and Grafana operates on Prometheus. Prometheus is built for making a vast variety of metrics reports for different sources, and for collecting and storing metrics. Read more on our Prometheus Monitoring 101 page.

    One general pattern for monitoring stacks is monitoring k8s clusters with prometheus operator stack and monitoring AWS resources with Cloudwatch data source. 


    Plugins are one of the most powerful features of Grafana. It has a huge repository of community built data sources and widgets which extends Grafana in a great way. 


    Grafana provides an HTTP API to get the dashboards in JSON format. These dashboards can be created again by supplying the payload stored as backup. These dashboards can also be imported through Grafana web UI. Many third party pre-built dashboards for tools like Elasticsearch, Airflow, and k8s are available which can be imported this way as well. 

    Get to know our Grafana as a Service better, and check out how MetricFire can fit into your monitoring environment. Get a free trial and start making Grafana dashboards now. Feel free to book a demo if you have questions about what Grafana can do for you.

    Get similar stories in your inbox weekly, for free

    Share this story with your friends

    MetricFire provides a complete infrastructure and application monitoring platform from a suite of open source monitoring tools. Depending on your setup, choose Hosted Prometheus or Graphite and view your metrics on beautiful Grafana dashboards in real-time.

    Latest stories

    200 Million Certificates in 24 Hours

    Let's Encrypt has been providing free Certificate Authority (CA) for websites in need of them …

    Gatling VS K6

    Gatling and K6 are performance load testing tools, and they are both open source, easy …

    Red Hat Ansible Platform 1 vs 2; What’s the Difference?

    Red Hat Ansible is a platform used by enterprises to manage, unify and execute infrastructure …

    Domino Data Labs Raised $100 Million in the Latest Funding Round

    Culled from the news released by Domino Data labs on funding and the company's progress …

    New Release: The Microsoft Azure Purview Is Now Available on General Availability

    News report detailing the announcement of the release of Azure purview on GA

    Google Introduces Online Training Program to Improve Cloud Skills

    Google addresses existing cloud personnel deficiency with training programs.