您好,登錄后才能下訂單哦!
PHP 中 Session 存儲(chǔ)在文件中,對(duì)于一般需求來(lái)講沒(méi)什么問(wèn)題,但是對(duì)于高并發(fā)、分布式集群架構(gòu)的項(xiàng)目來(lái)講,會(huì)有 性能和Session 共享 的問(wèn)題。
解決方案:配置 Session 存儲(chǔ)在 NoSQL 中,如 Redis 等
Reids 存儲(chǔ)
方法1:php.ini 配置 session.save_handler = redis session.save_path = "tcp://127.0.0.1:6379" 重啟 php-fpm 方法2:腳本中 ini_set() 配置
ini_set("session.save_handler", "redis");
ini_set("session.save_path", "tcp://127.0.0.1:6379");
Redis 如果配置了密碼,/etc/redis.conf 中的 requirepass ,session 存儲(chǔ)時(shí)會(huì)報(bào)錯(cuò)
方案:session.save_path = "tcp://127.0.0.1:6379?auth=authpass"
從Redis 中讀取session
key = "PHPREDIS_SESSION:".session_id() ; // session_id() 拼接前綴 PHPREDIS_SESSION,并以字符串形式存儲(chǔ)
測(cè)試代碼
<?php
// 如果未修改php.ini下面兩行注釋去掉
// ini_set('session.save_handler', 'redis');
// ini_set('session.save_path', 'tcp://127.0.0.1:6379');
session_start();
$_SESSION['sessionid'] = 'this is session content!';
echo $_SESSION['sessionid'];
echo '<br/>';
$redis = new redis();
$redis->connect('127.0.0.1', 6379);
// redis 用 session_id 作為 key 并且是以 string 的形式存儲(chǔ)
echo $redis->get('PHPREDIS_SESSION:' . session_id());
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。