• PHP实现多服务器SESSION共享


    为什么要session共享?

    现在稍微大一点的网站基本上都有好几个子域名,比如www.feiniu.com, search.feiniu.com, member.feiniu.com,
    这些网站如果需要共用用户登录信息,那么就需要做到session共享,当然前提是有相同的主域名。

    PHP的session原理?

    客户端访问php页面,执行session_start,生成session_id,一般我们是把session_id存储到cookie上,session内容保存在服务端,
    客户端访问访问不同的页面都会把session_id传到服务端,通过session_id来获取session内容。

    流程是这样,可是不同的服务器会对同一个客户端产生不同的session_id,这样的话不同服务器就不能得到相同的session内容。
    而且PHP 默认的 SESSION 数据都是分别保存在本服务器的文件系统中。

    所以我们要解决session共享,就必须解决两个问题:

    1. 多台服务器用同一个session_id

    1 这个比较容易解决,只要在php中设置存session_id的cookie域名为网站主域就可以
    2 打开PHP.ini, 设置session.cookie_domain = .feiniu.com, 
    3 当然也可以在php代码当中设置ini_set("session.cookie_domain","feiniu.com");

    2. 多台服务器用同一个session_id访问到相同的session内容 

    1 要实现这点,就必须把session内容存储到让所有服务器都能访问到的地方,php的session内容是默认存储到本服务器的文件中的,
    2 一般的解决方案是存入数据库,memcache或者redis这种缓存服务器,当然用默认的文件存储方式也可以,用NFS统一存储。
    3 
    4 如何修改session存储引擎,参考这篇文章:http://blog.csdn.net/yagas/article/details/7593415

    如何选择存储引擎?

    默认文件存储:

    1 这种方式的session销毁依托于php垃圾收集器,在高并发或销毁时间较长的情况下,在SESSION目录下产生大量文件,当然可以设置分级目录进行 SESSION 文件的保存。
    2 这会导致两个问题:第一、查找文件慢;第二,每个目录下可容纳的文件数是有限的,可能会导致新SESSION储存失败。

    数据库存储:

    1 把Session存储在数据库里可以防止Session数据被垃圾收集器删除,可以固化存储session数据。
    2 但是用数据库来同步session,会加大数据库的IO,增加数据库的负担。而且数据库读写速度较慢,不利于session的适时同步。

    memcache存储:

    1.以这种方式来同步session,不会加大数据库的负担,并且安全性比较高,把session放到内存里面,比从文件中读取要快很多。
    
    2.但是memcache把内存分成很多种规格的存储块,有块就有大小,这种方式也就决定了,memcache不能完全利用内存,会产生内存碎片,如果存储块不足,还会产生内存溢出。
    
    3.那些不需要“分布”的,不需要共享的,或者干脆规模小到只有一台服务器的应用,memcached不会带来任何好处,相反还会拖慢系统效率,因为网络连接同样需要资源。

    redis存储:与memcache相比,redis访问稍稍慢一点点,好处是:

    1.redis支持的数据结构较多,可以存储数组或对象,而memcache只能存储字符串。
    
    2.在session机器重启的情况下,memcache所有用户都必须重新获得 session,而redis不会。
    
    3.在突然涌来大量用户产生了很多数据把存储 session 的机器内存占满了的情况下,memcache会罢工,所有key都没过期的话就不停的覆盖最后写入的数据,而redis只是会变慢,不会影响程序的逻辑。

    原文地址: https://blog.csdn.net/xue632777974/article/details/68060837?utm_source=copy

  • 相关阅读:
    JavaCV的摄像头实战之一:基础
    JavaCV的摄像头实战之三:保存为mp4文件
    JavaCV的摄像头实战之五:推流
    JavaCV的摄像头实战之二:本地窗口预览
    几行代码把Chrome搞崩溃之:HTML5 MP3录音由ScriptProcessorNode升级成AudioWorkletNode采坑记
    根据经纬度坐标获得省市区县行政区划城市名称,自建数据库 java python php c# .net 均适用
    最新全国省市区县乡镇街道行政区划数据提取(2022年)
    我完成了10000小时开发3D引擎 Wonder
    腾讯云轻量服务器通过Docker搭建外网可访问连接的redis5.x集群
    Maven Helper插件——实现一键Maven依赖冲突问题
  • 原文地址:https://www.cnblogs.com/cxx8181602/p/9759645.html
Copyright © 2020-2023  润新知