Compartir a través de


Almacenamiento en caché de FTP <caching>

Información general

El elemento <caching> especifica la configuración de credenciales para el servicio FTP.

El servicio FTP almacena en caché las credenciales de usuario por motivos de rendimiento, lo que disminuye el tiempo necesario para autenticar a los clientes y reduce la sobrecarga asociada a la búsqueda de credenciales de usuario en el almacén de seguridad que está en uso. Por ejemplo, al usar la autenticación básica de FTP, las credenciales de usuario se almacenan en la base de datos de cuentas locales en el servidor donde se ejecuta el servicio FTP o en un controlador de dominio. Si usa credenciales de pertenencia a .NET, las cuentas de usuario se almacenan en una base de datos. Si las cuentas de dominio o la base de datos de pertenencia se almacenan en un equipo remoto, el almacenamiento en caché de credenciales ayudará a compensar el tiempo necesario para validar las cuentas. En un servidor FTP con un gran número de inicios de sesión de cuenta, esto puede aumentar considerablemente el rendimiento.

Cuando los requisitos de seguridad dictan que las credenciales deben vaciarse inmediatamente, puede configurar el almacenamiento en caché de credenciales para que se adapte a su entorno. Por ejemplo, si cambia una contraseña después de haber iniciado sesión correctamente en el sitio FTP, las credenciales antiguas se pueden almacenar en caché durante el tiempo de espera de la memoria caché. En una topología de red en la que es probable que esto ocurra con regularidad, es posible que desee reducir el tiempo de espera de la memoria caché o deshabilitar el almacenamiento en caché.

El almacenamiento en caché de credenciales está habilitado de forma predeterminada para FTP 7.0, FTP 7.5 y FTP 8.0. Las credenciales se almacenan en caché durante 15 minutos. El atributo flushInterval especifica la duración de las credenciales en la memoria caché y las credenciales se pueden vaciar manualmente reiniciando el servicio FTP.

Compatibilidad

Versión Notas
IIS 10.0 El elemento <caching> no se modificó en IIS 10.0.
IIS 8.5 El elemento <caching> no se modificó en IIS 8.5.
IIS 8.0 El elemento <caching> no se modificó en IIS 8.0.
IIS 7.5 El elemento <caching> del elemento <system.ftpServer> se incluye como una característica de IIS 7.5.
IIS 7.0 El elemento <caching> del elemento <system.ftpServer> se introdujo en FTP 7.0, que era una descarga independiente para IIS 7.0.
IIS 6,0 N/D

Nota:

Los servicios FTP 7.0 y FTP 7.5 se enviaron fuera de banda para IIS 7.0, lo que requería descargar e instalar el servicio desde la siguiente dirección URL:

https://www.iis.net/expand/FTP

Con Windows 7 y Windows Server 2008 R2, el servicio FTP 7.5 se incluye como característica para IIS 7.5, por lo que la descarga del servicio FTP ya no es necesaria.

Configuración

Para admitir la publicación de FTP para el servidor web, debe instalar el servicio FTP. Para ello, siga estos pasos.

Windows Server 2012 o Windows Server 2012 R2

  1. En la barra de tareas, haga clic en Administrador del servidor.

  2. En Administrador del servidor, haga clic en el menú Administrar y, después, haga clic en Agregar roles y características.

  3. En el asistente para Agregar roles y características, haga clic en Siguiente. Seleccione el tipo de instalación y haga clic en Siguiente. Seleccione el servidor de destino y haga clic en Siguiente.

  4. En la página Roles de servidor, expanda Servidor web (IIS) y, después, seleccione Servidor FTP.

    Nota:

    Para admitir la autenticación ASP.Membership o la autenticación del Administrador de IIS para el servicio FTP, también deberá seleccionar Extensibilidad de FTP, además de Servicio FTP.
    Screenshot of Server Roles page with F T P Server node expanded and F T P Extensibility selected..

  5. Haga clic en Siguiente y, después, en la página Seleccionar características, vuelva a hacer clic en Siguiente.

  6. En la página Confirmar selecciones de instalación, haga clic en Instalar.

  7. En la página Resultados , haga clic en Cerrar.

