Journalisation ODBC <odbcLogging>

Vue d’ensemble

L’élément <odbcLogging> configure la journalisation ODBC (Open Database Connectivity) pour Internet Information Services (IIS) 7. La journalisation ODBC enregistre toutes les activités HTTP dans une base de données définie par l’utilisateur au lieu de fichiers texte.

La journalisation ODBC est implémentée en tant que module de journalisation personnalisé dans IIS 7. Par conséquent, l’activation et la configuration de la journalisation ODBC dans IIS 7 se composent de deux actions distinctes :

  • Définition des attributs de journalisation ODBC dans l’élément <odbcLogging>. Plus précisément, les attributs suivants doivent être configurés :

    • L’attribut dataSource doit spécifier le nom de source de données système (DSN) pour la base de données où se trouve la table spécifiée par l’attribut tableName.
    • L’attribut password doit spécifier le mot de passe de base de données utilisé par IIS 7 lors de l’écriture d’informations de journal dans la base de données.
    • L’attribut tableName doit spécifier le nom de la table de base de données dans la base de données spécifiée par l’attribut dataSource.
    • L’attribut userName doit spécifier le nom d’utilisateur de base de données utilisé par IIS 7 lors de l’écriture d’informations de journal dans la base de données.
  • Définition des attributs de journalisation personnalisés corrects dans l’élément <logFile>. Plus précisément, les attributs suivants doivent être configurés :

    • L’attribut logFormat doit être défini sur "Custom".
    • L’attribut customLogPluginClsid doit être défini sur "{FF16065B-DE82-11CF-BC0A-00AA006111E0}"

Par défaut, IIS 7 consigne toutes les activités vers des fichiers texte qui utilisent le format de fichier journal étendu W3C et, par défaut, vous pouvez configurer IIS pour utiliser d’autres formats de fichiers texte tels que le format NCSA ou IIS natif. L’inconvénient majeur de l’utilisation de ces formats textuels est qu’ils sont plus difficiles à analyser pour l’activité et nécessitent généralement un utilitaire comme LogParser de Microsoft afin de récupérer toutes les informations utiles de vos journaux. En outre, les performances d’analyse des données avec des fichiers texte sont généralement beaucoup plus lentes qu’avec une base de données. Toutefois, la journalisation basée sur du texte est effectuée en mode noyau, ce qui améliore les performances des demandes de journalisation.

Lorsque vous utilisez la journalisation ODBC, l’activité de votre serveur est stockée dans une base de données, ce qui doit considérablement améliorer la récupération des données. Cela étend les possibilités d’utilisation d’un large éventail de clients de base de données lors de l’exploration de données de l’activité de votre serveur. L’inconvénient majeur de l’utilisation de la journalisation ODBC concerne les performances de la journalisation car, lorsque la journalisation ODBC est activée, IIS désactive le cache en mode noyau. Pour cette raison, l’implémentation de la journalisation ODBC peut dégrader les performances globales du serveur.

Remarque

Pour créer la table pour la journalisation ODBC, vous pouvez utiliser le fichier « %windir%\System32\inetsrv\logtemp.sql » fourni avec IIS 7. Pour plus d’informations sur la journalisation ODBC, consultez l’article 245243 de la Base de connaissances Microsoft.

Compatibilité

Version Notes
IIS 10.0 L’élément <odbcLogging> n’a pas été modifié dans IIS 10.0.
IIS 8.5 L’élément <odbcLogging> n’a pas été modifié dans IIS 8.5.
IIS 8.0 L’élément <odbcLogging> n’a pas été modifié dans IIS 8.0.
IIS 7.5 L’élément <odbcLogging> n’a pas été modifié dans IIS 7.5.
IIS 7.0 L’élément <odbcLogging> a été introduit dans IIS 7.0.
IIS 6.0 Les attributs de l’élément <odbcLogging> remplacent les propriétés métabase IIS 6.0 suivantes :
  • LogOdbcDataSource
  • LogOdbcPassword
  • LogOdbcTableName
  • LogOdbcUserName

