我们收到此异常:
TimeoutException: JBAS010213: Cannot acquire lock default-host/...
我们在 Web 应用程序中使用此 PhaseListener 来捕获 ajax 请求的 session 超时并重定向到索引(我们怀疑这可能相关,但我们不知道):
public class SessionExpirationPhaseListener implements PhaseListener {
@Override
public PhaseId getPhaseId() {
return PhaseId.RESTORE_VIEW;
}
@Override
public void beforePhase(PhaseEvent event) {
}
@Override
public void afterPhase(PhaseEvent event) {
FacesContext context = FacesContext.getCurrentInstance();
HttpServletRequest httpRequest = (HttpServletRequest) context.getExternalContext().getRequest();
if (httpRequest.getRequestedSessionId() != null && !httpRequest.isRequestedSessionIdValid()) {
String facesRequestHeader = httpRequest.getHeader("Faces-Request");
boolean isAjaxRequest = facesRequestHeader != null && facesRequestHeader.equals("partial/ajax");
// navigate to home page only for ajax requests
if (isAjaxRequest) {
ConfigurableNavigationHandler handler = (ConfigurableNavigationHandler) context.getApplication().getNavigationHandler();
handler.performNavigation("home");
}
}
}
}
我们正在一个具有 2 个节点(mod_cluster + apache)的 JBoss 集群上运行,并且启用了 SSO。你们知道可能出了什么问题吗?或者至少为我们指明了正确的方向?
谢谢,问候。
我是一名优秀的程序员,十分优秀!