负载平衡Plone 3.3.5时是否需要粘性会话?

| 我们遇到了一个我们怀疑与负载平衡有关的问题。我们在Apache之后有4个ZEO前端客户端。有时(从日志中)创建新内容项会记录错误。
2011-04-13T15:39:57 ERROR Zope.SiteErrorLog 1302701997.20.258830910503 https://x/intranet 
/portal_factory/MyType/xxx.2011-04-13.9797548037/xxx_edit
ValueError: Unable to find
我们怀疑发生的是,portal_factory将临时创建的项目存储在ZEO客户端会话存储中(我们如何确认),并且该存储未在ZEO客户端之间共享。当用户单击“保存”时,将发生验证错误,并且浏览器将返回到编辑屏幕。然后,此编辑屏幕视图转到另一个ZEO客户端,该客户端的会话存储中没有临时的“正在创建的项目”。 但是,我们之前已经运行了许多负载平衡的Plone站点,并且以前没有此问题的报告,因此我怀疑错误原因可能是其他原因,或者此站点上有某些因素触发了该行为。 不幸的是,这是一些相关的信息,非常模糊: http://plone.org/documentation/kb/sticky-sessions-and-mod_proxy_balancer     
已邀请:
在Plone 3中,对象创建逻辑中仍然保留了一些确实使用会话的代码。它在那里支持类似窗口小部件的界面,在该界面中,对象创建分散在多个实际请求中。这种支持和代码在Plone 4中消失了。 Plone 3中的这段代码依赖于访问request.SESSION。棘手的是,如果其他一些代码已经创建了会话,则该代码仅使用该会话。 Plone(甚至Plone 3)中没有任何代码应该首先创建会话,因此通常它不会存在并且不会被使用。但是,如果站点中的任何代码确实创建了会话,则对象创建逻辑也将使用它。这应该可以解释为什么您在大多数网站上都看不到问题。 所有这些特别棘手,因为只需调用request.SESSION即可创建一个会话。 Products.Archetypes中的content_edit_impl.py脚本使用不同的API来访问会话:
# Avoid implicitly creating a session if one doesn\'t exists
session = None
sdm = getToolByName(context, \'session_data_manager\', None)
if sdm is not None:
    session = sdm.getSessionData(create=0)
create = 0指示API避免在尚不存在会话的情况下隐式创建会话。 您可以尝试查找创建会话的代码,从原型中自定义代码以删除会话部分,也可以将会话存储区移到ZEO中并在所有Zope实例之间共享。虽然不建议在高流量网站上使用,但在简单情况下应该可以正常使用(https://weblion.psu.edu/trac/weblion/wiki/TemporaryStorageInZeo中的一些提示)。     
您的诊断不正确; portal_factory工具是无状态的,因此不需要任何会话关联。 您的错误消息也很模糊,看起来不完整。您是否检查了实例日志中的完整回溯?     

要回复问题请先登录注册