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 : Optimisations des performances d’un site Intranet de type Publishing

Lorsqu’on utilise SharePoint comme site Intranet, il est important de fournir le meilleur service à ses utilisateurs. L’amélioration des performances fait partie de cette tache.

Un article plus détaillé sur le sujet est en cours de rédaction, mais je peux vous donner quelques grandes pistes de travail :

Ce rapport vous donnera de nombreuses informations comme :

  • les réponses HTTP anormales
  • le poids total du flux lors du chargement
  • les fichiers avec un poids anormal (images lourdes par exemple)
  • la taille du ViewState ASP.NET

Dans notre contexte SharePoint Publishing, cela peut sembler inutile, mais ces informations sont capitales, car chaque kb économisé est à multiplier par le nombre d’utilisateurs et le nombre de page utilisées.

LES IMAGES

Il est inutile de remonter une image de plus de 600*800, vous devez absolument éduquer vos content managers qui réalisent rarement l’impact d’une image en 3000*4000 affichée dans une image taillée à 100 px de large.

La compression des image JPG est aussi un autre travail à faire pour tous les logos et images génériques de news par exemple (mais aussi toutes celles que vous compter utiliser).

Pour cela je vous propose le script PowerShell simple, il vous suffit d’ouvrir le site SharePoint en mode Explorer, puis de copier les images dans un folder (par exemple “F:\TEMP\PICTURES\”) et de lancer le script PowerShell suivant :

[int]$GLOBAL:TotalPicturesUpdated = 0

function ResizePicture([string]$FilePath)
{
    [System.Reflection.Assembly]::LoadWithPartialName("System.Drawing") > $null

    #$bmp = new-object System.Drawing.Bitmap($stream)
    $bmp = [System.Drawing.Bitmap]::FromFile($FilePath)

    [int]$PictureHeight = $bmp.Size.Height
    [int]$PictureWidth = $bmp.Size.Width

    $BMPTemp = new-object System.Drawing.Bitmap($PictureWidth, $PictureHeight)

    $graphicTemp = [System.Drawing.Graphics]::FromImage($BMPTemp)
    $graphicTemp.CompositingMode = [System.Drawing.Drawing2D.CompositingMode]::SourceOver
    $graphicTemp.CompositingQuality = [System.Drawing.Drawing2D.CompositingQuality]::HighQuality
    $graphicTemp.SmoothingMode = [System.Drawing.Drawing2D.SmoothingMode]::HighQuality
    $graphicTemp.InterpolationMode = [System.Drawing.Drawing2D.InterpolationMode]::HighQualityBicubic
    $graphicTemp.PixelOffsetMode = [System.Drawing.Drawing2D.PixelOffsetMode]::HighQuality
    $graphicTemp.DrawImage($bmp, 0, 0, $PictureWidth, $PictureHeight)
    $graphicTemp.Dispose()

    $bmp.Dispose()
    #Write-Host "Pixel: ", $BMPTemp.PixelFormat.ToString()
    $BMPTemp.Save($FilePath, [System.Drawing.Imaging.ImageFormat]::Jpeg)
    $BMPTemp.Dispose()

}

function StartProcess()
{
    # Create the stopwatch
    [System.Diagnostics.Stopwatch] $sw;
    $sw = New-Object System.Diagnostics.StopWatch
    $sw.Start()
    cls

    $results = (Get-childItem F:\TEMP\PICTURES\* -include *.jpg -recurse)

    foreach($myPicture in $results)
    {
        Write-host "[", $myPicture.FullName, "] - Before Resizing:", $myPicture.Length, "Bytes"
        ResizePicture $myPicture.FullName
        $GLOBAL:TotalPicturesUpdated +=1
    }

    $sw.Stop()
    # Write the compact output to the screen

    write-host " "
    write-host " "
    write-host " ------------------------------------------------------------- "
    write-host " ----", $GLOBAL:TotalPicturesUpdated " pictures updated in Time: ", $sw.Elapsed.ToString(), "----"
    write-host " ------------------------------------------------------------- "
    write-host " "
}

cls
StartProcess

Vous aurez alors une réduction de plus de 30% de la taille globale.

Vous pouvez alors simplement reprendre les fichiers résultat et les uploader à la place des précédentes versions.

LE VIEWSTATE

Cette partie est plus délicate, mais dans mon cas, cela représente environ 15 à 20 % du fichier HTML envoyé à l’utilisateur (plus de 100 KB de ViewState)

image

Après quelques recherches, je suis tombé sur ces deux articles :

