Friday, December 5, 2014

Failed to elevate VKTM's priority from 0 to 60 and Failed to elevate LGWR's priority from 0 to 60 on solaris

OS : Oracle Solaris 10 1/13 s10s_u11wos_24a SPARC
Database version : 11.2.0.4

When the Oracle database started, two trace files were noticing my attention :

<SID>_lgwr_9955.trc with contents :
ksesethighpri: (ksb.c:4201) Failed to elevate LGWR's priority from 0 to 60
 Error Info: Category(-2), Opname(skgdism_send), Loc(sp.c:1667), ErrMsg(Not owner) Dism(1024)

<SID>_vktm_9946.trc with contents :
ksesethighpri: (ksb.c:4201) Failed to elevate VKTM's priority from 0 to 60
 Error Info: Category(-2), Opname(skgdism_send), Loc(sp.c:1667), ErrMsg(Not owner) Dism(1024)
 kstmmainvktm: failed in setting elevated priority
 Verify: SETUID is set on ORADISM and restart the instance
 highres_enabled
VKTM running at (100ms) precision
 kstmrmtickcntkeeper: param _dbrm_quantum will not be effective

In found the following bugs on Metalink
19651732 : ON 11204 TRACES KSESETHIGHFAILED TO ELEVATE VKTM'S AND LGWR'S PRIORITY
12951619 : DATABASE TO USE CRITICAL THREADS FEATURE IN SOLARIS. Patch needed 16387058
16605688 : PATCH 16387058 NOT CHANGING LGWR PRIORITY SCHEDULE TO FX
17344824 : LGWR CANNOT GET OS PRIORITY ALTHOUGH PATCH 12951619 APPLIED
17930649 - ORADISM IS IMPROPERLY BUILT  

But they all seemed not related to my database version (11.2.0.4)

The following note was interesting because it recommends to place the LWGR process in the FX scheduling class at priority sixty.

SPARC: Reducing High waits on 'log file sync' on Oracle Solaris SPARC by Increasing Priority of Log Writer (Doc ID 1523164.1)

To do that, the Oracle installer account (oracle) must haven been granted the proc_priocntl role.
I checked the privilege with the following command :
$ppriv -l -v zone|grep prio
and get no result, so apparently user oracle did not have the proper privileges.

Before given the proper privileges I checked the class and priority of the LGWR and VKTM processes :

$ps -ef|grep -i ora_lgwr_<SID>
oracle  9955  9935   0 08:56:56 ?           0:00 ora_lgwr_<SID>
 $ps -ef|grep -i ora_vktm_<SID>
oracle 994699350 08:56:56 ?0:00 ora_vktm_<SID>

$ps -ecl|grep 9955
0 S   1101  9955  9935   TS  59        ? 148354        ? ?           0:00 oracle
$ps -ecl|grep 9946
0 S   1101  9946  9935   TS  59        ? 146788        ? ?           0:00 oracle

There were both running with priority 59 on the timeshare class.

From the global zone the neccessary privileges were given :
global#zonecfg -z userzone
zonecfg:userzone>set limitpriv="default,proc_priocntl"

I checked it on the local with the following command :
$ppriv -l -v zone|grep prio
proc_priocntl
       Allows a process to elevate its priority above its current level.

So the privileges are in place. Just a reboot of the local zone with init 6 needed.

After the local zone and the database were booted I checked the trace files :

For the LWGR there was no trace generated. The tracefile for the VKTM was generated with the following contents :

kstmmainvktm: succeeded in setting elevated priority
 highres_enabled
VKTM running at (1)millisec precision with DBRM quantum (100)ms
 [Start] HighResTick = 742578877597
 kstmrmtickcnt = 0 : ksudbrmseccnt[0] = 1417769168

So setting the elevated priority for the VKTM process succeeded.

Again I checked the class and priority of the LGWR en VKTM processs :
oracle  6246  6236   FX  60        ? 160986        ? 08:43:05 ?           0:00 ora_lgwr_<SID>
oracle  6237  6236   RT 101        ? 159588        ? 08:43:05 ?           0:03 ora_vktm_<SID>

The priority and class for the LGWR changed from 59 and TS to 60 and FX (fixed-priority). For the VKTM it changed from 59 and TS to 101 and RT (real-time).

So the only thing needed was to give the Oracle installer account the neccessary proc_priocntl privilege.

Note :
Hidden parameter "_high_priority_processes" tells Oracle to automatically set background processes to a higher than normal priority when the database is started. For my database the parameter has the following value  :
_high_priority_processes LMS*|LGWR|VKTM                         

So Oracle tried to set the priority for the LWGR and VKTM background processes higher than normal priority. Probably the Oracle installer account needed the proc_priocntrl privilege.

Critical Thread is a new scheduler optimization available in Oracle Solaris releases Solaris 10 Update 10 (8/11) and later versions. From database point of view, logwriter (lgwr) is one such process that can benefit from CT optimization on Solaris platform.

No comments:

Post a Comment