Grafana is an open source solution for running data analytics, pulling up metrics that make sense of the massive amount of data & to monitor our apps with the help of cool customizable dashboards.
This app gives demonstrates how we can embed a grafana panel into our node app and display it on our webpage as well as edit the properties of the grafana chart. This app is built using NodeJS, ExpressJS and EJS templating engine.
- Clone the github repo
- Run
npm i
and it will install all the project dependencies
- Go to Grafana Installation Guide and install grafana.
- After completing the installation, you should be able to open grafana by going to
http:\\localhost:3000
from your browser. - From the sidemenu, select
Configuration
->API Key
and generate a new API key withAdmin
role. Paste this key inside yourenv
file
- Select the
Create
option from sidemenu and selectDashboard
, now selectAdd a new panel
. You'll see grafana creates a panel for you with some dummy data. We're going to embed this panel in our node app - Click on the
Save
button from the menu bar and enter a name for your dashboard and save it. - Click on the panel title ->
Share
->Embed
-> Copy the value of src attribute from theiframe
element and paste it in theenv
file
- Now, to give permission to access grafana dashboard from our node server, we need to change some configurations. Checkout Grafana Configuration Guide to locate the
grafana.ini
config file in your OS and open it using any text editor. - Search for
allow_embedding
key and change its value totrue
. Also remove the semicolon;
before the key name to uncomment it - This property allows us to embed our panel into other webpages. - Now, search for
anonymous
keyword and insideauth.anonymous
section, remove the semicolon before property name and set theenabled
property totrue
. This now allows us to access the panel without need to login to grafana. - You can confirm these changes by going to
http://localhost:3000/admin/settings
and checking the property values
- Run
npm run dev
to start the node server and go tohttp:\\localhost:4000
to see the embedded panel - You can also change the panel properties by going to
\edit
route
Please feel free to reach out to me at [email protected]
in case you have any queries.