当前位置: 首页 > news >正文

西安正邦网站建设网站seo培训

西安正邦网站建设,网站seo培训,网站外部链接添加方式,做网站推广销售怎么样多台服务器共享 session 问题 现在的大型网站中,如何实现多台服务器中的 session 数据共享呢? 当使用多台服务器架设成集群之后,我们通过负载均衡的方式,同一个用户(或者 ip)访问时被分配到不同的服务器上…

多台服务器共享 session 问题

现在的大型网站中,如何实现多台服务器中的 session 数据共享呢?

当使用多台服务器架设成集群之后,我们通过负载均衡的方式,同一个用户(或者 ip)访问时被分配到不同的服务器上,假设在 A 服务器登录,如果在 B 服务器拿不到用户的登录信息 session。这时访问到 B 服务器时就出现未登录情况。

所以如何对于这种情况做到共享 session 至关重要。

以下给出一些解决方案:(来源网络以及自己的一些见解)

1、通过数据库 mysql 共享 session

  • a、采用一台专门的 mysql 服务器来存储所有的 session 信息。
    用户访问随机的 web 服务器时,会去这个专门的数据库服务器 check 一下 session 的情况,以达到 session 同步的目的。

    • 缺点
      依懒性太强,mysql 服务器无法工作,影响整个系统;
  • b、将存放 session 的数据表与业务的数据表放在同一个库。
    如果 mysql 做了主从,需要每一个库都需要存在这个表,并且需要数据实时同步。

    • 缺点
      用数据库来同步 session,会加大数据库的负担。
      数据库本来就是容易产生瓶颈的地方,如果把 session 还放到数据库里面,无疑是雪上加霜。
      上面的二种方法,第一点方法较好,把放 session 的表独立开来,减轻了真正数据库的负担 。
      但是 session 一般的查询频率较高,放在数据库中查询性能也不是很好,不推荐使用这种方式。

2、通过 cookie 共享 session

  • 把用户访问页面产生的 session 放到 cookie 里面,就是以 cookie 为中转站。

    当访问服务器 A 时,登录成功之后将产生的 session 信息存放在 cookie 中;

    当访问请求分配到服务器 B 时,服务器 B 先判断服务器有没有这个 session,

    如果没有,在去看看客户端的 cookie 里面有没有这个 session,

    如果 cookie 里面有,就把 cookie 里面的 session 同步到 web 服务器 B,这样就可以实现 session 的同步了。

    • 缺点
      cookie的安全性不高,容易伪造、客户端禁止使用cookie等都可能造成无法共享session。

3、通过服务器之间的数据同步 session

  • 使用一台作为用户的登录服务器,当用户登录成功之后,会将 session 写到当前服务器上,我们通过脚本或者守护进程将 session 同步到其他服务器上,这时当用户跳转到其他服务器,session 一致,也就不用再次登录。

    • 缺点
      速度慢,同步session有延迟性,可能导致跳转服务器之后,session未同步。
      而且单向同步时,登录服务器宕机,整个系统都不能正常运行。

4、通过 NFS 共享 Session

  • 选择一台公共的 NFS 服务器(Network File Server)做共享服务器,所有的 Web 服务器登陆的时候把 session 数据写到这台服务器上,那么所有的 session 数据其实都是保存在这台 NFS 服务器上的,不论用户访问那太 Web 服务器,都要来这台服务器获取 session 数据,那么就能够实现共享 session 数据了。

    • 缺点
      依赖性太强,如果NFS服务器down掉了,那么大家都无法工作了,
      当然,可以考虑多台NFS服务器同步的形式。

5、通过 memcache 同步 session

  • memcache 可以做分布式,如果没有这功能,他也不能用来做 session 同步。他可以把 web 服务器中的内存组合起来,成为一个"内存池",不管是哪个服务器产生的 session 都可以放到这个"内存池"中,其他的都可以使用。

    • 优点
      以这种方式来同步session,不会加大数据库的负担,并且安全性比用cookie大大的提高,把session放到内存里面,比从文件中读取要快很多。
    • 缺点
      memcache把内存分成很多种规格的存储块,有块就有大小,这种方式也就决定了,memcache不能完全利用内存,会产生内存碎片,如果存储块不足,还会产生内存溢出。

6、通过 Redis 共享 session

  • Redis 与 memcache 一样,都是将数据放在内存中。区别的是 Redis 会周期性的把更新的数据写入磁盘或者把修改操作写入追加的记录文件,并且在此基础上实现了master-slave(主从)同步。
  • 根据实际开发应用,一般选择使用memcache或redis方式来共享session.
http://www.hkea.cn/news/918921/

相关文章:

  • 厦门专业网站建设如何快速推广一个新产品
  • 帮人做传销网站违法吗seo网站排名助手
  • 如何做优品快报下的子网站营销型网站建设目标
  • 用织梦做网站调用乱码营业推广是什么意思
  • 做走私网站北京口碑最好的it培训机构
  • 网站建设OA系统开发it培训机构哪家好
  • 网站运维可以做哪些域名查询网站入口
  • 网站开发的基本语言外贸平台自建站
  • 女生自己做网站营销方法有哪些
  • 怎么自己做网站吓别人金融网站推广圳seo公司
  • 彩票网站的客服有做吗海淀seo搜索优化多少钱
  • 河源哪有做网站网页模板设计
  • 手机网站可以做英文版本吗近三天时政热点
  • 怎么做网站游戏网络优化排名培训
  • ic外贸网站建设黑帽seo技巧
  • 实业有限公司网站怎么做百度一下了你就知道官网
  • 企业电子商务网站推广平台有哪些渠道
  • 本地用织梦做网站百度的网站网址
  • 基础展示营销型型网站新闻发稿平台有哪些
  • 做游戏赚钱的网站最新新闻热点事件2022
  • 商务网站建设哪家好推广代理公司
  • 自己做网站是否要买云主机西安百度提升优化
  • 成都注册公司哪个区好分析网站推广和优化的原因
  • 模板建站杭州seo泽成
  • 济南网站建设公司川芎网络怎么注册自己的网址
  • linux下安装wordpress关键词优化排名查询
  • wordpress手机网站怎么做中央电视台一套广告价目表
  • 百家号如何给网站做推广推广方案是什么
  • 西安三网合一网站建设产品线上推广方案
  • 2023年免费b站入口百度网站优化