Проблема с numberOfViewsInSession и несколькими вкладками - PullRequest
6 голосов
/ 28 декабря 2010

У меня большая проблема с моим приложением и памятью. Приложение (java с jsf / richfaces / facelet) используют около 7000 пользователей одновременно.

По умолчанию переменная com.sun.faces.numberOfViewsInSession установлена ​​в 15 в файле web.xml. Эта переменная создает дерево представлений, а jsf извлекает конкретное представление в течение 15 нажатий назад.

Например, у меня есть 3 экрана для приложения, и я использую Firefox. Я иду на третьем экране в первой вкладке. Во второй вкладке у меня есть первый экран, и я нажимаю на следующую кнопку, JSF получить первый экран и перейти ко второму.

Этот механизм великолепен, но он потребляет много памяти (25Мо за сеанс для меня), и когда вы умножаете это число на 7000, мне нужно 175 Go памяти, это невозможно.

Поэтому я попытался установить com.sun.faces.numberOfViewsInSession равным 1 (3Mo по сеансу).

Но в моем примере, когда я нажимаю на второй вкладке следующей кнопки, я получаю следующую ошибку:

javax.servlet.ServletException: viewId:/private/pages/data/dataView.faces - View /private/pages/data/dataView.faces could not be restored.
at javax.faces.webapp.FacesServlet.service(FacesServlet.java:270)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
at org.ajax4jsf.webapp.BaseXMLFilter.doXmlFilter(BaseXMLFilter.java:206)
at org.ajax4jsf.webapp.BaseFilter.handleRequest(BaseFilter.java:290)
at org.ajax4jsf.webapp.BaseFilter.processUploadsAndHandleRequest(BaseFilter.java:388)
at org.ajax4jsf.webapp.BaseFilter.doFilter(BaseFilter.java:515)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
at fr.generali.mezzo.front.commun.performance.filters.PerformanceFilter.doFilter(PerformanceFilter.java:72)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
at org.jboss.web.tomcat.filters.ReplyHeaderFilter.doFilter(ReplyHeaderFilter.java:96)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:230)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:173)
at org.jboss.web.tomcat.security.SecurityAssociationValve.invoke(SecurityAssociationValve.java:182)
at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:525)
at org.jboss.web.tomcat.security.JaccContextValve.invoke(JaccContextValve.java:84)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:128)
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:104)
at org.jboss.web.tomcat.service.jca.CachedConnectionValve.invoke(CachedConnectionValve.java:157)
at org.apache.catalina.authenticator.SingleSignOn.invoke(SingleSignOn.java:420)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:241)
at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:844)
at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:583)
at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:447)
at java.lang.Thread.run(Thread.java:595)

Эта ошибка логична, потому что мой номерOfViewsInSession равен 1.

Итак, мой вопрос:

Учитывая, что я знаю данные, которые находятся в представлении (для второй вкладки), как я могу сделать, чтобы перехватить исключение и создать новое представление для моего пользователя?

Спасибо за вашу помощь.

1 Ответ

10 голосов
/ 28 декабря 2010

Восстановление представления вручную с использованием специальных знаний о вашем приложении, возможно, не является задачей для слабонервных.

Если вы хотите пойти по этому пути, я думаю, вам не следует пытатьсяпоймать исключение, но воспользоваться API StateManager в JSF.Это позволяет вам настроить способ управления средой JSF своего состояния просмотра.

Обратите внимание, что это сложная тема.Или в словах Эда Бернса (спецификация JSF):

Управление состоянием представления является сложным делом, и немногим разработчикам приложений придется беспокоиться о его настройке.Тем не менее, если вы еще не используете JSF 2.0, тогда я настоятельно рекомендую обновить до этого.Большой новой функцией в JSF 2.0 является Частичное сохранение состояния .Это значительно уменьшает объем памяти, необходимый для хранения состояния.

Еще один вариант, который, я полагаю, вы, возможно, уже рассмотрели, увидев, что вы знаете параметры, например com.sun.faces.numberOfViewsInSession использует состояние на клиенте.Это сохраняет состояние просмотра в скрытых полях и в основном дает вам неограниченную память, поскольку клиент используется в качестве распределенной памяти.Конечно, это дорого обходится из-за увеличения нагрузки на сеть.В случае AJAX эти издержки могут быть настолько большими, что их невозможно учесть.

...