UPA Up and Running best practices report by SPDocKit determines whether all user profile services are running in the farm.
Issue description
This check determines whether all user profile services are running in the farm.
Explanation
The User Profile service is a shared service in SharePoint Server 2013 that enables the creation and administration of user profiles that can be accessed from multiple sites and farms. Using Profile Synchronization, SharePoint Server 2013 enables User Profile service administrators to synchronize user and group profile information stored in the SharePoint Server 2013 profile store with profile information stored in directory services and business systems across the enterprise.
Not running user profile services will result in non-functioning social features and SharePoint apps. It will also affect any third-party code that implements features depending on the SharePoint user profiles or SharePoint social features.
Solution
Make sure that all user profile services are running on one or more servers. Provisioning User Profile service on more than one server will ensure high service availability. Note that you can provision only one instance of User Profile Synchronization service.
To verify that the service application is created, please go to the Central Administration > Application Management > Manage service applications. To verify that the service instances are started and configured properly, go to Central Administration > Application Management > Manage services on server.
This script retrieves the health status of all User Profile Service Applications. It checks the following:
at least one User Profile Service Application is provisioned
all User Profile Service Applications have an User Profile Synchronization service instance provisioned
all User Profile Service Applications have at least one User Profile Service instance provisioned
status of the running profile synchronization jobs. If running longer than a defined threshold, it will display a warning message (default: 24h).
param( [int]$UPASyncRunningThreshold=24)Write-Host""Write-Host"Checking User Profile Service Applications... "-NoNewLine$upaCol = Get-SPServiceApplication |where{$_.TypeName-eq"User Profile Service Application"}$upasync = Get-SPServiceInstance | where {$_.TypeName -eq "User Profile Synchronization Service" -and $_.Status -eq "Online"}
if ($upaCol -ne $null){Write-Host"$($upaCol.Count) found!"-ForegroundColorGreenWrite-Host""Write-Host"=========================================================================" foreach ($upa in $upaCol) {Write-Host"User Profile Service Application: $($upa.DisplayName)"Write-Host"UPA Sync: "-NoNewLineif (($upasync | where {$_.UserProfileApplicationGuid -eq $upa.Id}) -eq $null) {Write-Host"not provisioned"-ForegroundColorRed }else {Write-Host"provisioned, healthy"-ForegroundColorGreen }Write-Host"User Profile Service instances: "-NoNewLine $upasvcCount = [int]$($upa.ServiceInstances |where{$_.Status-eq"Online"}).Countswitch ($upaSvcCount) {0{Write-Host"none found"-ForegroundColorRed} 1 {Write-Host "1 found. Consider deploying additional instance for high availability." -ForegroundColor Yellow}
default{Write-Host"$upaSvcCount"-ForegroundColorGreen} }Write-Host"Checking profile synchronization status: "-NoNewLineif ($upa.IsSynchronizationRunning) {# check if running for more hours than specified in the thresholdWrite-Host"" $upaTimerJob = Get-SPTimerJob | Where {$_.DisplayName -eq "$($upa.DisplayName) - User Profile Incremental Synchronization"}
if ($upaTimerJob -eq $null) { Write-Host "Profile synchronization is running but the user profile synchronization timer job could not be found." -ForegroundColor Red
}else { $runningTime = [datetime]::Now - ($upaTimerJob.SynchronizationStatus | where {$_.Stage -eq "StartSynchronization"}).BeginTime
if ($runningTime.TotalHours -gt $UPASyncRunningThreshold) {Write-Host"Running for more than $UPASyncRunningThreshold"-ForegroundColorYellow Write-Host "Running since $(($upaTimerJob.SynchronizationStatus | where {$_.Stage -eq "StartSynchronization"}).BeginTime) ($($runningTime.ToString()))." -ForegroundColor Yellow
Write-Host"You may consider checking the synchronization job."-ForegroundColorYellow }else { Write-Host "Running since $(($upaTimerJob.SynchronizationStatus | where {$_.Stage -eq "StartSynchronization"}).BeginTime) ($($runningTime.ToString()))." -ForegroundColor Green
# still green } } }else {Write-Host"idle"-ForegroundColorGreen }Write-Host"========================================================================="Write-Host"" }}else{Write-Host"None found!"-ForegroundColorRed}
Additional information
Additional information can be found in the following TechNet articles: