CP Synch. optimization

bruno77
Member Posts: 62
Hi,
I am having some issues with deadlocks when using Commerce Portal. The "SynchMgt. Message Queue" is getting deadlocked because of the table lock done in CU 6205. Could I get some input on this code change:
Change table 6224 - SynchMgt. Message Queue - No. to BigInteger and AutoIncrement = Yes and then the change below to CU 6205:
Input would be appreciated. Thanks.
/Bruno
I am having some issues with deadlocks when using Commerce Portal. The "SynchMgt. Message Queue" is getting deadlocked because of the table lock done in CU 6205. Could I get some input on this code change:
Change table 6224 - SynchMgt. Message Queue - No. to BigInteger and AutoIncrement = Yes and then the change below to CU 6205:
GetNextSynchMessageNo(TableName : Text[250];Command : Code[11]) //GetNextSynchMessageNo //Temp Start //SynchMessageQueue.LOCKTABLE; //IF SynchMessageQueue.FIND('+') THEN; //SynchMessageNo := SynchMessageQueue."No." + 1; //Temp End Conv.PutSynchMessageValue( SynchMessageQueue,SynchMessageNo,'TABLE',TableName); //Temp Start SynchMessageNo := SynchMessageQueue."No."; //Temp End Conv.PutSynchMessageValue( SynchMessageQueue,SynchMessageNo,'COMMAND',Command);
Input would be appreciated. Thanks.
/Bruno
0
Comments
-
Hi Bruno.
I've done a couple of Commerce Portals but I never experienced synchronisation deadlocks. However do the NAS usually lock the table 6224 for quite a long time as the synchronisation data can be rather voluminous, and as long as NAS locks no user can change or add data to the system tables which are to be synchronised.
My workaround is to create a copy of the table 6224 and let NAS shovel the data from table 6224 into the copy, unlock the table 6224 and synchronise from the copy.
I'm not sure this is what you're looking for, but it is a common problem so I thought I post it...
Best RegardsIt is impossible to make anything foolproof, because fools are so ingenious.0 -
Good idea, I will try that if the above code change does not solve the problem. I did not consider the issue with the synch holding the lock for too long, I thought it was caused by multiple transactions hitting the table(request NAS and NAV users).
I have added a few additional tables to the synch (document lines) which causes a lot more transactions, so that is probably why I have issues.
Again, this is SQL so what I am trying to accomplish is to not do a table lock on insert, just a record level lock, and if I am not mistaken SQL will only lock the specific records that are synched (deleted), when synching (record level, or page level), however these are not touched by any other process so it "should" not matter how long they are locked in SQL.
Standard Navision does a table lock though (Locktable and Find('+')) which would have an impact and could cause conflicts. I think I can eliminate that using the code above though. The code change kind of simulates the change log, which uses the auto increment, instead of getting the last records entry number and increasing it.
Thanks for the input.
/Bruno0 -
So Bruno, what was the result of your test?
Did it help?
Im using almost standard Commerce Portal backed in Navision(Synch and to receive requests) and a completly other webshop in the Front End (I'm not that happy about Commerce Server 2000 or 2002).
The shop receives around 400 orders per day, salespeople might register max 100 orders in a day, and there is quite alot of change activity on items, but price updates etc. are done in evenings, so i don't think the volume should be a issue, but still deadlocks from time to time.0 -
I am having a similar problem to the on described above. I'm not sure if it is a table lock, or an error in the Navision Commerce Portal Synchronization service. Normally, when there is a problem, the synchronization does not produce an event log error.
Today, the service failed with the following event:
Faulting application procdriver.exe, version 3.70.2.19516, faulting module mscsups.dll, version 4.5.3810.0, fault address 0x00018894.
We are running Commerce Portal 3.70.B with SQL 2000 on a Windows 2003 Server.
Any insight would be appreciated.0
Categories
- All Categories
- 73 General
- 73 Announcements
- 66.6K Microsoft Dynamics NAV
- 18.7K NAV Three Tier
- 38.4K NAV/Navision Classic Client
- 3.6K Navision Attain
- 2.4K Navision Financials
- 116 Navision DOS
- 851 Navision e-Commerce
- 1K NAV Tips & Tricks
- 772 NAV Dutch speaking only
- 617 NAV Courses, Exams & Certification
- 2K Microsoft Dynamics-Other
- 1.5K Dynamics AX
- 322 Dynamics CRM
- 111 Dynamics GP
- 10 Dynamics SL
- 1.5K Other
- 990 SQL General
- 383 SQL Performance
- 34 SQL Tips & Tricks
- 35 Design Patterns (General & Best Practices)
- 1 Architectural Patterns
- 10 Design Patterns
- 5 Implementation Patterns
- 53 3rd Party Products, Services & Events
- 1.6K General
- 1.1K General Chat
- 1.6K Website
- 83 Testing
- 1.2K Download section
- 23 How Tos section
- 252 Feedback
- 12 NAV TechDays 2013 Sessions
- 13 NAV TechDays 2012 Sessions