Friday, March 15, 2013
CONFIGURATION DE LA TOPOLOGIE DE RECHERCHE SHAREPOINT 2013
Les GEDs SharePoint dépassent couramment le million de documents.
Dans ce contexte, il faut créer (au moins) deux indexeurs en équilibre de charge, ce qui nous permettra en plus d’offrir de la tolérance de panne.
1. Préambule
La source d’info :
On retrouve logiquement une grande partie du paramétrage de fast sur http://technet.microsoft.com/fr-fr/library/jj219705.aspx
Les prérequis :
Pas de tests en prod !
- Deux serveurs SharePoint 2013 sur lesquels on n’a pas encore crée de service de recherche (de toute façons, vous ne voulez pas du wizard pour une install en production ;)
o Le service de recherche ne doit pas être démarré sur les autres nœuds. Si oui, il faut faire un STOP service( ?)
- Un répertoire local de stockage sur chaque serveur ou (mieux) plusieurs répertoires sur un espace partagé. Ils doivent exister et êtres vides.
o Sur ces répertoires, le compte de ferme doit avoir le contrôle. Ceci se fait en accordant une permission au groupe local WSS_ADMIN_WPG qui le contient.
o Un bug fait que les répertoires sont testés localement sur le serveur ou on lance le script. Ils doivent donc être tous être crées sur ce nœud si le stockage est local.
- Classiquement :
o Ouvrir une session avec le compte d’Install de la ferme
o Lancer Powershell en mode administrateur
Si vous avez créé un service de recherche avec une topologie incorrecte, ou que le script échoue, une chance, dropper un service applicatif prend deux lignes
$spapp = Get-SPServiceApplication -Name "Search Service Application"
Remove-SPServiceApplication $spapp -RemoveData
A faire avant chaque tentative. Gardez aussi à l’esprit que l’ordonnanceur interne de SharePoint n’est pas en temps réel, il vaut mieux donc attendre 5 mn avant de relancer le script au cas où un job serait encore dans la file du SPTIMER.
2. Les rôles
On doit répartir les rôles query, admin, stats et content sur nos deux nœuds.
Dans mon exemple, je suivrais la matrice suivante :
ROLE SPIDX1 (Principal) SPIDX2 (Backup)
CRAWL X X
ADMIN X
CONTENT X X
STATS X
QUERY X X
3. Les partitions
- Le minimum pour l’équilibrage est deux partitions (0/1)
- Le minimum pour la tolérance de panne est de découper en un maitre et un replica pour chaque partition (0/1 répliqué en 1/0)
On aura donc quatre composants Index.
4. Le script
Partant de cette configuration, on peut commencer à écrire le script :
J’ai utilisé la nomenclature du technet.
# RAZ!
# Supprime le service applicatif et les BDD existantes
$spapp = Get-SPServiceApplication -Name "Search Service Application"
Remove-SPServiceApplication $spapp -RemoveData
#==============================================================
#Configuration Search Service Application (SSA)
#==============================================================
$SearchApplicationPoolName = "SearchAdminApplicationPool"
$SearchApplicationPoolAccountName = "SP2013\SP_SEARCH"
$SearchServiceApplicationName = "Search Service Application"
$SearchServiceApplicationProxyName = "Search Service Application Proxy"
$DatabaseInstance = "SQL2012\SPSQL2013"
$DatabaseName = "Sharepoint2013_SearchService"
#Nom des serveurs d’index
$App1 = “SPIDX1”
$App2 = "SPIDX2"
#Reps Exemples. Attention à mettre deux reps differents en Stockage partagé!
$IndexLocationServer1 = "D:\IDX_HostA"
$IndexLocationServer2 = "D:\IDX_HostB"
# Création des reps (avec le bug local)
New-Item -Path "\\SPIDX1\d$\IDX_HOSTA" -type directory -force
New-Item -Path "\\SPIDX1\d$\IDX_HOSTB" -type directory -force
New-Item -Path "\\SPIDX2\d$\IDX_HOSTB" -type directory -force
#==============================================================
# Création du Pool s’il n’existe pas
#==============================================================
Write-Host -ForegroundColor DarkGray "Test – Pool SSA"
$SPServiceApplicationPool = Get-SPServiceApplicationPool -Identity $SearchApplicationPoolName -ErrorAction SilentlyContinue
if (!$SPServiceApplicationPool)
{
Write-Host -ForegroundColor Yellow "Création – Pool SSA"
$SPServiceApplicationPool = New-SPServiceApplicationPool -Name $SearchApplicationPoolName -Account $SearchApplicationPoolAccountName -Verbose
}
#==============================================================
#Search Service Application
#==============================================================
Write-Host -ForegroundColor DarkGray "Test - SSA"
$SearchServiceApplication = Get-SPEnterpriseSearchServiceApplication -Identity $SearchServiceApplicationName -ErrorAction SilentlyContinue
if (!$SearchServiceApplication)
{
Write-Host -ForegroundColor Yellow "Création - SSA"
$SearchServiceApplication = New-SPEnterpriseSearchServiceApplication -Name $SearchServiceApplicationName -ApplicationPool $SPServiceApplicationPool.Name -DatabaseServer $DatabaseInstance -DatabaseName $DatabaseName
}
Write-Host -ForegroundColor DarkGray "Test - SSA Proxy"
$SearchServiceApplicationProxy = Get-SPEnterpriseSearchServiceApplicationProxy -Identity $SearchServiceApplicationProxyName -ErrorAction SilentlyContinue
if (!$SearchServiceApplicationProxy)
{
Write-Host -ForegroundColor Yellow "Création - SSA Proxy"
New-SPEnterpriseSearchServiceApplicationProxy -Name $SearchServiceApplicationProxyName -SearchApplication $SearchServiceApplicationName
}
#==============================================================
# Démarrer le service – IDX1
#==============================================================
$HostA = Get-SPEnterpriseSearchServiceInstance -Identity $App1
Write-Host -ForegroundColor DarkGray "Test – SSI 1"
if($HostA.Status -ne "Online")
{
Write-Host -ForegroundColor Yellow "Démarrage – SSI 1"
Start-SPEnterpriseSearchServiceInstance -Identity $HostA
While ($HostA.Status -eq "Online")
{
Start-Sleep -s 5
}
Write-Host -ForegroundColor Yellow "SSI 1 Démarré"
}
#==============================================================
# Démarrer le service – IDX2
#==============================================================
$HostB = Get-SPEnterpriseSearchServiceInstance -Identity $App2
Write-Host -ForegroundColor DarkGray " Test – SSI 2"
if($HostB.Status -ne "Online")
{
Write-Host -ForegroundColor Yellow " Démarrage– SSI 2"
Start-SPEnterpriseSearchServiceInstance -Identity $HostB
While ($HostB.Status -eq "Online")
{
Start-Sleep -s 5
}
Write-Host -ForegroundColor Yellow "SSI 2 Démarré"
}
#==============================================================
# Créer une nouvelle topologie vide pour pouvoir la modifier, et la remplir.
#==============================================================
$InitialSearchTopology = $SearchServiceApplication |
Get-SPEnterpriseSearchTopology -Active
$NewSearchTopology = $SearchServiceApplication | New-SPEnterpriseSearchTopology
#==============================================================
# Composants IDX1 : Stats, Index, Crawl, Admin, Query
#==============================================================
New-SPEnterpriseSearchAnalyticsProcessingComponent -SearchTopology $NewSearchTopology -SearchServiceInstance $HostA
New-SPEnterpriseSearchContentProcessingComponent -SearchTopology $NewSearchTopology -SearchServiceInstance $HostA
New-SPEnterpriseSearchCrawlComponent -SearchTopology $NewSearchTopology -SearchServiceInstance $HostA
New-SPEnterpriseSearchAdminComponent -SearchTopology $NewSearchTopology -SearchServiceInstance $HostA
New-SPEnterpriseSearchQueryProcessingComponent -SearchTopology $NewSearchTopology -SearchServiceInstance $HostA
#==============================================================
# Composants IDX2: Index, Crawl, Query (noeud de backup)
#==============================================================
New-SPEnterpriseSearchContentProcessingComponent -SearchTopology $NewSearchTopology -SearchServiceInstance $HostB
New-SPEnterpriseSearchCrawlComponent -SearchTopology $NewSearchTopology -SearchServiceInstance $HostB
New-SPEnterpriseSearchQueryProcessingComponent -SearchTopology $NewSearchTopology -SearchServiceInstance $HostB
#==============================================================
# Création de deux indexs, deux partitions = 4 replicas
# spécifier les répertoires permet d'éviter de le stocker dans "Office Servers..."
# A = 0/1 B= 1/0
#==============================================================
New-SPEnterpriseSearchIndexComponent -SearchTopology $NewSearchTopology -SearchServiceInstance $HostA -IndexPartition 0 -RootDirectory $IndexLocationServer1
New-SPEnterpriseSearchIndexComponent -SearchTopology $NewSearchTopology -SearchServiceInstance $HostB -IndexPartition 1 -RootDirectory $IndexLocationServer2
New-SPEnterpriseSearchIndexComponent -SearchTopology $NewSearchTopology -SearchServiceInstance $HostA -IndexPartition 1 -RootDirectory $IndexLocationServer1
New-SPEnterpriseSearchIndexComponent -SearchTopology $NewSearchTopology -SearchServiceInstance $HostB -IndexPartition 0 -RootDirectory $IndexLocationServer2
#==============================================================
# Enregistrement de la topologie
#==============================================================
Write-Host -ForegroundColor Yellow "Enregistrement tolologie"
Set-SPEnterpriseSearchTopology -Identity $NewSearchTopology
#==============================================================
# Suppression de l’ancienne
#==============================================================
Write-Host -ForegroundColor DarkGray "Suppression tolologie.old"
Remove-SPEnterpriseSearchTopology -Identity $InitialSearchTopology -Confirm:$false
Write-Host -ForegroundColor Yellow "Supprimée"
#==============================================================
#Check Search Topology
#==============================================================
Get-SPEnterpriseSearchStatus -SearchApplication $SearchServiceApplication -Text
Write-Host -ForegroundColor Yellow "Topologie configurée!"
5. Résultat attendu :
On peut aussi tester en ligne de commande par, par exemple,
Get-SPEnterpriseSearchStatus –SearchApplication « Serch Service Application"
Emmanuel ISSALY
Architecte Infrastructure Sharepoint
MCNEXT
Subscribe to:
Comments (Atom)