Programme d’installation

L’élément <odbcLogging> n’est pas disponible dans l’installation par défaut d’IIS 7 et versions ultérieures. Pour l’installer, procédez comme suit.

Windows Server 2012 ou Windows Server 2012 R2

  1. Dans la barre des tâches, cliquez sur Gestionnaire de serveur.
  2. Dans Gestionnaire de serveur, cliquez sur le menu Gérer, puis sur Ajouter des rôles et des fonctionnalités.
  3. Dans l’Assistant Ajout de rôles et de fonctionnalités, cliquez sur Suivant. Sélectionnez le type d’installation, puis cliquez sur Suivant. Sélectionnez le serveur de destination, puis cliquez sur Suivant.
  4. Dans la page Rôles serveur, développez Serveur web (IIS), Serveur web et Intégrité et diagnostic, puis sélectionnez Journalisation ODBC. Sélectionnez Suivant.
    Screenshot shows the Health and Diagnostics features for Windows Server 2012 or Windows Server 2012 R2 with O D B C Logging selected. .
  5. Dans la page Sélectionner les composants, cliquez sur Suivant.
  6. Dans la page Confirmer les sélections d’installation, cliquez sur Installer.
  7. Dans la page Résultats , cliquez sur Fermer.

Windows 8 ou Windows 8.1

  1. Dans l’écran Démarrer, déplacez le pointeur jusqu’au coin inférieur gauche, cliquez avec le bouton droit sur le bouton Démarrer, puis cliquez sur Panneau de configuration.
  2. Dans Panneau de configuration, cliquez sur Programmes et fonctionnalités, puis sur Activer ou désactiver des fonctionnalités Windows.
  3. Développez Internet Information Services, Services World Wide Web, Intégrité et diagnostic, puis sélectionnez Journalisation ODBC.
    Screenshot shows the Health and Diagnostics features for Windows 8 or Windows 8.1 with O D B C Logging selected.
  4. Cliquez sur OK.
  5. Cliquez sur Fermer.

Windows Server 2008 ou Windows Server 2008 R2

  1. Dans la barre des tâches, cliquez sur Démarrer, pointez sur Outils d’administration, puis cliquez sur Gestionnaire de serveur.
  2. Dans le volet de hiérarchie du Gestionnaire de serveur, développez Rôles, puis cliquez sur Serveur web (IIS).
  3. Dans le volet Serveur web (IIS), faites défiler jusqu’à la section Services de rôle, puis cliquez sur Ajouter des services de rôle.
  4. Dans la page Sélectionner des services de rôle de l’Assistant Ajout de services de rôle, sélectionnez Journalisation ODBC, puis cliquez sur Suivant.
    Screenshot shows the Health and Diagnostics features for Windows Server 2008 or Windows Server 2008 R2 with O D B C Logging selected.
  5. Dans la page Confirmer les sélections pour l'installation, cliquez sur Installer.
  6. Dans la page Résultats , cliquez sur Fermer.

Windows Vista ou Windows 7

  1. Dans la barre des tâches, cliquez sur Démarrer, puis sur Panneau de configuration.
  2. Dans Panneau de configuration, cliquez sur Programmes et fonctionnalités, puis sur Activer ou désactiver des fonctionnalités Windows.
  3. Développez Internet Information Services, sélectionnez Journalisation ODBC, puis cliquez sur OK.
    Screenshot shows the Health and Diagnostics features for Windows Vista or Windows 7 with O D B C Logging selected.

Procédure

Il n’existe aucune interface utilisateur pour configurer la journalisation ODBC pour IIS 7. Pour obtenir des exemples de configuration de la journalisation ODBC par programmation, consultez la section Exemples de code de ce document.

Configuration

Attributs

Attribut Description
dataSource Attribut de chaîne facultatif. Spécifie le nom de source de données système (DSN) de la base de données dans laquelle le journal est écrit.

