Performance

Tips for Performance Optimization

Product line

Standard

|

Expert

Operating mode

CLOUD ABO

|

ON-PREMISES

Modules

Services & CRM

Budget & Phases

Purchases

Resource Planning

Business Intelligence

Created: 10.05.2007
Machine translated
Updated: 30.04.2021 | Article changed, interactive performance analysis tool linked

There are several components that can affect the overall performance of the system. If certain parts stand out negatively or the overall system is performing poorly, it is important to find out exactly what is slow and what the potential impacts are.

Depending on the type of operation: on-premises (operated by the customer) or cloud subscription (operated by Vertec), there are different ways to influence performance.

Below is a graphical representation of the two variants. The colours show who can influence which part of the performance.

On-Premises Installation

 

 

Cloud subscription installation

 

 

Only Vertec has an influence on the blue areas: Only Vertec can influence the business logic, i.e. how something is calculated or how the data is handled.

In the cloud subscription scenario, Vertec is responsible for the operation, but the upper levels remain the same. This means that even with good server and network performance, Vertec can do things that will not perform now or in five years’ time.

Only the customer or – if parts have been outsourced to an external service provider – this third party has any influence on the orange areas. The orange components are beyond the reach of Vertec or Vertec advisor.

In the green areas, there is a mixed responsibility: Vertec can influence customizing opportunities in the sense that we provide high-performance customizing opportunities or make optimizations if we see that certain customizing opportunities are used in such a way that they are not high-performance.

Customers have an influence on the requirements in this area. In the case of features, performance should always be included as an additional requirement and the feature should be checked accordingly. It can also be worthwhile to examine optimization options for existing installations. Here, the Vertec advisor is also responsible for ensuring that the implementation is as efficient as possible. This includes rejecting certain requirements if it is obvious that they will not perform well now or in the future.

This article discusses performance issues related to customizing. For information on network performance, see Performance on the Web.

How do you find out what kind of performance problem it is?

Often, it’s just a list or folder display, or a particular behavior causes performance degradation. First, you need to determine if it’s really a problem with Vertec. For example, it could be a network problem.

Try to find out where the performance problem lies in Vertec by using our Interactive Performance Analysis Tool or the list below.

Vertec starts up slowly, but is fast afterwards

IX top-level folder

One possible cause could be an IX folder set up at the top level of Vertec. The top level, called root, is the one you see first when Vertec starts up (e.g. root data, public folders).

The IX folder calculates its contents as soon as the layer in which it is located is shown. If the folder is in the root, this is the case at startup.

If you move the IX folder to a lower level, Vertec will restart at normal speed. You can move a folder using the script: Move folder.

Wrapper Link Types

At startup, the folder structure of the logged-in user is shown at the top level. If you use wrapper link types on project users who have the Always show containers option disabled, the tree will be checked for each of these containers to see if it needs to be shown or not. For these wrapper link types, activate Always show containers option. Thus, although the folder in the tree will be shown, the objects will not be loaded until you click on the corresponding folder.

Load active projects at program start

For installations with very many projects (from 2000-3000 active projects), it is advantageous not to load the projects at the start of the program. To do this, observe the following steps:

  • In the system settings under Project, deactivate the entry Read active projects at program start.
  • In all lists with project columns (services, expenses, outlays, and activities), change the project column control to edtProject. This causes a search dialog to appear instead of a drop-down selection.

Controlling loaded objects

In Vertec under Einstellungen> System Info see [LoadedObjects] for a list of all the objects that have been loaded. So after booting, check what Vertec has loaded. This might give you an indication of why booting is slow.

Slow start due to file sharing problems (on-premises only)

If Vertec.Desktop.exe is located on and started from the file server, file sharing issues may affect startup performance.

The Vertec desktop app should never be launched over the network. Use the Vertec cloud app or the Vertec web app instead.

If it is unavoidable to use the Vertec desktop app on a client, perform an appropriate Client Installation .

Slow start due to different ip versions

In one case, it happened that Vertec started very slowly on some clients. After the connection was up, Vertec ran normally fast.

The reason was that the server was set to IPv6 and expected the connection attempts to do so. However, all problematic clients were set to IPv4. This configuration appears to be possible, but it causes delays in connection. After the server was set to IPv4, the delays did not occur.

Delayed start of vertec 6.0 when there is no internet connection

Starting the desktop app takes 20 to 30 seconds on a computer without an internet connection. As soon as there is an internet connection, the application starts at the usual speed.

This is related to the .NET Certificate Revocation Check (CRL). If Internet Options > Advanced > Security > Check for publisher’s certificate revocation is disabled, the application starts normally.

Workaround: Provide Internet connection or disable revocation-list checking (which is not needed if there is no Internet connection).

A specific folder opens slowly

Folder Structure

The folder you click is part of a folder structure. What you want to show are the subfolders.

One possible cause could be an IX folder set up as one of the subfolders. The IX folder calculates its contents as soon as the layer it is located in is shown. In this case, the display of the parent folder takes a long time.

