php本身的session机制不能跨机,这个多服务器,或者多子域名的开发带来了麻烦。通过万能的GOOGLE知道目前大概有这么几种方案解决
1)使用数据库来实现
2)自己写server端,通过改写session处理函数来请求
3)使用nfs等跨机存储来保存session
4)使用memcached来保存
5)使用zend platform提供的解决方案 

6)还有一种鬼子比较喜欢的方式,Tokyo tyrant实现session共享

大概现在搜到的就这几种,通过比较选择了memcached,参考这里http://rfyimcool.blog.51cto.com/1030776/668108

Memcached服务器端安装:

1.下载libevent和memcached

最新版本是: libevent-1.4.9-stable.tar.gz和memcached-1.2.6.tar.gz

libevent官方: http://www.monkey.org/~provos/libevent/

Memcached官方: http://www.danga.com/memcached/

2.安装

 

# cd /data/src

 

# tar zxvf libevent-1.4.9-stable.tar.gz

 

# cd libevent-1.4.9-stable

 

# ./configure –prefix=/usr && make && make install

 

# ls -al /usr/lib |grep libevent # 检查是否安装成功

 

# cd /data/src

 

# tar zxvf memcached-1.2.6.tar.gz

 

# cd memcached-1.2.6

 

# ./configure –with-libevent=/usr && make && make install

 

# ls –al /usr/local/bin/mem* # 检查是否安装成功

 

3.启动

 

# /usr/local/bin/memcached –d –m 512 –l 211.162.62.77 -p 11211 -P /tmp/memcached.pid

 

-d选项是启动一个守护进程;

-m是分配给Memcache使用的内存数量;单位是MB;

-u是运行Memcache的用户,或者是root,

-l是监听的服务器IP地址;

-p是设置Memcache监听的端口;

-c选项是最大运行的并发连接数,默认是1024;

-P是设置保存Memcache的pid文件;保存在 /tmp/memcached.pid

 

 

Web端的设置

1.安装php-memcached扩展

 

# cd /data/src

 

# tar zxvf memcache-3.0.3.tgz

 

# cd memcache-3.0.3

 

# /usr/local/php/bin/phpize

 

# ./configure --enable-memcache --with-zlib-di –with-php-config=/usr/local/php/bin/php-config

 

# make && make install

 

设置php.ini

 

l       把extension_dir修改为/usr/local/php/lib/php/extensions

 

l       把memcache.so复制到上述目录

 

l       添加一行载入memcache扩展:extension = memcache.so

 

l       在[session]标签下,把session.save_handler = memcache

 

l       session.save_path = "tcp://211.162.58.77:11211"

 

2.测试环境

1)phpinfo

 

 

Registered save handlers

 

files user sqlite memcache

 

2)test1.php

<?php

session_start();

if (!isset($_SESSION['TEST'])) {   

$_SESSION['TEST'] = time();

}

$_SESSION['TEST3'] = time();

print $_SESSION['TEST'];

print "<br><br>";

print $_SESSION['TEST3'];

print "<br><br>";

print session_id();

?>

输出:

1234506445

1234506445

3bbf03b9cedace4e0164a0c3d56712d1

3)test2.php

取test1.php输出的sessionid来测试

<?php

$memcache = memcache_connect('211.162.58.77', 11211);

var_dump($memcache->get('3bbf03b9cedace4e0164a0c3d56712d1'));

?>

输出:

string(37) "TEST|i:1234503252;TEST3|i:1234503398;"

至此,测试成功!

 

现在记录一下碰到的问题,参照上面方法,安装,测试都没问题,但是在自己系统中二级域名下貌似还是无法取$_SESSION,后通过参考

http://zhengdl126.iteye.com/blog/768211    将php.ini中的session.use_cookies设置为1,当然默认情况下也是设置为1的,session.cookie_domain设置为自己系统的顶级域名,比如abc.com/  www.abc.com/  web.abc.com  那么

session.cookie_domain就应该设置为“.abc.com” 

 

同时原来的在销毁session时必须 session_unset();后session_destroy();  同时将内存和文件全部销毁,否则会出现

session_destroy 后 var_dump一下$_SESSION变量,仍然有值的,但此值不会在close后被write回去