Uploaded image for project: 'ZK'
  1. ZK
  2. ZK-2039

ZK7/6.5.4 and Glassfish 3/4 problem with <distributable/> in web-fragment

XMLWordPrintable

    • Icon: Bug Bug
    • Resolution: Won't Fix
    • Icon: Normal Normal
    • None
    • 6.5.4
    • Security Level: Jimmy
    • None
    • Glassfish 3/4

    • None

      as a fix for the clustering issue ZK-1896 (for Jboss AS 7) the <distributable/> tag was added to the web-fragment.xml in the zk.jar

      This change causes an Exception when a zk session is created on first request

      java.lang.IllegalArgumentException: PWC2788: setAttribute: Non-serializable attribute with name javax.zkoss.zk.ui.Session
      at org.apache.catalina.session.ManagerBase.checkSessionAttribute(ManagerBase.java:832)
      at org.apache.catalina.session.StandardSession.setAttribute(StandardSession.java:1713)
      at org.apache.catalina.session.StandardSessionFacade.setAttribute(StandardSessionFacade.java:178)
      at org.zkoss.zk.ui.http.SessionAgent.put(SessionAgent.java:30)
      at org.zkoss.zk.ui.http.SimpleSessionCache.put(SimpleSessionCache.java:36)
      at org.zkoss.zk.ui.sys.SessionsCtrl.newSession(SessionsCtrl.java:158)
      at org.zkoss.zk.ui.http.WebManager.getSession(WebManager.java:435)
      at org.zkoss.zk.ui.http.WebManager.getSession(WebManager.java:416)
      at org.zkoss.zk.ui.http.DHtmlLayoutServlet.doGet(DHtmlLayoutServlet.java:126)
      at javax.servlet.http.HttpServlet.service(HttpServlet.java:668)
      at javax.servlet.http.HttpServlet.service(HttpServlet.java:770)
      at org.apache.catalina.core.StandardWrapper.service(StandardWrapper.java:1550)
      at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:281)
      at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:175)
      at org.apache.catalina.core.StandardPipeline.doInvoke(StandardPipeline.java:655)
      at org.apache.catalina.core.StandardPipeline.invoke(StandardPipeline.java:595)
      at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:161)
      at org.apache.catalina.connector.CoyoteAdapter.doService(CoyoteAdapter.java:331)
      at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:231)
      at com.sun.enterprise.v3.services.impl.ContainerMapper$AdapterCallable.call(ContainerMapper.java:317)
      at com.sun.enterprise.v3.services.impl.ContainerMapper.service(ContainerMapper.java:195)
      at com.sun.grizzly.http.ProcessorTask.invokeAdapter(ProcessorTask.java:860)
      at com.sun.grizzly.http.ProcessorTask.doProcess(ProcessorTask.java:757)
      at com.sun.grizzly.http.ProcessorTask.process(ProcessorTask.java:1056)
      at com.sun.grizzly.http.DefaultProtocolFilter.execute(DefaultProtocolFilter.java:229)
      at com.sun.grizzly.DefaultProtocolChain.executeProtocolFilter(DefaultProtocolChain.java:137)
      at com.sun.grizzly.DefaultProtocolChain.execute(DefaultProtocolChain.java:104)
      at com.sun.grizzly.DefaultProtocolChain.execute(DefaultProtocolChain.java:90)
      at com.sun.grizzly.http.HttpProtocolChain.execute(HttpProtocolChain.java:79)
      at com.sun.grizzly.ProtocolChainContextTask.doCall(ProtocolChainContextTask.java:54)
      at com.sun.grizzly.SelectionKeyContextTask.call(SelectionKeyContextTask.java:59)
      at com.sun.grizzly.ContextTask.run(ContextTask.java:71)
      at com.sun.grizzly.util.AbstractThreadPool$Worker.doWork(AbstractThreadPool.java:532)
      at com.sun.grizzly.util.AbstractThreadPool$Worker.run(AbstractThreadPool.java:513)
      at java.lang.Thread.run(Thread.java:662)

      Glassfish seems to assume the whole application as distributable and doesn't allow the non-serializable SimpleSession to be added to the the HttpSession, even if no clustering is required.

      (Not sure) This might be a bug in Glassfish, as the merging rules for web.xml/web-fragment.xml seem complex (and confusing) and might be interpreted differently by containers.
      see

      The current workaround is to use the SerializableUiFactory when deploying ZK 6.5.4/7.0.0 on a Glassfish Container
      add the following configuration element to the zk.xml

      <system-config>
      	<ui-factory-class&gt;org.zkoss.zk.ui.http.SerializableUiFactory</ui-factory-class&gt;
      </system-config>
      

            jumperchen jumperchen
            cor3000 cor3000
            Votes:
            0 Vote for this issue
            Watchers:
            1 Start watching this issue

              Created:
              Updated:
              Resolved: