Bienvenue à Blogs CodeS-SourceS Identification | Inscription | Aide

Blog Technique de Romelard Fabrice

Les dernières Actualités de Romelard Fabrice (Alias fabrice69 ou F___) principalement autour des technologies Microsoft

Actualités

  • Toutes les actualités et informations sur les technologies Microsoft principalement autour de .NET et SQL Server

Archives

SharePoint : Version améliorée du script de contrôle des alertes SharePoint

Dans un précédent message, nous avons vu comment relancer le service SPTimerV3 à distance pour une liste définie de serveurs.

Ce script fonctionne parfaitement, mais force le redémarrage du service NT, même si cela n’est pas du tout nécessaire. Le fait est que le cas particulier des Alertes bloquées réside dans le blocage d’un Job SharePoint qui ne va pas au bout de son travail et reste dans un statut intermédiaire.

Ainsi, cette première version redémarrait en force ce service NT sans aucun test de validité, ce qui n’est pas optimal. De ce fait, une nouvelle version beaucoup plus aboutie a été écrite afin de :

  • Lister tous les Jobs SharePoint de la ferme en cours
  • Faire un test du statut des job “Immediate Alerts” pour tous les serveurs SharePoint de la ferme
    • Si sur une des machines de la ferme, un des Job “Immediate Alerts” est dans un statut différent de “Succeeded” depuis plus d’un jour
      • Effectue un redémarrage du service NT “SPTimerV3”
      • Envoie un mail via SMTP à l’administrateur pour ce redémarrage avec le nom de la machine

On peut donc ensuite retrouver les messages de redémarrage dans son Outlook comme sur cet exemple :

image

Avec le détail :

image

Ce qui permet donc par la suite d’intervenir si ce redémarrage est trop régulier sur la machine.

Cette tache peut-être ensuite planifiée sur chaque ferme SharePoint.


function Send-SMTP-Message([string]$fromAdress, [string]$toAdress, [string]$SmtpServerAddress, [string]$SubjectTextToSend, [string]$MessageTextToSend)
{
    $from = New-Object System.Net.Mail.MailAddress $fromAdress
    $to =   New-Object System.Net.Mail.MailAddress $toAdress

    # Create Message
    $message = new-object  System.Net.Mail.MailMessage $from, $to
    $message.Subject = $SubjectTextToSend
    $message.Body = $MessageTextToSend

    # Set SMTP Server and create SMTP Client 
    $server = $SmtpServerAddress 
    $client = new-object system.net.mail.smtpclient $server 
 
    # Send the message 
    "Sending an e-mail message to {0} by using SMTP host {1} port {2}." -f $to.ToString(), $client.Host, $client.Port
    $client.Send($message)
    "Message to: {0}, from: {1} has beens successfully sent" -f $from, $to 
}

function Restart-Service-AllServer([string]$MyServiceName, [Array]$MyServers, [string]$fromAdress, [string]$toAdress, [string]$SmtpServerAddress)
{
    foreach($myServer in $MyServers)
    {
        [string]$SubjectToSend = "Restart of the Service", $MyServiceName, "For the Server", $myServer
        [string]$MessageToSend = $SubjectToSend.ToString(), "-", (Get-Date).ToString()
        Write-Host $MessageToSend
        Get-WmiObject -computer $myServer Win32_Service -Filter "Name='$MyServiceName'"| Restart-Service -Force
        Send-SMTP-Message $fromAdress $toAdress $SmtpServerAddress $SubjectToSend $MessageToSend
    }
}

function Restart-JobService-SPFarm([string]$MyJobTimerName, [string]$MyServiceName, [string]$fromAdress, [string]$toAdress, [string]$SmtpServerAddress)
{
    [Array] $ServersNeedtobeRestarted = @()

    [Void] [System.Reflection.Assembly]::LoadWithPartialName("Microsoft.SharePoint")
    $MyFarm = [Microsoft.SharePoint.Administration.SPfarm]::Local
    [Microsoft.SharePoint.Administration.SPWebServiceCollection]$mywebServices = new-object Microsoft.SharePoint.Administration.SPWebServiceCollection($MyFarm)

    Write-Host " ------------------------------------------------------------ "
    foreach ($mywebService in $mywebServices)
    {
        $MyWebApplications = $mywebService.WebApplications;
        foreach ($myWebApp in $MyWebApplications)
        {
            if($myWebApp.RunningJobs.Count -gt 0)
            {
                Write-Host " - Name:", $mywebService.Name, "- WEb Application Name:", $myWebApp.Name
                $MyWebAppRunningJobs = $myWebApp.RunningJobs|Where{$_.JobDefinitionTitle -eq $MyJobTimerName}
                foreach($myRunningjob in $MyWebAppRunningJobs )
                {
                    Write-Host " - JobDef Title:", $myRunningjob.JobDefinitionTitle, "- ServerName:", $myRunningjob.ServerName, "- Status:", $myRunningjob.Status , "- PercentDone:", $myRunningjob.PercentageDone.ToString(), "- StartTime:", $myRunningjob.StartTime.ToString()
                    $DiffDate = ((Get-Date) - $myRunningjob.StartTime).Days
                    if(($DiffDate -gt 0) -and ($myRunningjob.Status -ne "Succeeded"))
                    {
                        Write-Host "     ==>>>> Job need to be restarted - DiffDate:", $DiffDate, "days - Server", $myRunningjob.ServerName
                        $ServersNeedtobeRestarted += $myRunningjob.ServerName
                    }
                }
            }
        }   
    }
    Write-Host " ------------------------------------------------------------ "

    $ServersNeedtobeRestarted =  $ServersNeedtobeRestarted |Select-Object -Unique
    Write-Host "Server: ", $ServersNeedtobeRestarted
   
    if($ServersNeedtobeRestarted.length -gt 0)
    {
        Write-Host "     ==>>>> Restart the service ", $MyServiceName, "on the servers:", $ServersNeedtobeRestarted
        Restart-Service-AllServer $MyServiceName $ServersNeedtobeRestarted $fromAdress $toAdress $SmtpServerAddress
    }
}

cls

$EmailFrom = "MOSSIntranet@mycompany.com"
$Manageremail = "SharePointManager@mycompany.com"
$smtpServer = "smtp-Server-Address.mycompany.com"

$MyServiceNameToCheck = "SPTimerV3"
$myJobTimerNameToCheck = "Immediate Alerts"
Restart-JobService-SPFarm $myJobTimerNameToCheck $MyServiceNameToCheck $EmailFrom $Manageremail $smtpServer


Vous pouvez retrouver comme toujours ce script sur le site CodePlex créé pour ce type d’outils :

Romelard Fabrice [MVP]

Ce post vous a plu ? Ajoutez le dans vos favoris pour ne pas perdre de temps à le retrouver le jour où vous en aurez besoin :
Posted: jeudi 25 novembre 2010 15:54 par ROMELARD Fabrice

Commentaires

lognoulm a dit :

Bonjour Fabrice,

Pour faciliter la journalisation et l'envoi d'e-mail par les scripts, le framework LOG4NET peut s'avérer très utile http://logging.apache.org/log4net/.

Un wrapper pour PowerShell est disponible sur CodePlex: http://log4posh.codeplex.com/

# décembre 13, 2010 09:27
Les commentaires anonymes sont désactivés

Les 10 derniers blogs postés

- Merci par Blog de Jérémy Jeanson le 10-01-2019, 20:47

- Office 365: Script PowerShell pour auditer l’usage des Office Groups de votre tenant par Blog Technique de Romelard Fabrice le 04-26-2019, 11:02

- Office 365: Script PowerShell pour auditer l’usage de Microsoft Teams de votre tenant par Blog Technique de Romelard Fabrice le 04-26-2019, 10:39

- Office 365: Script PowerShell pour auditer l’usage de OneDrive for Business de votre tenant par Blog Technique de Romelard Fabrice le 04-25-2019, 15:13

- Office 365: Script PowerShell pour auditer l’usage de SharePoint Online de votre tenant par Blog Technique de Romelard Fabrice le 02-27-2019, 13:39

- Office 365: Script PowerShell pour auditer l’usage d’Exchange Online de votre tenant par Blog Technique de Romelard Fabrice le 02-25-2019, 15:07

- Office 365: Script PowerShell pour auditer le contenu de son Office 365 Stream Portal par Blog Technique de Romelard Fabrice le 02-21-2019, 17:56

- Office 365: Script PowerShell pour auditer le contenu de son Office 365 Video Portal par Blog Technique de Romelard Fabrice le 02-18-2019, 18:56

- Office 365: Script PowerShell pour extraire les Audit Log basés sur des filtres fournis par Blog Technique de Romelard Fabrice le 01-28-2019, 16:13

- SharePoint Online: Script PowerShell pour désactiver l’Option IRM des sites SPO non autorisés par Blog Technique de Romelard Fabrice le 12-14-2018, 13:01