php memcache 同步,采用memcache在web集群中实现session的同步会话

本文介绍了如何在Web集群环境中使用Memcache同步PHP session,包括配置步骤、实例演示及注意事项。通过设置session.save_handler为memcache,确保一致性哈希策略,并指定多台服务器路径,实现在多个节点间的session共享。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

使用memcache来同步session是还是不错的,当然也可以通过redis来保存session,可以php开启并将Session存储到Redis缓存,下面是设置利用memcache在web集群中同步会话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

session_start();

$_SESSION['username'] = "abcabc";

echo session_id();

?>

b)、显示session内容文件

$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(); 得到的session id

echo $val;

?>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值