Handling Business Central Telemetry like a boss: my Azure Data Explorer dashboard

WaldoBusiness Central1 year ago140 Views

You might have seen it, you might haven even been there – but in any case: this year, at BCTechDays, I did a session about “Telemetry”.  And since BCTechDays posts its sessions online (how unique is that!), you can watch the session here:

This post is NOT about the session, so I invite you to watch the session above, and give me some more views .

This post is about the tool I used to demo (the Azure Data Explorer) and the dashboard I made that you now can use yourself.  Since the session, I massively improved and simplified the dashboard, which makes the “getting started” much easier. 

So .. lets get started…

The scope

The goal of this blogpost is to give you a kickstart in analyzing your Telemetry with the Azure Data Explorer.  You’ll see it’s similar to the PowerBI dashboard that Microsoft created, but very different for ad hoc analysis scenarios, where I find it much more efficient!

Quick introduction

The Azure Data Explorer (ADE) is actually made for analyzing “huge amounts of data” with KQL: it’s able to execute KQL in a query window, and it’s even able to save your collection of KQL queries in dashboards … and much more.  See it as a collection of queries, that you can easily run (in parallel), and are always there at your disposal.

Now – Application Insights, where Business Central is sending its signals to, happens to be a big database, that we are able to query with the ADE.  We don’t need to set up additional databases, synching with them or anything – just connect, and run queries to the online data – with the additional advantage over PowerBI: all your queries will always be the latest and greatest data!

Getting started

Easy:

  1. Browse to https://dataexplorer.azure.com/
  2. Sign in

Signing in is important, because that’s going to be the account that you’ll use in your dashboards.  So – pick the account that you have access to the Application Insights service as well!

Connecting to your App Insights

 When you have signed in, on the left, you have the “Query” tab:

This Query window is very similar to the “Logs” in Application Insights: we can execute KQL on a database.  But .. obviously, the first thing we need to do is set up that connection to that database.  In our case: Application Insights.

To set up a connection, you’ll need a connectionstring, and for Application Insights, it’s pretty easy to set up – all you need is your Azure SubscriptionId being put in this format:

https://ade.applicationinsights.io/subscriptions/<YourAzureSubscriptionGuid>

To test it, just click Add/Connection, and set up your connection:

When connected, you get a list of all your AppInsights endpoints, and you’ll be able to execute queries, like you’re used to:

The key part is that connection string, because you’ll need it going further.

Setting up my dashboard

I’m not going to explain how to start from scratch – not saying you shouldn’t (see later).  You’ll just find it much easier to have a good example before you’re starting to build your own..  trust me: KQL and Telemetry is all about Copy/Pasting ;-).  And you’re about to paste about 100 queries in one go 🤪.

There are a few resources you might want tot start with.  Just to name a few:

I’m going to focus on what I know, which is mine (because that’s what I know best, obviously ;-)).  Although, do know, you’ll learn a lot from all others as well!

I’ll use the “waldo.BCTelemetry Dashboard“.  The way to import it, is simply:

And use (copy/paste) the raw link:

https://raw.githubusercontent.com/waldo1001/waldo.BCTelemetry/master/Azure%20Data%20Explorer/dashboard-waldo.BCTelemetry.json

Give it the name that you like

And done!

Now, you’ll see a dashboard all with errors.  Simply because it has my connection, and you don’t have access.

To fix this, go to “Data Sources” and edit the "AI-Datasource", and paste the same URI that you already has set up above, Connect and select the database you want to analyze with this dashboard.

The base queries

I already made some base queries for you, and it’s important to understand.

A base query is actually a variable that you can use in your dashboard, that you “pre-fill” with data, so that you don’t have to do the same things all over the place. 

I created 2 for you:

  • allTraces: very similar to “traces”, but already filtered with a bunch of parameters that I have set up, extended with a bunch of columns, and so on.  Too much to explain, just have a look, and be amazed 🤪.
  • entraTenantIdDescriptions: this is a call to external data, which you can use to make it easier to identify your customers.  I’ll “join” this with the “aadTenantIds”, and you get “TenantDescriptions” for free in all the tiles in the dashboard.

Setting up these tenantDescriptions, I can’t do that for you, obviously.  That’s why you see this in the “Base Tables” tile:

When you check out the base query, you’ll see it points to this file:

https://raw.githubusercontent.com/waldo1001/waldo.BCTelemetry/master/Azure%20Data%20Explorer/ExternalData/entraTenantId.json

The idea is: you create your own file, and make it available so that the dashboard can download it – and obviously change the base query to your own URL.  Me personally, I simply use dropbox 🤷‍♂️.  But you can do whatever you want.  Make sure the format is the same.  You don’t have to, but it is a small effort, and it makes the dashboard very much more readable.  On top of that, you get a simple parameter to simply filter all the entire dashboard for one customer, if necessary.

Parameters

When you go to the Parameters, you’ll see that I already have a bunch of parameters.  Just browse through them, to see if they make sense.  Most of these, I already use in the Base Query “allTraces“, so there isn’t really anything you should change, they are “just” used already ;-). 

But – you can also add your own.  There are enough examples for you to start from, I’d say ;-).

You are done!

This is it.  You did all that was necessary to make it work.  Now, it’s up to you to start analyzing whatever you like.

Clean up

You’ll see there are some “CT” tabs in the dashboards.  “CT” stands for “Custom Telemetry”.  When you look at the BCTechDays session, you’ll see what that means, but chances are you don’t have this telemetry, or you have different eventIds.  So please feel free to delete or change however you see fit.

Tip: there are settings

Don’t forget you can set up your environment when you click settings on the top right

Here, you can set the time zone, zo your timestamps will be in your time zone, and not UTC.  Very useful!  I invite you to check the other settings to make the experience more “your own”!

Another tip: start from scratch

No matter how much I want yo to use my dashboard, I don’t think you should do just that.  I think it’s interesting to see it as a starting point, but you know, there are not “updates”, there is no branching, no version control, no forking, nothing of the sorts.  As such, you basically just copied my dashboard and made it your own.  Whatever update I do, you won’t get, and whatever update you do, will be overwritten when you import a new version of my dashboard.

What I would suggest is, look at my (and other people’s ) dashboards as a reference, but start one from scratch, for yourself.  You take full control, manage it yourself, and that’s your go-to board.  But also set up some dashboards of mine, Duilio or anyone else, just as a reference, to copy from to your own, when necessary.  I personally think that would be a good workflow.

Original Post https://www.waldo.be/2024/06/28/handling-business-central-telemetry-like-a-boss-my-azure-data-explorer-dashboard/

0 Votes: 0 Upvotes, 0 Downvotes (0 Points)

Leave a reply

Follow
Search
Popular Now
Loading

Signing-in 3 seconds...

Signing-up 3 seconds...