La pregunta básicamente es “Realizar modificaciones en algunas carpetas (BIN por ejemplo) Sin reiniciar la app”
Bueno aquí debo hacer mención a Jesús Bosch que fue el que escribió este titulo en su pregunta en los foros (hace ya bastante tiempo pero lo tenia en borrador así que aquí esta para futuras referencias)
- (Pregunta en Foros de MSDN) DLL y compilación dinámica
http://social.msdn.microsoft.com/Forums/es-ES/fe46afb9-51a4-45bf-87ff-4902f28b7483/dll-y-compilacin-dinmica
Ahora los enlaces/url a los post del foros son mas user-friendly (tienen el titulo al final), y se modifico la UI… date una vuelta por los Foros MSDN
Entonces en este post:
- Compilar? Muy
pero muybreve introducción de compilación en ASP.NET… - Cambios en BIN sin compilar todo el sitio (sin reiniciar) . Atributo optimizeCompilations
- Pensemos… en voz alta! Cuidados Especiales
- ¿Y si no queremos compilar nunca? compilationMode="Never" (solo para ASP.NET Webforms)
Compilar? Muy pero muy breve introducción de compilación en ASP.NET…
Como sabrás o te estas enterando si utilizas proyectos ASP.NET Websites compila el sitio en la primer petición, el codebehind y los archivos de código, lo que puedes prevenir precompilando todo el sitio que te dejo para investigar; En cambio si utilizas ASP.NET WebApp (Proyectos Web) puedes compilar en un único ensamblado, tendiendo un poco mas de “poder” sobre él (idem en proyectos MVC). Mas info sobre compilación:
- Proyectos de aplicación web frente a proyectos de sitio web en Visual Studio
http://msdn.microsoft.com/es-es/library/dd547590.aspx#compilation
Y en ASP.NET MVC? Ídem a Proyectos Web (Aplicaciones Web)… al fin y al cabo es una Proyecto Web ASP.NET solo que con componentes diferentes
Si bien a veces es bueno tener uno u otro, al realizar cambios en producción en algunos archivos reinicia la aplicación web… y allí es la pregunta:
Cambios en BIN sin compilar todo el sitio (sin reiniciar). Atributo optimizeCompilations
Si solamente quieres que no se reinicie todo el sitio se puede establecer el atributo optimizeCompilations en true de la sección compilation del web.config (mas info aquí)
Cuando se realizan cambios en archivos de nivel superior (léase en el global.asax, o carpetas App_Code, o BIN) se compila todo el sitio…. eso ya lo sabemos.
Textual de MSDN:
(…)Si desea poder cambiar los archivos de nivel superior sin tener que volver a compilar todo el sitio, puede establecer en true el atributo optimizeCompilations del elemento compilation en el archivo Web.config.Si el valor de optimizeCompilations es true, al cambiar un archivo de nivel superior, solo se vuelven a compilar los archivos afectados. (…)
<compilation
optimizeCompilations="true">
Fix: para que funcione deberías tener estos hotfix dependiendo del Sistema operativo
- En XP and Server 2003 : click aquí…
- En Vista and Server 2008 : click aquí…
- En Windows 7/8 , ya lo tiene!
Pero no es la panacea! deberías tener en cuenta algunos puntos…
Pensemos… en voz alta! Cuidados Especiales
(también esto esta en la pagina de MSDN)
- Si uno no cambias alguna firma de un método, tus paginas que utilizan los assemblies (las dll) seguirán funcionado.
- Si tienes métodos nuevos, las nuevas paginas utilizan las nuevo métodos y serán compiladas dinámicamente
NOTA Final: (…)Si desea utilizar el atributo optimizeCompilations para minimizar el tiempo de la compilación dinámica, deberá revisar atentamente cada cambio que realice en los archivos de nivel superior de un sitio y, si hay algún cambio que no sea seguro, deberá quitar temporalmente el atributo optimizeCompilations o establecer su valor en false.(…)
¿Y si no queremos compilar nunca? compilationMode="Never" (solo para ASP.NET Webforms)
Allí puedes utilizar la propiedad CompilationMode que sirve para establecer si se realiza o no esta acción sobre las Paginas (y/o UserControls), así que aquí estamos hablando solo de ASP.NET Webforms
O sea, debes precompilar todo el sitio (algo que hablamos mas arriba) o sino las paginas o usercontrol con código no funcionarían
Lo podemos escribir en la directiva de pagina, pero para todo el sitio va en el web.config en la seccion pages:
<configuration>
<system.web>
<pages compilationMode="Never" />
</system.web>
</configuration>
Enlaces
- Elemento compilation (Esquema de configuración de ASP.NET)
http://msdn.microsoft.com/es-es/library/vstudio/s10awwz0.aspx - (idem anterior) Elemento compilation (Esquema de configuración de ASP.NET)
http://msdn.microsoft.com/es-es/library/s10awwz0.aspx - Descripción de la compilación dinámica de ASP.NET
http://msdn.microsoft.com/es-es/library/ms366723.aspx - A new flag to optimize ASP.NET compilation behavior
http://blogs.msdn.com/b/davidebb/archive/2009/04/15/a-new-flag-to-optimize-asp-net-compilation-behavior.aspx - DLL y compilación dinámica (Post en Foros de MSDN)
http://social.msdn.microsoft.com/Forums/es-ES/netfxwebes/thread/fe46afb9-51a4-45bf-87ff-4902f28b7483 - CompilationMode (Enumeración)
http://msdn.microsoft.com/es-es/library/system.web.ui.compilationmode.aspx - Elemento pages (Esquema de configuración de ASP.NET)
Para establecer el valor CompilationMode para todo el sitio…
Siempre lo tengo en cuenta para temas de optimización y performance. Gracias!.
No sé si ahora con ASP.NET 4.5.1, y nuevas versiones de ASP.NET y la ASP.NET vNext se incluirán mejoras al respecto de lo comentado en este gran post.
Desde mi ignorancia, no sé si se incluirán para IIS 7.5 temas de Asp.net warm up & Application Initialization.
Muchas gracias.