Windows 8 o Windows 8.1

  1. En la pantalla Inicio, mueva el puntero hasta la esquina inferior izquierda, haga clic con el botón derecho en el botón Inicio y, a continuación, haga clic en Panel de control.

  2. En Panel de control, haga clic en Programas y características y después en Activar o desactivar las características de Windows.

  3. Expanda Internet Information Services y, después, seleccione Servidor FTP.

    Nota:

    Para admitir la autenticación ASP.Membership o la autenticación del Administrador de IIS para el servicio FTP, también deberá seleccionar Extensibilidad de FTP.
    Screenshot of Internet Information Services and F T P Server pane expanded with F T P Extensibility highlighted.

  4. Haga clic en OK.

  5. Haga clic en Cerrar.

Windows Server 2008 R2

  1. En la barra de tareas, haga clic en Inicio, seleccione Herramientas administrativas y, luego, haga clic en Administrador del servidor.

  2. En el panel de jerarquía del Administrador del servidor, expanda Roles y, luego, haga clic en Servidor web (IIS).

  3. En el panel Servidor web (IIS), desplácese hasta la sección Servicios de rol y, luego, haga clic en Agregar servicios de rol.

  4. En la página Seleccionar servicios de rol del Asistente para agregar servicios de rol, expanda Servidor FTP.

  5. Seleccione Servicio FTP.

    Nota:

    Para admitir la autenticación ASP.Membership o la autenticación del Administrador de IIS para el servicio FTP, también deberá seleccionar Extensibilidad de FTP.
    Screenshot of Select Role Services page of the Add Role Services Wizard with F T P Server node expanded and F T P Service selected.

  6. Haga clic en Next.

  7. En la página Confirmar selecciones de instalación, haz clic en Instalar.

  8. En la página Resultados , haga clic en Cerrar.

Windows 7

  1. En la barra de tareas, haga clic en Inicio y, luego, haga clic en Panel de control.

  2. En Panel de control, haga clic en Programas y características y después en Activar o desactivar las características de Windows.

  3. Expanda Internet Information Services y, luego, Servidor FTP.

  4. Seleccione Servicio FTP.

    Nota:

    Para admitir la autenticación ASP.Membership o la autenticación del Administrador de IIS para el servicio FTP, también deberá seleccionar Extensibilidad de FTP.
    Screenshot of Internet Information Services and F T P Server node expanded displaying F T P Extensibility and F T P Service both selected.

  5. Haga clic en OK.

Windows Server 2008 o Windows Vista

  1. Descargue el paquete de instalación desde la siguiente dirección URL:

  2. Siga las instrucciones del siguiente tutorial para instalar el servicio FTP:

Procedimientos

Configuración de la memoria caché de credenciales de FTP

Nota para los usuarios de IIS 7.0: Algunos de los pasos de esta sección pueden requerir que instale Administration Pack para IIS 7.0 de Microsoft, que incluye el Editor de configuración de IIS. Para instalar Administration Pack para IIS 7 de Microsoft, consulte la siguiente dirección URL:

Nota:

No hay ninguna interfaz de usuario directa que le permita configurar el elemento <hostNameSupport>; por tanto, en los pasos siguientes se usará la característica Editor de configuración de IIS.

  1. Abra el Administrador de Internet Information Services (IIS):

    • Si usa Windows Server 2012 o Windows Server 2012 R2:

      • En la barra de tareas, haga clic en Administrador del servidor, en Herramientas y, a continuación, en Administrador de Internet Information Services (IIS).
    • Si usa Windows 8 o Windows 8.1:

      • Mantenga presionada la tecla Windows, presione la letra X y haga clic en Panel de control.
      • En Panel de control, haga clic en Herramientas administrativas y, a continuación, haga doble clic en Administrador de Internet Information Services (IIS).
    • Si usa Windows Server 2008 o Windows Server 2008 R2:

      • En la barra de tareas, haga clic en Inicio, seleccione Herramientas administrativas y, a continuación, haga clic en Administrador de Internet Information Services (IIS).
    • Si usa Windows Vista o Windows 7:

      • En la barra de tareas, haga clic en Inicio y, luego, haga clic en Panel de control.
      • Haga doble clic en Herramientas administrativas y, a continuación, haga doble clic en Administrador de Internet Information Services (IIS).
  2. En el panel Conexiones, haga clic en el nombre del servidor.

  3. En el panel Inicio, haga doble clic en la característica Editor de configuración.

  4. En el menú desplegable Sección, expanda system.ftpServer y, a continuación, haga clic en almacenamiento en caché.
    Screenshot of Configuration Editor feature pane showing system dot f t p Server menu expanded.

  5. Expanda credentialsCache en la vista de lista.

  6. Elija True o False en la lista desplegable para el atributoenabled.

  7. Escriba el número de segundos para el intervalo de vaciado del atributo flushInterval.

  8. En el panel Acciones, haga clic en Aplicar.

