2011-05-19 16 views
6

Ok, así que he estado trabajando en un proyecto ASP.NET por un tiempo y parece que he tomado algunas malas decisiones de diseño que vuelven a atormentarme como el proyecto sigue creciendo cada vez más en términos de datos contenidos.resultados de búsqueda en caché en sesión vs mantener gran montón de objetos limpios

Después de leer sobre la administración de memoria .NET, creo que he identificado un conjunto completo de posibles razones. Dado que las cosas que estoy haciendo no son particularmente especiales, me pregunto si hay un patrón estándar para lograr lo que quiero hacer que me estoy perdiendo.

Tengo una consulta (algo cara) que arroja algo entre 1 y 20000 resultados. En solicitudes posteriores, podemos estar buscando el conjunto de resultados, así que guardo este resultado en la sesión. La sesión es InProc. Me pregunto:

  • ¿Tiene sentido a) almacenar el resultado b) en una sesión c) en proceso? Quiero la velocidad de (a). No sé si hay una forma más eficiente que almacenarla por el usuario (b) y si uso un servidor de estado más sofisticado, ¿no es más lento (c)? ¿O podría ser esa la solución, deshacerse de esos objetos grandes más rápidamente en lugar de mantener el último resultado en la RAM hasta que expire la sesión?

  • Si cualquier conjunto de resultados> ~ 20000 filas termina arruinando el LOH, ¿existe una forma genérica de evitarlo?

Sé que esta pregunta está poco especificada. Me acabo de dar cuenta de que mi diseño general puede ser defectuoso (escalabilidad w.r.t.), y estoy tratando de estimar exactamente qué tan defectuoso. Espero que se puedan recopilar algunos consejos sobre patrones estándar que, sin embargo, lo conviertan en una pregunta generalmente útil.

Respuesta

1

¿Por qué devolver siempre todos los registros? Creo que la mejor manera de acelerar tu consulta es devolver solo los datos necesarios para el usuario ... ¡así que solo los datos que caben en la página!

Pruebe Google para ROW_NUMBER() (SQL Server) o LIMIT (mySQL).

Aquí hay 2 productos tutorial

1) ScottGu's Blog

2) 15 Second Tutorial

+0

Gracias. Las respuestas han sido muy útiles hasta ahora, pero esto realmente encaja muy bien con el tema en cuestión. Comenzamos con un back-end de Access. Ahora estamos a punto de hacer la transición a SQL Server, sin embargo, pensé que si la parte .NET de la aplicación no puede manejar la carga de memoria, no tiene sentido una costosa migración de db si el rendimiento no se incrementa notoriamente. Sin embargo, este podría ser un buen punto que muestra cómo podemos optimizar mejor la parte de .NET con un DB decente detrás (suponiendo que después de una breve investigación de Google que esto no es posible con el acceso para ordenamientos arbitrarios) – Nicolas78

+0

bien encontró una manera de Haga la paginación en access http://stackoverflow.com/questions/1900635/how-do-i-implement-pagination-in-sql-for-ms-access, pero dada la fealdad de la solución en comparación con una formulación sql adecuada allí podría ser todavía un punto para una migración largamente esperada – Nicolas78

+0

Una cosa que puede hacer con el acceso es intentar paginar con un SQL como este: SELECCIONAR ARRIBA (10) DESDE Table1 ORDER BY Id ... Luego almacenar la última ID en un variable y siguiente puede hacer esto: SELECCIONAR ARRIBA (10) DESDE Table1 Donde Id> * LastIdStored * .... ¡Pero la mejor manera es migrar en otro DB! – 2GDev

1

Sin saber cuál es su consulta, pero ¿por qué debería extraer más filas de su base de datos de las que necesita mostrar a su usuario a la vez? Con buenos índices, retirar las páginas subsiguientes debería ser bastante rápido y solo necesitas hacer eso si necesitas esas páginas.

Una alternativa es guardar los ID del conjunto de resultados para los 20000 elementos. De esta manera, si necesita recorrerlas, puede simplemente levantar las filas individuales rápidamente a través de una clave principal.

Por último, tal vez debería considerar usar el objeto Cache para almacenar sus resultados en lugar de la sesión. De esta forma, deja que .NET decida cuándo deshacerse de los objetos y no resultan en una Sesión inflada.

+0

gracias. Terminé marcando la respuesta de 2GDev para la referencia ROW_NUMBER() pero ustedes básicamente están de acuerdo, ahora tengo una gran reconstrucción por venir;) – Nicolas78

1

Debe intentar evitar almacenar los resultados en la sesión. Es probable que su aplicación no funcione bien si el usuario emplea varias pestañas del navegador en la misma sesión (sucede).

Si usa la sesión, definitivamente no use el modo InProc porque a medida que los usuarios vayan creciendo el proceso consumirá memoria y eventualmente lo reciclará y las sesiones de los usuarios se perderán incluso si el tiempo de espera no ha expirado.

Intente hacer una búsqueda en la base de datos ya que Keltex solo mencionó los datos que está mostrando.

Cuestiones relacionadas