Move the IX folder to a lower level, for example, by simply inserting another folder. The IX folder is then calculated only if you really want to see it. You can move a folder using the script: Move folder.

Single Folder

The folder is a single folder. You want to show the entries. It is a:

Normal Folders

If there are thousands of entries to load, it may take a little longer. In that case, you just have to wait. In any other case, it will be more of a problem with the displayed list. See “List slowly showing” below.

Expression Folder

  • Check the expression. Can it be optimized?
    There are classes in Vertec that can contain a lot of objects. If you specify a class list in OCL, all objects in that class are loaded into memory. This can lead to high memory consumption and poor performance, especially with the OpenPerformance or ChargedPerformance classes.
    Can you change the starting point? For example, can you use invoices that are charged instead of invoices? Or, instead of open services, can you first call only the users of a particular team and take only those services? Can you use service sums instead of services?
  • Can I use an SQL folder instead of an expression? SQL folders are recommended if you want to select specific objects from a large amount of data based on a simple condition. Unlike the OCL expression, only the objects that match the SQL condition are loaded from the database.
    Note: If the folder is the basis of a query folder, you should not change it. SQL folders should not be used as the basis for query folders, as they do not update automatically when changes are made.
  • Does the expression seem OK to you? Then it could be the list settings that are shown. To check this, create a temporary Expression folder with the same expression. If it works faster, look for the problem in the list. See below List is showing slowly.

Sql folder

If there are thousands of entries to load, it may take a little longer. In that case, you just have to wait. In any other case, it will be more of a problem with the displayed list. See below List is shown slowly .

Query Folder

A query folder is based on several other folders. Check the underlying folders. Does it have a “long runner” underneath that you can optimize? Otherwise, it could also be due to the list settings. See below List will show slowly.

List is shown slowly

Checking the columns

It is important that columns that are no longer needed are not simply set to 0 width, but are deleted. Otherwise, they will still be calculated and will take time. Check for such columns in the list and delete them if you no longer need them.

Checking the column expression

  • Are there complex calculations in the list? Complex calculations take time. It is advisable not to perform complex calculations on lists that are often used. It is better to create a second folder that will perform the calculations used in the list.
  • Check the expressions. Can they be optimized? Here is an example of a column expression and how to optimize it. An expression like this one on an employee list:
    offeneleistungen->select(phase.boldid=8070)...

    loads all open services for each employee in the list and filters them according to a specific phase. For large installations this can bring Vertec to a standstill. It is better to load the phase first and then filter only the open services on this phase according to the employee:

    Projektphase.allinstances->select(boldid=8070).offeneleistungen->select(bearbeiter=self)...

Test Folder Performance

The Test Folder Performance Python script allows you to determine the performance of a folder (specified by the ID). As a result, a list of the load times of each column is returned. For more information about this script, see Script: test folder performance Performance.

Checking the constraints

Constraints can lead to significant speed problems. An indication of such problems is when certain lists take a long time to build: e.g. if project lists are long, but performance lists are iO, you should check the constraints on projects and adjust them if necessary.

Service sums in lists

  • Do you need performance totals? These are not recommended in column expressions, since the performance gain when calculating the sum is usually overcompensated by the large quantity of individual SQL queries.

It is problematic if the list is shown in the background while the service data is changed in the foreground. Service sums are always recalculated as soon as any service in the system is changed. The recalculation occurs when the service sum numbers are also visible. In this case, the whole list is recalculated continuously, which can lead to a massive loss of performance.

Expressions on rights

Expressions on permissions can lead to performance degradation. The problem is that every time a user accesses a member, the permission has to be checked – a “caching” is not possible, because the result of the expression can change between 2 calls. In particular, read rights that are assigned to entire classes (i.e. not to individual fields) have to be checked again for each individual field.

Check if you have permissions that work with expressions. In this case, you should limit the permissions accordingly, for example, write instead of read (which often exists anyway, for example for address entries) or assign only to individual fields.

In principle, read rights at class level not without specifying the corresponding fields, especially for classes that are either displayed in lists (such as service, address entry) or used in totals (invoice).

Recording services is slow

Is entering services fast and then slow? Pay attention to what you have shown in the background. It could be a list of service sums. A detailed explanation of this constellation is described in the previous section under “Service sums in lists”.

Displaying a project or phase is slow

Show invoiced services, expenses and outlays

In the system settings, section Project/Case, there is the setting Show billed services and expenses. If this option is set to Yes, the billed services, expenses and outlays from the service entry are shown in separate subfolders on the project.

This can reduce the speed of displaying projects and project phases when there are many billed items. To optimize performance, turn this option off by default. If you want to access billed services, expenses, and outlays, you can temporarily turn this option on or access the corresponding invoice. The billed items are always visible on the invoice.

Show budget values

In the system settings, section Project/Case, there is the setting Show totals. Here you can define whether the budget values on projects and project phases should show the comparison with the actual values by default or not. In order to be able to calculate these figures, Vertec must load services, expenses and outlays of the corresponding phase or project. Therefore, such a setting may be accompanied by a slowdown.

