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 :
|
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
- Dans la barre des tâches, cliquez sur Gestionnaire de serveur.
- Dans Gestionnaire de serveur, cliquez sur le menu Gérer, puis sur Ajouter des rôles et des fonctionnalités.
- 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.
- 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.
. - Dans la page Sélectionner les composants, cliquez sur Suivant.
- Dans la page Confirmer les sélections d’installation, cliquez sur Installer.
- Dans la page Résultats , cliquez sur Fermer.
Windows 8 ou Windows 8.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.
- Dans Panneau de configuration, cliquez sur Programmes et fonctionnalités, puis sur Activer ou désactiver des fonctionnalités Windows.
- Développez Internet Information Services, Services World Wide Web, Intégrité et diagnostic, puis sélectionnez Journalisation ODBC.
- Cliquez sur OK.
- Cliquez sur Fermer.
Windows Server 2008 ou Windows Server 2008 R2
- Dans la barre des tâches, cliquez sur Démarrer, pointez sur Outils d’administration, puis cliquez sur Gestionnaire de serveur.
- Dans le volet de hiérarchie du Gestionnaire de serveur, développez Rôles, puis cliquez sur Serveur web (IIS).
- 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.
- 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.
- Dans la page Confirmer les sélections pour l'installation, cliquez sur Installer.
- Dans la page Résultats , cliquez sur Fermer.
Windows Vista ou Windows 7
- Dans la barre des tâches, cliquez sur Démarrer, puis sur Panneau de configuration.
- Dans Panneau de configuration, cliquez sur Programmes et fonctionnalités, puis sur Activer ou désactiver des fonctionnalités Windows.
- Développez Internet Information Services, sélectionnez Journalisation ODBC, puis cliquez sur OK.
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