SAND Dashboards: The Full Tour

In the second blog post of the SAND series, we will take a detailed look at the different FAMIUM SAND dashboards: Real-Time Monitoring, Reporting, Errors Overview, DRM/ Media/ XHR Errors and Session Details. Read on to discover what the purpose of each dashboard is and how best to use it.

Real-Time Monitoring Dashboard

The Real-Time Monitoring Dashboard is for the live tracking of the “health” or performance of the streaming service. It focuses on what is happening right now, so the data displayed is 5-minutes-old or younger.

Made to “paint a picture” at a glance, the dashboard contains only a handful of panels with the key information you need in order to know if a streaming service is performing well or not:

Real-time Monitoring Dashboard
  1. The number of streams being watched right now
  2. The number of clients[1] watching streams right now
  3. The average bit-rate of the streams over the last 5 minutes
  4. The average start-up time of the streams over the last 5 minutes
  5. The number of streams and clients that were active in the last 5 minutes
  6. The number and types of errors that occurred in the last 5 minutes

Tip: Use this dashboard to discover how the number of concurrent streaming sessions, what errors occurred, if any, and asses the general health of streams (ideally, you want to see high bit-rates, low start-up times and few to no errors). 

Reporting Dashboard

The Reporting Dashboard is for big-picture insights. Its panels give a comprehensive summary of streaming service usage and performance for the defined time-interval:

Reporting Dashboard
  1. The total number of streams watched
  2. The total number of clients who were active
  3. The total number of errors
  4. The total number of DRM, Media and XHR errors
  5. The average number of streaming sessions and clients over time
  6. A breakdown of the platforms used to stream
  7. The average number of active platforms over time
  8. A breakdown of the browsers used to stream
  9. The average number of active browsers over time
  10. A list of the different manifest URLs used to stream
  11. The average number of active manifest URLs over time

Dashboard panels are interactive, meaning that they contain even more information than initially visible. The interactivity gives you control to explore the data. Elements can be hovered over, clicked on, zoomed into and much more.

Interactive feature: Clicking
Interactive feature: Zooming in

The best way to learn all the interactive features is by exploring them yourself. When using the dashboard, don’t be afraid to click and drag your mouse around!

Tip: Use the Reporting Dashboard to get a broad understanding of your audience. Answer questions like “How many people were streaming and when?”, “What devices were used to stream?” and “Which are the most popular manifest URLs?”. Once you are equipped with big-picture insights, investigate specific sessions or errors in more detail using other dashboards.

Errors Overview Dashboard

FAMIUM SAND focusses on being a debugging/error analysis tool. As a result, this dashboard offers an overview of all errors that happened within a given time-range. It is divided into five sections: General, DRM License Server Errors, DRM Client-Side Errors, XHR Errors and Media Errors.

Errors Overview Dashboard
  • The general section shows all errors that occurred. In more targeted panels, it also details in on the serious errors (DRM, XHR and Media) that were thrown. In this section, you will find:
    1. The total number of errors that occurred
    2. A pie chart of all errors
    3. The number of errors thrown over time
    4. A pie chart showing a breakdown of serious errors (DRM, XHR and Media) only
    5. A pie chart showing the number of streaming sessions affected by serious errors (DRM, XHR and Media)
    6. A list of streaming sessions affected by DRM, XHR and Media errors

Tip: If you see a streaming session ID or client ID in the table (6) that you want to take closer look at, click on the ID. You will automatically open the Session Details page of that session/ client in a new tab.

  • The DRM License Server Errors section drills into, as the name suggests, all DRM license server errors. Included in this section are:
    1.  The total number of DRM license server errors
    2. A breakdown of the different types of DRM license server errors
    3. The number sessions affected by DRM license server errors over time
    4. A breakdown of the devices affected by DRM license server errors
    5. A breakdown of the browsers affected by DRM license server errors
    6. A list of the specific DRM license server errors together with the specific platform and browsers that were impacted
  • The other sections (DRM Client-Side Errors, XHR Errors and Media Errors) are built identically to the DRM License Server section described above, but for inspecting DRM client-side, XHR and media errors respectively.

To summarize, the Errors Overview Dashboard tells you what went wrong, where and when. It informs you about key stats (e.g. the total number of errors), key groups (e.g. the different types of XHR errors that were thrown), and observable trends (e.g. whether specific errors are reoccurring on specific platforms).