To optimize performance, turn this option off by default. This can be overridden on a project-by-project and phase-by-project basis by ticking Show values? so that you can only show the numbers when you really need them.

Show activity list is slow

When validating documents that are assigned to an activity, it is also checked whether the linked file exists in the filesystem. This can lead to performance problems with large activity lists.

In the system settings under General there is the setting Check existence of document files. In this system setting you can set whether the check should take place. By default it is set to Ja. If it is set to Nein, the check will no longer take place and activities with documents without an associated file in the filesystem are still valid.

Creating an entry is slow

If creating objects is unbearably slow, but everything else is running smoothly, this may be caused by the Notif port blocked by the server firewall.

If you install Vertec on a server that also has a firewall for the internal network (e.g. in the case of XP, Server 2003 and Server 2008), the Notif port and possibly the XML port must be explicitly enabled for this to work. To do this, you should enable the port and also Vertec.CloudServer.exe.

The information about what is running on which ports can be found in the Vertec.ini configuration file, which is located in the Vertec installation directory.

Deleting an entry is slow

Is it possible that the entry is connected to another via a CustomLink or a GenericLink? It is the case that when you delete all 'sister’ objects are also loaded. So if you have a CustomLink / GenericLink between addresses and user, and there are 5000 addresses attached to one user, then when you delete one such user all 4999 others are loaded as well.

First, remove the link connection to the other object manually, and then delete the entry.

Miscellaneous is slow

Does Vertec seem to be slow in general, but you can’t pinpoint exactly where?

Can a network problem be ruled out? See the article Performance in the network .

Vertec is slow, notif brings errors (on-premises only)

Does Vertec sometimes run very slowly, and I keep getting error messages about Notif not running. In the system info, there is an error “Socket Error #11001” with the Notif.

The reason for this is an incorrect hostname in the INI file. The computer on which the Notif is running has a different name. If you correct the name, the Notif is running correctly and Vertec is also running normally fast again.

Are you working with windows 8.1 on a laptop?

In connection with Windows 8.1 on laptops, the following problem may occur: The Windows 8.1 Power Saving Mode automatically sets the Airplane Power Saving Mode when the radio connections are turned off. This may be the case, for example, when the laptop is on the LAN and on power. Nevertheless, this Power Saving Mode is automatically set and severely affects the performance of Vertec (and, of course, any other application that would consume a lot of resources locally).

If you delete the energy-saving plan, it just comes back the next time you turn off the radio. So every time you turn off the radio, you have to turn off the aircraft energy-saving mode again.

Affected by this problem are the Windows clients desktop app and cloud app, which seem to react so strongly to processor throttling due to the use of WPF and related graphics performance. The web app, which also uses WPF on the server, on the other hand, is not visual, and the exact same business logic, runs smoothly.

Corrupt indices (on-premises only)

One possibility is that the slowdown has to do with corrupt indices. This greatly slows down computationally intensive processes in particular.

MS SQL

You can re-create the database indexes with a new convert. To do this, simply run an Sql convert without changing the version.

Firebird

A Backup / restore the database deletes the indexes and re-creates them. Make sure that all users close Vertec before performing this operation.

If that doesn’t work, increasing the page size of the database can help. For more information, see the article on Firebird pages and buffersize .

Compare Loaded Objects before/after

In Vertec under Einstellungen> System Info see [LoadedObjects] for a list of all objects that have been loaded. For slow operations, it may be worthwhile to compare the loaded objects before and after the operation to get an indication of where the performance problem might be coming from. See Performance analysis with loaded objects for details.

Vertec On-Premises

Cloud Clients vs. Desktop Clients

There is the server hardware, the database (Firebird or MS SQL) and the network. Based on these are the Vertec server services and the various clients. The so-called fat client, the desktop app, which directly contacts the database server and processes the entire business logic locally, as well as the cloud clients, in which the application logic runs in the cloud server and the actual clients as thin clients only apply the representation. These two fundamentally different types of client naturally each have their own performance behavior, e.g. with regard to operation over a narrow VPN connection (Vertec in WAN systems).

The structure of the software is the same for both types of clients: there is the business logic, the object space (in which the Vertec objects live) and the customizing in the Vertec itself (lists, queries, evaluations, etc.). In the case of the cloud clients, another network is involved for the display on the end devices.

Note the CPU usage of Vertec.Desktop.exe while you are working with Vertec on the client (in Task Manager). If the CPU usage of Vertec.Desktop.exe is low while you are waiting in Vertec, it can be assumed that there is a problem with the network, server, or database. See the article Performance on the Net.

If the CPU usage of Vertec.Desktop.exe is high while you have to wait in Vertec, it can be assumed that it is really Vertec that is slow (assuming your system meets the minimum requirements).

The performance of cloud clients (cloud app and web app) depends on network latency, not bandwidth.

Since Cloud Clients run sessions on the server, make sure that the server has the appropriate service (at least 100-200 MB RAM per session).

Has the Vertec Service started? Is the Notif running normally?

Verify that the cloud server service is started and that Notif is not reporting any errors.