我一直在使用Flask login module,它在服务器上创建和维护会话。
由于服务器维护会话,我认为它不是完全无状态的。当应用程序有多个服务器时,它是如何工作的。请求是否应该是粘性的(即,给定会话应该向特定服务器发出后续请求)?
答案 0 :(得分:13)
您所做的陈述并不完全正确:
...在服务器上创建和维护会话。
Flask-Login使用Flask提供的会话功能,因此它存储在会话中的数据将由Flask使用配置的会话存储机制编写。
默认情况下,Flask将用户会话作为安全cookie写入客户端,但也可以在服务器上进行会话。例如,此snippet显示了如何配置Flask以在服务器端Redis存储上写入会话。
当用户会话存储在客户端cookie中时,很明显拥有多个服务器不是问题。 cookie将被发送到处理每个请求的服务器,所以一切都会正常工作。
对于服务器端会话,这也适用。服务器端会话在唯一标识符下写入,然后将此唯一标识符存储在客户端cookie中。然后每个请求都带有会话ID,Flask使用此ID加载会话数据。如果将所有Web服务器配置为使用相同的用户会话存储,则多个服务器可以毫无问题地处理来自同一客户端的请求。