Java自学者论坛

 找回密码
 立即注册

手机号码,快捷登录

恭喜Java自学者论坛(https://www.javazxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,会员资料板块,购买链接:点击进入购买VIP会员

JAVA高级面试进阶训练营视频教程

Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程Go语言视频零基础入门到精通Java架构师3期(课件+源码)
Java开发全终端实战租房项目视频教程SpringBoot2.X入门到高级使用教程大数据培训第六期全套视频教程深度学习(CNN RNN GAN)算法原理Java亿级流量电商系统视频教程
互联网架构师视频教程年薪50万Spark2.0从入门到精通年薪50万!人工智能学习路线教程年薪50万大数据入门到精通学习路线年薪50万机器学习入门到精通教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程MySQL入门到精通教程
查看: 541|回复: 0

如何运用PHP+REDIS解决负载均衡后的session共享问题

[复制链接]
  • TA的每日心情
    奋斗
    2024-4-6 11:05
  • 签到天数: 748 天

    [LV.9]以坛为家II

    2034

    主题

    2092

    帖子

    70万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9

    积分
    705612
    发表于 2021-7-10 13:57:35 | 显示全部楼层 |阅读模式

    一、为什么要使用Session共享?

    稍大一些的网站,通常都会有好几个服务器,每个服务器运行着不同功能的模块,使用不同的二级域名,而一个整体性强的网站,用户系统是统一的,即一套用户名、密码在整个网站的各个模块中都是可以登录使用的。各个服务器共享用户数据是比较容易实现的,只需要在后端放个数据库服务器,各个服务器通过统一接口对用户数据进行访问即可。但还存在一个问题,就是用户在这个服务器登录之后,进入另一个服务器的别的模块时,仍然需要重新登录,这就是一次登录,全部通行的问题,映射到技术上,其实就是各个服务器之间如何实现共享 SESSION 数据的问题。

    二、了解session工作原理

    在解决问题之前,先来了解一下 PHP SESSION 的工作原理。在客户端(如浏览器)登录网站时,被访问的 PHP 页面可以使用 session_start() 打开 SESSION,这样就会产生客户端的唯一标识 SESSION ID(此 ID 可通过函数 session_id() 获取/设置)。SESSION ID 可以通过两种方式保留在客户端,使得请求不同的页面时,PHP 程序可以获知客户端的 SESSION ID;一种是将 SESSION ID 自动加入到 GET 的 URL 中,或者 POST 的表单中,默认情况下,变量名为 PHPSESSID;另一种是通过 COOKIE,将 SESSION ID 保存在 COOKIE 中,默认情况下,这个 COOKIE 的名字为 PHPSESSID。这里我们主要以 COOKIE 方式进行说明,因为应用比较广泛。

    服务端通过客户端传递的session_id区分用户,用来标记用户的登录状态。

    用户再次发送请求的时候,把服务端返回的session_id通过cookie[或者URL传参]的形式传递到服务端,这样服务端就可以区分出来具体操作的用户。

    三、如何解决负载均衡之后的session共享问题?

    1.不使用session,换作cookie

    把session改成cookie,就能避开session的一些弊端。【安全性较低】

    2.数据库记录下session信息

    使用数据库记录session信息,session的使用频率比较高,如果存在数据库中,频繁的读取会对数据库产生较大的压力,网站性能瓶颈一般都存在数据库.

    3.负载均衡的时候使用ip_hash算法进行分发

    使用ip_hash可能会导致某一台服务器负载较大。如果某段时间内服务器进入了很多固定IP代理的请求 [代理] ,如果代理IP的负载过高就会导致ip_hash对应的服务器负载压力过大,这样ip_hash就失去了负载均衡的作用了。

    4.对session文件进行同步

    使用同步工具对session文件进行同步,保证负载服务器的session文件都是一致的,这种做法虽然可以解决session共享的问题,同样的内容会存在多个服务器上,而且部分服务器存在的session文件可能从开始到结束完全没有使用到,浪费了服务器的资源。 【rsync,inotify-tools等】

    5.使用memcache或者redis保存session信息 [建议]

    相比文件取信息,从内存取数据速度要快很多,而且在多个服务器需要共用 session 时会比较方便,将这些服务器都配置成使用同一组 memcached 服务器就可以,减少了额外的工作量。其缺点是 session 数据都保存在 memory 中,一旦宕机,数据将会丢失。但对 session 数据来说并不是严重的问题。

    四、PHP+REDIS解决session共享问题

    1、session默认存储是php.ini中配置的

    //session存储方式
    session.save_handler = files  
      
    //session保存路径  N表示按照分级存储
    session.save_path = "N;/path"

     

    注:session.save_path = "2;/data/session_tmp"代表将session文件分成两级存放,即/data/session_tmp/4/b /sess_4b1e384ad74619bd212e236e52a5a174If,取前两位字符,但是php并不生成目录,需要自己手工生成。

    //session保存的目录
    session.save_path = "d:/wamp/tmp"    php自带函数session_save_path
    //是否自动开启session
    session.auto_start = 0

     

    2、设置session保存方式为redis

    (1) 修改完成之后重启php-fpm,nginx改php.ini配置文件

    session.save_handler = redis
            session.save_path = “tcp://127.0.0.1:6379″

     

    (2) 通过ini_set设置

    ini_set(“session.save_handler”,”redis”);
            ini_set(“session.save_path”,”tcp://127.0.0.1:6379″);

     

    有密码设置

      ini_set(“session.save_path”,”tcp://127.0.0.1:6379?auth=redisauthkey″);

     

    (3) 具体实现

    <?php        
    //如果未修改php.ini下面两行注释去掉       
     //ini_set('session.save_handler', 'redis');       
      //ini_set('session.save_path', 'tcp://127.0.0.1:6379');      
        session_start();        
        $_SESSION['sessionid'] = 'this is session content!';        
        echo $_SESSION['sessionid'];       
         echo '<br/>';
            $redis = new redis();       
             $redis->connect('127.0.0.1', 6379);       
              $redis->auth( ‘redisauthkey’ );
    //redis用session_id作为key并且是以string的形式存储        
    echo $redis->get('PHPREDIS_SESSION:' . session_id());  
    ?>

     

    3、通过session_id建立自己的一套session机制

    借助session_id建议一套自己的机制,原理可以参考session保存机制。

    • 用户第一次请求时候,给用户下发session_id。

    • 之后请求都要带上session

    • 用户登录之后把用户信息存在redis,借助session_id表示。

    好处就是:把自己的一套session机制抽象为类,如果之后session不存在redis,后期可以直接通过修改类文件解决问题。

    作者:齐亚威

    来源:宜信技术学院

    哎...今天够累的,签到来了1...
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|小黑屋|Java自学者论坛 ( 声明:本站文章及资料整理自互联网,用于Java自学者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2024-5-3 21:40 , Processed in 0.076547 second(s), 29 queries .

    Powered by Discuz! X3.4

    Copyright © 2001-2021, Tencent Cloud.

    快速回复 返回顶部 返回列表