Dynamics CRM Performance Optimization II. (Anamnesis)

Dynamics CRM Performance Optimization Blog Series

  1. Introduction
  2. Anamnesis
  3. Diagnosis
  4. Therapy
  5. Control Examination

Anamnesis

As I explained in the previous post, the purpose of the "Anamnesis" phase of a Dynamics CRM performance optimization engagement is to understand the essence of the performance complaints. Based on a detailed understanding we can follow with the right diagnosis of the problem. So what does it mean "understanding"? In order to understand, you must do following:

  • Talk to the customer
  • Verify the complaints in a hands-on experience

We need to talk to our primary customer contact person, but also to the end users from whom the complaints are coming. We need to see the behavior directly on the computers, where it happens. If the poor performance is observed only on remote locations we need to ask the customer to demonstrate it using whatever technology available – conference call, remote access to the computers etc. Further, it is essential to understand if the behavior is role-specific / user-specific and if yes, what the characteristics of the roles or users having performance issues are.

At the end of this "anamnesis" exercise, we will have a list of different findings typically falling in one of following 2 major categories:

  • User Interface (visible) issues
  • Backend processing issues

In the following part I will give you an overview of typical performance issues from both categories which should be considered as an guidance for subsequent engagement phases:

User Interface (visible) issues

In the following table I will present you the most typical user interface performance issues:

Issue

Description

Conditions

Overall poor performance

This is a very generic issue and must be further analyzed if it can fall into other – more specific category

All users?Selected user groups?

Entity form slow load time

This is definitely the number one in all hit-lists and the most frequently complained performance issue of all. The reason for this is, that loading of entity forms is something, the users do most of the time and the expectation for good performance is very high.

All users?All entity forms?Selected users groups?Selected forms?

Entity form slow save time

Slow saving time is less frequent due to some specific implementation reasons, but also due to lower performance expectations (Broadly accepted expectation is, that saving does "something" in the background and needs some time for that)

All users?All entity forms?Selected users groups?Selected entity forms?

Entity view slow retrieval / Advanced find slow retrieval

If this issue occurs we can observe following:

- A waiting time before the view rendering starts

- The view rendering runs slower than expected

All users?All entity views?Selected users groups?Selected entity views?

Slow rendering of reports

Typically rendering of reports should not be much slower than a couple of seconds. Everything above is recognized as an issue

All users?All reports?Selected users groups?Selected reports?

Slow rendering of dashboards

Dashboards are composite UI constructions, so a longer rendering time can be expected, but if some of the dashboard elements are rendering too slowly the whole user experience suffers.

All users?All dashboards?Selected users groups?Selected dashboards?

Outlook client starting slowly / freezing

In most of the Dynamics CRM implementations the Outlook Client is the preferred client-side solution thanks to the synchronization function and offline capability. It is very annoying if users observe significantly lower Outlook performance or even freezing issues after installing the Dynamics CRM client.

All users?Selected user groups?Dependency on Outlook version?

Slow SharePoint integration

Typically SharePoint folders integrated on Dynamics CRM forms should not render much slower than any other usual sub-grid.

All users?On all entity forms?Selected users groups?On selected entity forms?

 

Backend processing issues

In the following table I will present you the most typical backend performance issues:

Issue

Description

Conditions

Slow workflow execution

Dynamics CRM users typically expect, that the workflow triggered by a user interaction is executed latest "in a couple of minutes". Anything between "more" than a couple of minutes and hours/days may be a serious issue, especially when business processes depend on finished workflows.

All users?Selected user groups?All workflows?Selected workflows?

Slow incoming data integration

Almost every large Dynamics CRM implementation contains a large portion of integration with surrounding systems. Incoming integration is mostly implemented as:

- Real-time

- Batch

In both cases users expect the data to be in Dynamics CRM "in time", when they need them.

All data?Selected data?

Slow outgoing data integration

The outgoing integration is mostly implemented as real-time, so the user's expectation is the same as in previous.

All data?Selected data?

Slow server-side E-Mail integration

If server-side integration with a messaging system is implemented, users expect same behavior for Dynamics CRM E-Mail activities as for E-Mails themselves – very fast sending out or delivery.

All E-Mails?Sending only?Receiving only?

Slow initial data load

This is a very specific issue, which does not directly touch end users, but rather the implementation team and is a one-time issue. But never then less, it can be a major show-stopper, especially if a prescribed time slot is given to the implementation team to import huge amounts of initial data.

 

 

In the next part I will start the most interesting topics around diagnosing the reasons for poor performance, so stay tuned!

 

Robert Rybaric is an architect in the Microsoft EMEA Dynamics Center of Excellence