La valeur par défaut est InternetDb.
password Attribut de chaîne facultatif. Spécifie le mot de passe de base de données ODBC que vous utilisez lorsque vous écrivez des informations dans la base de données pendant la journalisation des événements. Par défaut, cette valeur est chiffrée.

La valeur par défaut est [enc:AesProvider::enc].
tableName Attribut de chaîne facultatif. Spécifie le nom de la table de base de données ODBC où Windows écrit des informations pendant la journalisation des événements.

La valeur par défaut est InternetLog.
userName Attribut de chaîne facultatif. Spécifie le nom d’utilisateur de base de données ODBC utilisé pour écrire des informations dans la base de données pendant la journalisation des événements.

La valeur par défaut est InternetAdmin.

Éléments enfants

Aucune.

Exemple Configuration

Ce premier exemple de configuration pour le site web par défaut configure les attributs de l’élément <odbcLogging> qui spécifient le nom DSN système, le nom de la table, le nom d’utilisateur et le mot de passe d’une connexion de journalisation ODBC.

<location path="Default Web Site">
   <system.webServer>
      <odbcLogging dataSource="InternetDb"
         tableName="InternetLog"
         userName="InternetAdmin"
         password="[enc:AesProvider:57686f6120447564652c2049495320526f636b73:enc]" />
   </system.webServer>
</location>

Ce deuxième exemple de configuration configure les attributs de journalisation personnalisés corrects dans l’élément <logFile> qui activent la journalisation ODBC pour le site web par défaut.

<site name="Default Web Site" id="1" serverAutoStart="true">
   <application path="/" applicationPool="DefaultAppPool">
      <virtualDirectory path="/" physicalPath="%SystemDrive%\inetpub\wwwroot" />
   </application>
   <bindings>
      <binding protocol="http" bindingInformation="*:80:" />
   </bindings>
   <logFile logFormat="Custom"
      customLogPluginClsid="{FF16065B-DE82-11CF-BC0A-00AA006111E0}" />
</site>

Exemple de code

Les exemples de code suivants configurent deux ensembles d’options pour le site web par défaut :

  • La première moitié de chaque exemple configure les attributs de l’élément <odbcLogging> qui spécifient le nom DSN système, le nom de la table, le nom d’utilisateur et le mot de passe d’une connexion de journalisation ODBC.
  • La deuxième moitié de chaque exemple spécifie les attributs de journalisation personnalisés dans l’élément <logFile> qui activent la journalisation ODBC.

AppCmd.exe

appcmd.exe set config "Default Web Site" -section:system.webServer/odbcLogging /dataSource:"InternetDb" /commit:apphost
appcmd.exe set config "Default Web Site" -section:system.webServer/odbcLogging /tableName:"InternetLog" /commit:apphost
appcmd.exe set config "Default Web Site" -section:system.webServer/odbcLogging /userName:"InternetAdmin" /commit:apphost
appcmd.exe set config "Default Web Site" -section:system.webServer/odbcLogging /password:"P@ssw0rd" /commit:apphost

appcmd.exe set sites "Default Web Site" -logFile.logFormat:"Custom" /commit:apphost
appcmd.exe set sites "Default Web Site" -logFile.customLogPluginClsid:"{FF16065B-DE82-11CF-BC0A-00AA006111E0}" /commit:apphost

Remarque

Vous devez veiller à définir le paramètre commit sur apphost quand vous utilisez AppCmd.exe pour configurer ces paramètres. Cela valide les paramètres de configuration dans la section d’emplacement appropriée dans le fichier ApplicationHost.config.

C#

using System;
using System.Text;
using Microsoft.Web.Administration;

