So, we have some development going on using Open UI. All you folks who have worked on Open UI will know this. There is one thing that is consistent across the board – “bugs”.
In our constant fight against those bugs we have decided to go “bleeding edge”. Imbibe every patch for our Siebel version and keep that up every month. This is against our “traditional” way of doing things, but that did not matter since there were bigger issues to solve.
As part of this story – we recently implemented Siebel the Patchset 6 on 8.1.1.11.
In the next two days we saw an increase in the number of crashes while using the application. Siebel crash increasingly became the most loved word and was reported all over the place, but were not serious enough to warrant immediate action.
But of course we are not kind to crashes in many ways. We do what every good developer does.
- Go to the server
- Get a CSV file from the FDR, get crash.txt, and get the Siebel log file
- See which view and what action crashes the application
>> See a more detailed post on how to debug Siebel application crashes <<
Crashes are not hard to debug, but they cannot be called straight-forward. If there are more than a few actions that can cause crash – you are guaranteed to an exciting life for the next 1-2 hours.
The FDR file showed more than 2 distinct errors on the crashing thread.
We take the process id from here and get going through the log files.
Do take note while selecting the log file. Siebel Object Managers are multi-threaded. Multiple processes run on one thread and one process crash can bring down the entire thread. Don’t get confused if you don’t see crash causes in one of the log files. You are just seeing a log that is unrelated to the crash. The best way to pick the log file is by looking for the process id suffixed in the FDR file.
Log file analysis did not turn up anything great. But a pattern was observed – most of the log files and FDR files pointed to one custom view developed a while back.
Crash file was not very useful in this case.
Exception 0xc0000005 at 0x00933849 Thread: 0x0000155c, Process 0x000027cc - CONTEXT - EIP: 0x771c9f45, EFL: 0x00010216, FS: 0x00000053, GS: 0x0000002b CS: 0x00000023, DS: 0x0000002b, SS: 0x0000002b, ES: 0x0000002b EAX: 0xffffffff, EBX: 0x008fa240, ECX: 0x0098fff4, EDX: 0x166b68d4 ESI: 0x0098fff0, EDI: 0x0098fff4, EBP: 0x0018ffec, ESP: 0x0018ffdc - CALL STACK - sslcshar +0x53849 = CCFAtomics::Decrement() +0x9 sslcshar +0x19108 = SSstring::operator=() +0x28 sslcsrvr +0x5f66 = CrashDiagMgr::GetLogFileByCompName() +0xa6 ssmsgbrd +0x3746 = LessComparison::operator()() +0x1fd6 ssmsgbrd +0x747c = LessComparison::operator()() +0x5d0c ssmsgbrd +0x78d3 = LessComparison::operator()() +0x6163 sscfom +0x18cac = CSSService::InvokeMethod() +0x24c sssabsvm +0x3438 = CompMain() +0x378 siebprocmw +0x1d37 siebprocmw +0x4bc9 = SmiBeginTrace() +0x16d9 kernel32 +0x1336a = BaseThreadInitThunk() +0x12 ntdll +0x39f72 = RtlInitializeExceptionChain() +0x63 ntdll +0x39f45 = RtlInitializeExceptionChain() +0x36 - STACK DUMP - 0018ffdc: 86 4a 40 00 00 e0 fd 7e ff ff ff ff 28 74 25 77 .J@....~....(t%w 0018ffec: 00 00 00 00 00 00 00 00 86 4a 40 00 00 e0 fd 7e .........J@....~
The custom view now got into burning focus. We check the intense changes going on in the server –
- Changes to that view, screen, associated applets and BCs
- SRF updates in other parts of the application
- LOV updates, Symbolic String updates
- Runtime event updates
- Docking rule changes
Although there is no trusting any development team, it so happens that we have the best team possible on the job. But this consistent crash in only one Siebel view was turning out to be a hard nut to crack.
- SRF, Repository, Runtime updates were reverted to previously working versions to no avail
- Reverting LOVs from backups seemed to solve the problem for some time, but not for all time. We also had lot of MLOV conversions and this aggravated the permutations that we had to play with
After spending a more than 6 hours and not getting any results, we came back to our favorite topic. Oracle Siebel Patchset 6 that had been installed 2 days previously had to go. After an excruciating wait to uninstall the patch we see that the problem resolved itself.
Stumped? Yes, that’s the word.
The next cycle of “create SR”, “wait”, and “wait some more” started for the newly identified issue, while development continues on Patchset 5.
After a week passed a kind soul from Oracle noticed that we were not lying and indeed on Patchset 6. And, Patchset 6 caused random crashes in the application. The work-around provided was to set a (hitherto unheard) system preference value “Defer Object Initialization” to TRUE.
Patchset now goes back to 6, system preference is set, and the wait begins for more excitement from the next patchset.
No matter how many times we see problems with the patch I continue to be surprised why we trust the patch more than our own code. A simple uninstall would have saved those 6 hours of debugging time. But the log files/FDRs were successful in being cryptic about the errors like never before.
But why on earth should Patchset 6 not like only one view of the hundreds we have? That’s a good question for Sherlock Holmes, not for mortals.
Refer this Oracle Support Document for more details.