Nota:

Esta sección contiene información sobre cómo modificar los valores de IIS mediante el Editor de configuración de IIS. La edición incorrecta de los valores de configuración de IIS puede dañar gravemente la instalación de IIS. Por lo tanto, asegúrese de que sigue estos pasos con atención. Para mayor seguridad, debe realizar una copia de seguridad de los valores de configuración de IIS antes de usar el Editor de configuración de IIS para realizar cualquier modificación. Para más información sobre cómo realizar una copia de seguridad de los valores de configuración de IIS y cómo usar el Editor de configuración de IIS, vea los temas siguientes:

Configuración

El elemento <caching> se configura en el nivel global en ApplicationHost.config.

Atributos

Ninguno.

Elementos secundarios

Elemento Descripción
credentialsCache Elemento opcional.

Especifica la configuración de caché de credenciales para el servicio FTP.

Ejemplo de configuración

En el ejemplo de configuración siguiente se habilita el almacenamiento en caché de credenciales FTP para un servidor y se establece el tiempo de espera de credenciales en 300 segundos (cinco minutos).

<system.ftpServer>
   <caching>
      <credentialsCache enabled="true" flushInterval="300" />
   </caching>
</system.ftpServer>

Código de ejemplo

En los ejemplos siguientes se habilita el almacenamiento en caché de credenciales FTP para un servidor y se establece el tiempo de espera de credenciales en 300 segundos (cinco minutos).

AppCmd.exe

appcmd.exe set config -section:system.ftpServer/caching /credentialsCache.enabled:"True" /commit:apphost

appcmd.exe set config -section:system.ftpServer/caching /credentialsCache.flushInterval:"300" /commit:apphost

Nota:

Debe asegurarse de establecer el parámetrocommit en apphost cuando use AppCmd.exe para configurar estos valores. Esto confirma los valores de configuración en la sección de ubicación adecuada del archivo 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 cachingSection = config.GetSection("system.ftpServer/caching");

         ConfigurationElement credentialsCacheElement = cachingSection.GetChildElement("credentialsCache");
         credentialsCacheElement["enabled"] = true;
         credentialsCacheElement["flushInterval"] = 300;

         serverManager.CommitChanges();
      }
   }
}

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 cachingSection As ConfigurationSection = config.GetSection("system.ftpServer/caching")

      Dim credentialsCacheElement As ConfigurationElement = cachingSection.GetChildElement("credentialsCache")
      credentialsCacheElement("enabled") = True
      credentialsCacheElement("flushInterval") = 300

      serverManager.CommitChanges()
   End Sub
End Module

JavaScript

var adminManager = new ActiveXObject('Microsoft.ApplicationHost.WritableAdminManager');
adminManager.CommitPath = "MACHINE/WEBROOT/APPHOST";
var cachingSection = adminManager.GetAdminSection("system.ftpServer/caching", "MACHINE/WEBROOT/APPHOST");

var credentialsCacheElement = cachingSection.ChildElements.Item("credentialsCache");
credentialsCacheElement.Properties.Item("enabled").Value = true;
credentialsCacheElement.Properties.Item("flushInterval").Value = 300;

adminManager.CommitChanges();

VBScript

Set adminManager = createObject("Microsoft.ApplicationHost.WritableAdminManager")
adminManager.CommitPath = "MACHINE/WEBROOT/APPHOST"
Set cachingSection = adminManager.GetAdminSection("system.ftpServer/caching", "MACHINE/WEBROOT/APPHOST")

Set credentialsCacheElement = cachingSection.ChildElements.Item("credentialsCache")
credentialsCacheElement.Properties.Item("enabled").Value = True
credentialsCacheElement.Properties.Item("flushInterval").Value = 300

adminManager.CommitChanges()