这种只能够再后台服务器代码里面设置一个方法,在前端Ajax请求的时候,进行返回sessionId信息了。因为不知道具体的语言所以所得比较笼统(比如:Java的话可能会说再action层写一个AJAX处理的方法;PHP不是很好说一般是controller层中写)
最近在开发MySQL代理中间件过程中, 遇到这样一个问题: 当前后端连接不是一一对应的关系时, 对前端连接设置SESSION级别的变量时, 如何能使前端后变量的值保持一致
一个直观的实现方式是, 拦截SET语句, 判断scope是SESSION时, 将变量的值保存在前端连接中 当执行其他查询语句时, 在获取后端连接后, 先将前端连接中保存的变量逐一发送到后端连接, 然后执行查询语句, 释放后端连接时再将变量的值恢复
这种实现方式存在几个显著的问题
1 存在一定的性能损耗, 至少增加了1次与后端MySQL的交互 但是, 这也是后端连接池方案都会遇到的问题, 前后端连接绑定不存在这种问题, 但是也就失去了连接池带来的好处
2 需要判断参数值是否合法, 实现起来非常繁琐 例如, 如果考虑支持字符集设置, 就要枚举出MySQL支持的所有字符集及字符序类型, 解析 SET NAMES 'utf8' COLLATE 'utf8_general_ci' 时, 对字符集和字符序进行合法性判断 对于某些参数, 例如sql_mode, 还需要考虑MySQL版本之前的差异
在这种实现方式下, 有几个优化点可以参考
1 批量执行SET语句 MySQL语法层面支持 SET SESSION var1 = val1, SESSION var2 = val2; , 因此不论前端连接接收到的SET语句是单条的还是批量的, 在将这些kv值发往后端时, 可以整合成一条SQL, 从而减少与MySQL的交互次数, 提高执行效率
2 后端连接按需重置 当归还后端连接时, 不再重置连接, 而是在下一次获取连接时, 先判断连接中的变量值与前端连接是否全部相同, 如果全部相同, 则不需要重置, 可以直接使用, 否则, 将那些值不相同的变量设置到后端连接
3 使用 COM_RESET_CONNECTION 命令重置连接 COM_RESET_CONNECTION命令可以将连接恢复到初始状态, 具体内容可参考文档: >
如果仅仅是写demo,对于sprintboot项目,只要在启动类加上@EnableRedis>
以上就是关于js怎么获得服务器端的session id全部的内容,包括:js怎么获得服务器端的session id、如何使MySQL前后端连接SESSION变量保持一致、redis实现session共享的一些细节等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)