如何解决Azure kubernetes-具有会话管理的应用程序吗?
我计划在Azure kubernetes上部署使用会话的Asp.net应用程序。如何确保传入请求到达创建会话的同一容器。
解决方法
建议在Kubernetes上部署的应用具有遵循The Twelve Factor App的设计。
如果该应用程序为无状态并且不共享任何内容,那么一切将变得更加容易。参见Twelve Factor App - Processes
十二个因素的过程是无状态的,没有共享。任何需要保留的数据都必须存储在有状态的支持服务中,通常是数据库。
某些网络系统依赖“粘性会话”,即将用户会话数据缓存在应用进程的内存中,并期望将来来自同一访问者的请求将路由到同一进程。粘性会话违反了十二个因素,因此切勿使用或依赖。会话状态数据非常适合提供时间到期的数据存储,例如Memcached或Redis。
使用Redis是存储属于用户的临时数据的一种方法。
对于身份验证,我建议在Authorization: Bearer <token>
标头中使用带有JWT令牌的OpenID Connect。参见例如Azure Active Directory B2C以获得OpenID Connect提供程序的示例。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。