internal static class Sample
{
   private static void Main()
   {
      using (ServerManager serverManager = new ServerManager())
      {
         Configuration config = serverManager.GetApplicationHostConfiguration();

         ConfigurationSection odbcLoggingSection = config.GetSection("system.webServer/odbcLogging", "Default Web Site");
         odbcLoggingSection["dataSource"] = @"InternetDb";
         odbcLoggingSection["tableName"] = @"InternetLog";
         odbcLoggingSection["userName"] = @"InternetAdmin";
         odbcLoggingSection["password"] = @"P@ssw0rd";

         ConfigurationSection sitesSection = config.GetSection("system.applicationHost/sites");
         ConfigurationElementCollection sitesCollection = sitesSection.GetCollection();
         ConfigurationElement siteElement = FindElement(sitesCollection, "site", "name", @"Default Web Site");
         if (siteElement == null) throw new InvalidOperationException("Element not found!");

         ConfigurationElement logFileElement = siteElement.GetChildElement("logFile");
         logFileElement["customLogPluginClsid"] = @"{FF16065B-DE82-11CF-BC0A-00AA006111E0}";
         logFileElement["logFormat"] = @"Custom";

         serverManager.CommitChanges();
      }
   }

   private static ConfigurationElement FindElement(ConfigurationElementCollection collection, string elementTagName, params string[] keyValues)
   {
      foreach (ConfigurationElement element in collection)
      {
         if (String.Equals(element.ElementTagName, elementTagName, StringComparison.OrdinalIgnoreCase))
         {
            bool matches = true;
            for (int i = 0; i < keyValues.Length; i += 2)
            {
               object o = element.GetAttributeValue(keyValues[i]);
               string value = null;
               if (o != null)
               {
                  value = o.ToString();
               }
               if (!String.Equals(value, keyValues[i + 1], StringComparison.OrdinalIgnoreCase))
               {
                  matches = false;
                  break;
               }
            }
            if (matches)
            {
               return element;
            }
         }
      }
      return null;
   }
}

VB.NET

Imports System
Imports System.Text
Imports Microsoft.Web.Administration

Module Sample
   Sub Main()
      Dim serverManager As ServerManager = New ServerManager
      Dim config As Configuration = serverManager.GetApplicationHostConfiguration

      Dim odbcLoggingSection As ConfigurationSection = config.GetSection("system.webServer/odbcLogging", "Default Web Site")
      odbcLoggingSection("dataSource") = "InternetDb"
      odbcLoggingSection("tableName") = "InternetLog"
      odbcLoggingSection("userName") = "InternetAdmin"
      odbcLoggingSection("password") = "P@ssw0rd"

      Dim sitesSection As ConfigurationSection = config.GetSection("system.applicationHost/sites")
      Dim sitesCollection As ConfigurationElementCollection = sitesSection.GetCollection
      Dim siteElement As ConfigurationElement = FindElement(sitesCollection, "site", "name", "Default Web Site")
      If (siteElement Is Nothing) Then
         Throw New InvalidOperationException("Element not found!")
      End If

      Dim logFileElement As ConfigurationElement = siteElement.GetChildElement("logFile")
      logFileElement("customLogPluginClsid") = "{FF16065B-DE82-11CF-BC0A-00AA006111E0}"
      logFileElement("logFormat") = "Custom"

      serverManager.CommitChanges()
   End Sub

   Private Function FindElement(ByVal collection As ConfigurationElementCollection, ByVal elementTagName As String, ByVal ParamArray keyValues() As String) As ConfigurationElement
      For Each element As ConfigurationElement In collection
         If String.Equals(element.ElementTagName, elementTagName, StringComparison.OrdinalIgnoreCase) Then
            Dim matches As Boolean = True
            Dim i As Integer
            For i = 0 To keyValues.Length - 1 Step 2
               Dim o As Object = element.GetAttributeValue(keyValues(i))
               Dim value As String = Nothing
               If (Not (o) Is Nothing) Then
                  value = o.ToString
               End If
               If Not String.Equals(value, keyValues((i + 1)), StringComparison.OrdinalIgnoreCase) Then
                  matches = False
                  Exit For
               End If
            Next
            If matches Then
               Return element
            End If
         End If
      Next
      Return Nothing
   End Function


End Module

JavaScript

var adminManager = new ActiveXObject('Microsoft.ApplicationHost.WritableAdminManager');
adminManager.CommitPath = "MACHINE/WEBROOT/APPHOST";