Le premier explique de facon didactique qu’une grande partie du ViewState généré de base est produit par l’objet ASP.NET “SharePoint:AspMenu” et que ce ViewState généré est totalement inutile pour la navigation.

Il est donc possible de modifier la Master Page de son site de publishing et de modifier celle-ci en désactivant le ViewState pour les objets du Menu (de haut et de gauche). Les objets à modifier sont donc :

  • SharePoint:AspMenu
  • PublishingNavigation:PortalSiteMapDataSource

Il faut donc rajouter l’option suivante dans les balises de ces objets :

  • EnableViewState="false"

Cette modification est confirmé par le second lien en rapport avec SP 2010

Vous sauvegardez cette master page et l’appliquez pour votre site intranet.

Une petite analyse par Fiddler et neXpert vous confirme le résultat, pour mon cas :

image

Je vous conseille de valider ce changement sur une plateforme de pré-production avant toute mise en ligne.

Il reste beaucoup d’autres axes d’amélioration, mais ceci sera pour un prochain article.

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: mercredi 7 juillet 2010 19:02 par ROMELARD Fabrice

Commentaires

ROMELARD Fabrice a dit :

Petit détail quand on utilise Fiddler, il faut couper tous les autres soft qui font des requêtes HTTP (genre Outlook par exemple pour des synchro de flux RSS).

Sinon tout le résultat est faussé.

Je viens de tester et le changement du paramètre pour le menu semble ne pas poser de soucis sur les usage (navigation ou édition de pages)

Mise en production certainement dans 1 semaine

Romelard Fabrice [MVP]

# juillet 8, 2010 18:15

lognoulm a dit :

Bonjour Fabrice,

Excellent article et très bonne idée ce script.

Pour analyser le traffic HTTP de manière visuelle, tu peux également utiliser l'outil Visual Round Trip Analyzer (http://www.microsoft.com/downloads/details.aspx?FamilyID=119f3477-dced-41e3-a0e7-d8b5cae893a3&displaylang=en)

Marc

# juillet 16, 2010 18:25

ROMELARD Fabrice a dit :

Merci Marc,

En fait je prends aussi FireBug maintenant avec pas mal de détails et de propositions d'amélioration.

D'ailleurs, après usage, la désactivation du ViewState dans le menu, n'est pas forcément une bonne idée dans un Intranet.

Je vais faire un autre post pour cela justement, puis un suivant pour une autre option vraiment efficace.

Fabrice Romelard [MVP]

# juillet 20, 2010 13:41

dummy1 a dit :

Question de débutant: la compression des images n'est elle pas faire par IIS ? (si la compression IIS est activée bien sur)

# juillet 26, 2010 08:51

lognoulm a dit :

Bonjour,

La plupart des formats d'images sont nativement compressés, il n'y a donc aucun intérêt à laisser IIS le faire "en plus". Par défaut, seules les extensions statiques suivantes le sont: .txt, .htm, et .html

Voir: http://www.microsoft.com/technet/prodtechnol/WindowsServer2003/Library/IIS/25d2170b-09c0-45fd-8da4-898cf9a7d568.mspx?mfr=true

# juillet 26, 2010 20:45
Les commentaires anonymes sont désactivés

Les 10 derniers blogs postés

- [SharePoint] Les sessions TechDays 2012… par Le blog de Patrick [MVP SharePoint] le il y a 6 heures et 54 minutes

- TechDays Paris 2012 : Session pleinière jour 3 par Blog Technique de Romelard Fabrice le 02-09-2012, 11:01

- Mishra Reader : un lecteur RSS très Zune Style en Open Source ! par Cyril Sansus le 02-09-2012, 08:28

- [framework 4] Les Tasks et le Thread UI par Fathi Bellahcene le 02-09-2012, 00:33

- Workflow Foundation 3 a un pied dans la tombe par Blog de Jérémy Jeanson le 02-08-2012, 22:15

- TechDays Paris 2012 : Nouvelles tendances du poste de travail - Bring Your own PC par Blog Technique de Romelard Fabrice le 02-08-2012, 19:42

- TechDays Paris 2012 : System Center Service Manager 2012 Vue d’ensemble par Blog Technique de Romelard Fabrice le 02-08-2012, 17:32

- TechDays Paris 2012 : Pleinière second jour par Blog Technique de Romelard Fabrice le 02-08-2012, 16:23

- TechDays Paris 2012 : Retour d'expérience sur la mise en place d'un Cloud Privé par Blog Technique de Romelard Fabrice le 02-08-2012, 16:04

- TechDays Paris 2012 : Comment SharePoint a sauvé mes TechDays par Blog Technique de Romelard Fabrice le 02-07-2012, 23:59