An update conflict has occurred

Nei giorni scorsi Trevor Seward (@NaupliusTrevor) ha pubblicato un articolo molto interessante che consiglio a tutti: What is the SharePoint Configuration Cache. Questo post mi ha dato lo spunto per parlare di un errore che ultimamente ho riscontrato di frequente.

L’errore in questione è il seguente e, come si intuisce anche dal messaggio, è il risultato di una delle possibili cause di fallimento del Configuration Wizard.

An exception of type Microsoft.SharePoint.Administration.SPUpdatedConcurrencyException was thrown. Additional exception information: An update conflict has occurred, and you must re-try this action. The object SPUpgradeSession Name=Upgrade-20120310-130057-953 was updated by XXXX\svcSP_Farm, in the PSCONFIG (5168) process, on machine APP01. View the tracing log for more information about the conflict.

(more…)

Ripristinare timer job definition

Recentemente mi è capitato di seguire un attività di troublshooting su una farm MOSS “gambizzata”. Per errore erano state eliminate tutte le timer job definitions. Per alcune di queste una soluzione, forse poco elengante, è quella di (ri)creare la web application ed effettuare quindi il restore dei dati. Di fatto il solo restore non è sufficiente affinchè vengano ricreate le timer job definitions.

Ma questo non vale per tutti i timer job. Ad esempio non vale per l’Application Server Timer Job e l’Application Server Administration Service Timer Job, dettagli no?? Dopo un po di ricerche ho scoperto che questi timer job vengono creati dalla feature Shared Services, quindi per ripristinari “basta” reinstallare la feature via stsadm. Il comando completo è il seguente:

stsadm -o installfeature -name SharedServices -force

I timer job che vengono ricreati sono: Application Server Timer Job, Application Server Administration Service Timer Job, Licensing Synchronizer Job.

<Edit>
Prima di arrendermi all’evidenza ho provato anche la strada Powershell, ho letto più di un post che parlava di come creare timer job definition con ps. Purtroppo mi blocco alla lettura delle timer job definition presenti per la mia web application. Condivido con voi lo script, se qualcuno avesse voglia e tempo di completarlo mi faccia sapere, sono curioso :)

[void][reflection.assembly]::LoadWithPartialName(“Microsoft.SharePoint”)
[void][reflection.assembly]::LoadwithPartialName(“Microsoft.Office.Server”)

$SPSite = New-Object Microsoft.SharePoint.SPSite(“http://moss“)

$webApp = $SPSite.WebApplication

foreach ($timerjob in $webApp.JobDefinitions){
    Write-Host $timerjob.TypeName, $timerjob.Name, $timerjob.ID, $timerjob.Parent;
}

Qui potete trovare maggiori dettagli sulle informazioni disponibili in JobDefinitions. Ai fini pratici questo script non mi è servito proprio a niente, in compenso mi sono divertito a fare un po’ di pratica su Powershell ;)

</Edit>

– Riccardo