Tip: Use this dashboard as a starting point to gain a clear picture of the error-landscape. Check key stats and identify trends or patterns. After that, start debugging specific errors using either the DRM/ Media/ XHR Errors Dashboard or the Session Details Dashboard.

DRM/ Media/ XHR/ All Errors Dashboard

FAMIUM SAND provides five tabular dashboards for exploring DRM, Media, and XHR errors in details (the DRM License Server Errors Dashboard, DRM Client-Side Errors Dashboard, Media Errors Dashboard, XHR Errors Dashboard, and All Errors Dashboard). These five dashboards are structured identically, so in this post we will only introduce one of them: the Media Errors Dashboard.

Tip: Use these tabular dashboards to investigate errors in detail. The table helps you debug, because for each error it lists the full error message, when it happened, where it happened (which streaming session, which client and what user agent), and what manifest URL the error is linked to. In the case of media errors, the table also shows how many frames were dropped during streaming.

The Media Errors Dashboard shows all media errors from the last 24 hours. If you like, you can toggle the time-window on the top right-hand corner of the dashboard to set a different time-range.

Text boxes above the table let you filter for error messages and user agents. This makes inspection easier by, for example, quickly letting you find out which sessions were affected by media errors containing the word “pipeline”. Column filters in the table itself also let you filter for error messages and user agents, and additionally let you filter for streaming session IDs, client IDs and manifest URLs.

Interactive feature: Filtering

The panels on the right will ensure you never lose sight of the big-picture, even when you are looking at the details of a media error. They show:

  1. The total number of Media Errors that happened in time-range (12h)
  2. The total number of streaming sessions affected by media errors
  3. The total number of clients affected by media errors
  4. The time series distribution of all media errors
Media Errors Dashboard

Session Details

Visiting the Session Details Dashboard is like taking a lens to a streaming session. It displays all the metrics collected from a streaming session and puts the dashboard user in control of exploring the data.

The easiest way to arrive at this dashboard is to click on a streaming session ID link in another dashboard, for example in the Session Overview Dashboard, which is like a staging area to the Session Details Dashboard. The table helps the user identify streaming sessions worth exploring in more depth by listing key metrics like startup time or number of errors. Once you’ve found a streaming session you want to dive into, simply click the link! Navigating into Session Details this way will ensure that the time-window encompasses the entire duration of the session.

Session Overview Dashboard

Once in the Session Details Dashboard, make the most of the fine-grained metrics at your fingertips by (interactively!) exploring the panels. These include:

Session Details Dashboard
  1. A table with key data about the streaming session (streaming session ID, client ID, first and last timestamps, session duration, average buffer level, average bit-rate, average live-edge delay, and number of errors)
  2. A table listing device information (e.g. platform, OS, browser, browser version, MPD URL, user agent, referrer, player, and adapter)
  3. A table specifying startup durations (manifest loading time, player loading time, and total startup time)
  4. A timeline pin-pointing the events that happened during the stream
  5. The average bit-rate of the session over time
  6. The average buffer level of the session over time
  7. The average live-edge delay of the session over time
  8. The error that occurred during streaming
  9. The average memory usage of the session over time
  10. A list of all errors that occurred (Error Log)
  11. All the raw data reported by the client
  12. All DRM requests sent by the client
  13. All HTTP transactions made between client and server
Interactive feature: Timeline

Tip: Use this dashboard when you want to understand a streaming session in depth. Observe how a streaming session unfolded, identify relationships between different metrics and draw conclusions about the causes and consequences of an error.  

Conclusion

At FAME, we build dashboards with our customers’ informational needs and user-experience in mind. Our aim is to deliver an indispensable tool for every content provider’s toolbox.

After reading this blog post, you should be familiar with the different FAMIUM SAND dashboards and their capabilities. You should also feel confident to use them to debug errors and investigate the performance of your streaming service. If you have any suggestions for new features, let us know in the comments. We look forward to hearing your ideas!


[1] Each stream or streaming session receives a unique ID. A client is the anonymized person who has watched the stream. Over the course of their streaming life, a client will watch many streams, some streams might even be watched simultaneously in different browser windows.

Leave a Reply

Your email address will not be published. Required fields are marked *