zoukankan      html  css  js  c++  java
  • web集群时利用memcache来同步session

    web集群时利用memcache来同步session

    张映 发表于 2010-07-19

    分类目录: php

    以前我写过一篇关于web集群时,session同步怎么解决的文章。博文名称是web集群时session同步的3种方法,个人觉得用memcache来同步session是最好的,下面是我的设置过程

    1,模拟web集群

    我启动了二个memcached进程,分别模拟二台服务器

    /usr/local/bin/memcached -d -m 20 -u zhangy -p 12000 -P ./memcached.pid
    /usr/local/bin/memcached -d -m 20 -u zhangy -p 13000 -P ./mem.pid

     

    2,修改php的配置

    vi /usr/local/php/lib/php.ini

    session.save_handler = “memcache”
    memcache.hash_strategy = “consistent”
    session.save_path = “tcp://127.0.0.1:13000?weight=10,tcp://127.0.0.1:12000″

    说明:第一行,session的储存方式是memcache;第二行,memcache的hash算法是consistent;第三行,session储存的地位;

    3,重起apache

    查看phpinfo

    session

    Session Support enabled
    Registered save handlers files user sqlite memcache
    Registered serializer handlers php php_binary

    紧接着下面是

    session.save_path tcp://127.0.0.1:13000,tcp://127.0.0.1:12000 tcp://127.0.0.1:13000,tcp://127.0.0.1:12000

    4,做个简单测试

    a),准备文件session.php

    1. <?php  
    2. session_start();  
    3. $_SESSION['username'] = "abcabc";  
    4. echo session_id();  
    5. ?>  
    <?phpsession_start();$_SESSION['username'] = "abcabc";echo session_id();?>

    b),显示session内容文件

    1. <?php  
    2. $mem = new Memcache;  
    3. $mem->addServer("127.0.0.1",12000)or die ("Could not add server 12000");  
    4. $mem->addServer("127.0.0.1",13000)or die ("Could not add server 13000");  
    5. $val = $mem->get('qp0mrob2ovcqle3u4lbr4obsa5');    //echo session_id();  
    6. echo $val;  
    7. ?>  
    <?php$mem = new Memcache;$mem->addServer("127.0.0.1",12000)or die ("Could not add server 12000");$mem->addServer("127.0.0.1",13000)or die ("Could not add server 13000");$val = $mem->get('qp0mrob2ovcqle3u4lbr4obsa5');    //echo session_id();echo $val;?>

    c),结果是username|s:6:”abcabc”;

    5,关于memcache的api

    网上有很多关于memcache的api,你也可以自己写一个,php.net里面memcache的方法说的很清楚,并且例子很多,做起来很快。我是把thinkphp里面的有关于cache的类库拿出来,整合到自己的代码中。这个类库中不光包括memcahce,还有其他的一些cache。网上有关memcache的api思想差不多,大同小异,思想差不多,我觉得都是拿过来,山寨一下就是个新的。自己去找一下吧。

  • 相关阅读:
    SpringCloud学习笔记(6)——Eureka高可用
    上传大数据到SharePoint 2010
    批量导入导出站点权限site permissions
    List does not exist. The page you selected contains a list that does not exist. It may have been deleted by another user
    Change upload file limit in specified Webapllication in SharePoint (PowerShell)
    导出SharePoint2013用户及权限
    启用SharePoint 2013文档版本控制
    移除SharePoint2013里的NoteBook笔记本链接
    启用SharePoint 的 web application下面所有站点“备用语言”
    SharePoint 2013 event id 8321 错误
  • 原文地址:https://www.cnblogs.com/dasn/p/1864366.html
Copyright © 2011-2022 走看看