Community Tip - Stay updated on what is happening on the PTC Community by subscribing to PTC Community Announcements. X
Hi,
We have a customer who stores CAD files in FileVaults (more tha 8TB), so Microsoft SQL Database contains theoretically only the metadata.
The size of the SQL Database is greater than 200GB.
There is a dedicated VM for SQL server with 128GB Memory and 8vCPU.
The customer has some performance issues with for example complex queries.
Somethimes this query runs fast - 5-10 sec - but other time tis query runs 5-10 minutes!
An SQL expert adviced to our customer to use at least 1-1,5 times more memory for SQL Server than the existing database size.
This can be a good way to handle performance issue?
Thanks,
Károly
Solved! Go to Solution.
Thanks for eveyone for the previous recommendations!
Meanwhile It seems the performance problems were solved with the following steps:
So we started an investigation and we realized if the File Vault VHDX disks are not attached to the virtual machine teh boot process is 4 seconds.
But after attaching even just one FileVault disk, the system slowed down terribly.
One FileVault disk size is ~ 1.5TB and contains more than 3.000.000 - 5.000.000 small files and the VHDX type was Dinamically Expanding.
So the solution was to create brand new FIXED sized VHDXs with 64KB stripe size and copy all original FileVault content to the new ones.
After this step the new VM started 4 seconds with all new FileVault disk attached to it!
3. Performance Impact of Hyper-V CPU Compatibility Mode: after the migration the local IT turned off the Hyper-V CPU Compatibility Mode. So further performance gains could be achieved.
Nowadays the Windchill Service startup time is 90 seconds vs. 210-300 seconds before migration.
We are yet to implement the SQL Server performance tuning steps described in the PTC knowledge base articles suggested by mmeadows-3 as the client is satisfied with the current performance.
SQL Performance Tips
Most Windchill system administrators are not SQL Server certified DBAs. Fortunately, PTC has given SQL Server a lot of attention and provided various recommendations for optimizing it.
Start with general cleanup and performance tuning recommendations.
If these don't help, log a performance call with PTC Technical Support. They will want you to perform the slow running actions and send them the performance tables.
windchill wt.util.jmx.ExportPerfTables -chunkSize 20000 perftables.gz
If the system is performing well and it is just these queries that suffer... What do you mean by 'query'? Are these customizations or reports?
Hi,
thanks for cleanup and performance tuning recommendations summary.
I will try to catch a SQL Expert and we will review these and will make a plan to execute these steps.
They have lot of Query Builder based reports.
There are some queries that can be run to reproduce the performance issue.
But there are performance issues one or two day a week when the system got stuck without running these aformentioned queries.
The CPU utilization is on 100% in every Core for a couple of hours. The memory usage is 90% by default. (All free memory is reserved by MS SQL Server - 115 GB)
Thanks!
Ultimately, the answer may be to throw more resources at it. But it feels like the slow reports are a symptom of an underlying issue.
You can use JConsole (windchill wt.util.jmx.SMJconsole) to try to identify what is running during these lockups. Select the Windchill tab to see what is running at the moment. The ElapsedTotalCpuSeconds column may be useful.
It may not be Windchill/DB related. For example: Antivirus scanning can consume all processors for a period of time. If Defender antivirus and a third-party antivirus are both running, it can lock up a server for hours.
PTC Tech Supt's performance team can help direct you to the source of the issue.
@kszemes wrote:
An SQL expert advised to our customer to use at least 1-1,5 times more memory for SQL Server than the existing database size.
I'd be cautious trusting this expert. SQL server can perform worse with too much memory. Even for the largest of installations, PTC never recommends any such ratio.
1.) SQL Server will eventually consume all of the memory made available to it. This is by design, and why it's important to configure an upper limit based on what is actually available on the server.
2.) Most SQL Server installations have only a fraction of the RAM compared to their data size. It is possible to analyze SQL Server and determine if the RAM is actually the bottleneck.
Hello @kszemes,
It looks like you have some responses from some community members. If any of these replies helped you solve your question please mark the appropriate reply as the Accepted Solution.
Of course, if you have more to share on your issue, please let the Community know so other community members can continue to help you.
Thanks,
Community Moderation Team.
Thanks for eveyone for the previous recommendations!
Meanwhile It seems the performance problems were solved with the following steps:
So we started an investigation and we realized if the File Vault VHDX disks are not attached to the virtual machine teh boot process is 4 seconds.
But after attaching even just one FileVault disk, the system slowed down terribly.
One FileVault disk size is ~ 1.5TB and contains more than 3.000.000 - 5.000.000 small files and the VHDX type was Dinamically Expanding.
So the solution was to create brand new FIXED sized VHDXs with 64KB stripe size and copy all original FileVault content to the new ones.
After this step the new VM started 4 seconds with all new FileVault disk attached to it!
3. Performance Impact of Hyper-V CPU Compatibility Mode: after the migration the local IT turned off the Hyper-V CPU Compatibility Mode. So further performance gains could be achieved.
Nowadays the Windchill Service startup time is 90 seconds vs. 210-300 seconds before migration.
We are yet to implement the SQL Server performance tuning steps described in the PTC knowledge base articles suggested by mmeadows-3 as the client is satisfied with the current performance.
@kszemes Thanks for circling back and sharing your solution with the community!