Recientemente aprendí Scala y estoy a punto de comenzar a trabajar/aprender Lift Framework. Revisando las características y comenzando con el framework, había visto algunas capacidades increíbles del framework, incluyendo el ajax inverso y el cometa. Anteriormente, en mi experiencia, tuve una experiencia realmente mala con el ajax inverso, que nunca fue escalado. Si elijo el marco de elevación para cualquier desarrollo, esta será la razón. Mi pregunta aquí es qué tan madura es la tecnología y el producto, y qué tan escalable es utilizando Lift on Tomcat. Comparando con la especificación de servlet 3.0, ¿cuál es mejor para este propósito, espere a la especificación de servlet 3.0 o comience a usar lift?¿Qué tan escalable es el cometa/ajax invertido de Lift Framework?
Respuesta
Reverse AJAX es Comet. Son solo dos nombres diferentes para la misma cosa. En cuanto a la raíz de su pregunta ...
La escalabilidad del soporte de Lift's Comet depende en gran medida del contenedor de servlets. Usted realmente necesita un contenedor que admita continuaciones de forma nativa. Jetty es con quien estoy familiarizado, pero estoy bastante seguro de que hay otros. Al contar con soporte de continuación en el nivel de contenedor, puede evitar bloquear un hilo por cliente, que es de donde provienen la mayoría de los problemas de escalabilidad de Comet.
En otras áreas de escalabilidad, Lift CometActor
es la abstracción genérica alrededor de un único cliente con una encuesta larga activa. Debido a que esta abstracción es un actor, se puede manejar dentro del marco de actor existente (Scala stdlib para Lift 1.0.x, o Lift actors on 2.0). Esto también evita el problema de escala de subprocesos y asegura que las actualizaciones pendientes se pondrán en cola de manera ordenada.
En resumen, el soporte de Lift's Comet es tan escalable como Comet. Por supuesto, hay gastos generales intrínsecos asociados con la técnica. Nunca podrá evitar comprometer al menos un socket por cliente. Sin embargo, Lift (junto con un contenedor habilitado para continuación) puede mitigar cualquier sobrecarga no esencial nada más sacarlo de la caja.
- 1. ¿Qué tan escalable es Jetty?
- 2. ¿Qué tan escalable es System.Threading.Timer?
- 3. ¿Qué tan escalable es ZeroMQ?
- 4. ¿por qué el marco web lift es escalable?
- 5. Qué tan popular es el Seam Framework
- 6. Entity Framework + MySQL - ¿Por qué el rendimiento es tan terrible?
- 7. ¿Cuál es mejor framework Java/GWT o Scala/Lift?
- 8. Herencia en Lift Mapper o Record Framework
- 9. ¿El marco Lift es tan "fácil" como Ruby on Rails o Django?
- 10. ¿Cuán escalable es Grails?
- 11. ¿Qué tan confiable es el instalador avanzado?
- 12. ¿Qué tan estable es el lenguaje Groovy?
- 13. ¿Qué tan estable es el sshfs dokan?
- 14. ¿Qué tan eficaz es StackFrame?
- 15. ¿Qué tan persistente es localStorage?
- 16. ¿Qué tan confiable es HTTP_HOST?
- 17. ¿Qué tan eficiente es javascript?
- 18. ¿Qué tan estable es NSubstitute?
- 19. ¿Qué tan aleatorio es Random.Next()?
- 20. ¿Qué tan útil es Response.IsClientConnected?
- 21. ¿Qué tan estable es WPF?
- 22. ¿Qué tan único es XAML?
- 23. ¿Qué tan bueno es VTK?
- 24. ¿Qué tan bueno es startswith?
- 25. ¿Qué tan portátil es GLib?
- 26. ¿Qué tan confiable es __destruct?
- 27. ¿Qué tan rápido es Data.Array?
- 28. ¿Qué tan rápido es LINQ?
- 29. ¿Qué tan caro es Thread.getStackTrace()?
- 30. ¿Qué tan seguro es javax.crypto.Cipher?