var odbcLoggingSection = adminManager.GetAdminSection("system.webServer/odbcLogging", "MACHINE/WEBROOT/APPHOST/Default Web Site");
odbcLoggingSection.Properties.Item("dataSource").Value = "InternetDb";
odbcLoggingSection.Properties.Item("tableName").Value = "InternetLog";
odbcLoggingSection.Properties.Item("userName").Value = "InternetAdmin";
odbcLoggingSection.Properties.Item("password").Value = "P@ssw0rd";

var sitesSection = adminManager.GetAdminSection("system.applicationHost/sites", "MACHINE/WEBROOT/APPHOST");
var sitesCollection = sitesSection.Collection;
var siteElementPos = FindElement(sitesCollection, "site", ["name", "Default Web Site"]);
if (siteElementPos == -1) throw "Element not found!";
var siteElement = sitesCollection.Item(siteElementPos);

var logFileElement = siteElement.ChildElements.Item("logFile");
logFileElement.Properties.Item("customLogPluginClsid").Value = "{FF16065B-DE82-11CF-BC0A-00AA006111E0}";
logFileElement.Properties.Item("logFormat").Value = "Custom";

adminManager.CommitChanges();

function FindElement(collection, elementTagName, valuesToMatch) {
   for (var i = 0; i < collection.Count; i++) {
      var element = collection.Item(i);
      if (element.Name == elementTagName) {
         var matches = true;
         for (var iVal = 0; iVal < valuesToMatch.length; iVal += 2) {
            var property = element.GetPropertyByName(valuesToMatch[iVal]);
            var value = property.Value;
            if (value != null) {
               value = value.toString();
            }
            if (value != valuesToMatch[iVal + 1]) {
               matches = false;
               break;
            }
         }
         if (matches) {
            return i;
         }
      }
   }
   return -1;
}

VBScript

Set adminManager = WScript.CreateObject("Microsoft.ApplicationHost.WritableAdminManager")
adminManager.CommitPath = "MACHINE/WEBROOT/APPHOST"

Set odbcLoggingSection = adminManager.GetAdminSection("system.webServer/odbcLogging", "MACHINE/WEBROOT/APPHOST/Default Web Site")
odbcLoggingSection.Properties.Item("dataSource").Value = "InternetDb"
odbcLoggingSection.Properties.Item("tableName").Value = "InternetLog"
odbcLoggingSection.Properties.Item("userName").Value = "InternetAdmin"
odbcLoggingSection.Properties.Item("password").Value = "P@ssw0rd"

Set sitesSection = adminManager.GetAdminSection("system.applicationHost/sites", "MACHINE/WEBROOT/APPHOST")
Set sitesCollection = sitesSection.Collection
siteElementPos = FindElement(sitesCollection, "site", Array("name", "Default Web Site"))
If (siteElementPos = -1) Then
   WScript.Echo "Element not found!"
   WScript.Quit
End If
Set siteElement = sitesCollection.Item(siteElementPos)

Set logFileElement = siteElement.ChildElements.Item("logFile")
logFileElement.Properties.Item("customLogPluginClsid").Value = "{FF16065B-DE82-11CF-BC0A-00AA006111E0}"
logFileElement.Properties.Item("logFormat").Value = "Custom"

adminManager.CommitChanges()

Function FindElement(collection, elementTagName, valuesToMatch)
   For i = 0 To CInt(collection.Count) - 1
      Set element = collection.Item(i)
      If element.Name = elementTagName Then
         matches = True
         For iVal = 0 To UBound(valuesToMatch) Step 2
            Set property = element.GetPropertyByName(valuesToMatch(iVal))
            value = property.Value
            If Not IsNull(value) Then
               value = CStr(value)
            End If
            If Not value = CStr(valuesToMatch(iVal + 1)) Then
               matches = False
               Exit For
            End If
         Next
         If matches Then
            Exit For
         End If
      End If
   Next
   If matches Then
      FindElement = i
   Else
      FindElement = -1
   End If
End Function