session是服务器端使用的一种记录客户端状态的机制,但是也相对的增加了服务器的存储压力。
因为session是以文件的形式保存在服务器内的。
而且session文件都是小文件,当服务器中的session文件过多时,会导致服务器的IO效率降低,web处理效率也会降低。
因为在同一级目录存在过多的session文件,当然你也可以设置session的多级目录存储。
但是你的session文件一多的话,还是会影响web访问的效率的,并且服务器对于小文件的查找是非常慢的。
怎么解决这个问题呢?
其实我们可以把session保存在redis中就可以了。
下面以php为例。其他语言也类似
第一步,先在服务器上安装redis扩展,只有安装了扩展之后,你才能操作redis。
第二步,修改php.ini的配置。
1.redis有密码的设置方法
session.save_handler = redis # 默认的设置是file,这里改成redis
session.save_path = "tcp://127.0.0.1:6379?auth=passwd" # 这里填redis的连接配置参数
2.redis没有密码的设置方法
session.save_handler = redis # 默认的设置是file,这里改成redis
session.save_path = "tcp://127.0.0.1:6379" # 如果redis不带密码,则使用这种配置
3.如果你有多个站点,并不想全局设置的话,你可以在php中操作这两个参数。
ini_set('session.save_handler', 'redis');
ini_set('session.save_path', 'tcp://127.0.0.1:6379');
存储到redis里面的keys的名称是类似 PHPREDIS_SESSIONxxxxxxxxx ,我们只需要连接到redis,并执行 scan 0 match PHPREDIS_SESSION* 即可列出全部的sessionkeys
总结:这样的话,就可以降低web端访问的压力了,并且服务器的压力也不会太大,比较服务器对于小文件的操作是非常慢的。能够快速的反应过来,降低了服务器的IO操作。但是注意了,列出redis库中的键的时候千万不要用keys *,这样操作的话,如果你的redis数据库中的集合过大的话,是会造成服务器卡顿的,然后可能会一两个小时都会卡住。想要列出库中键的话,可以用scan来查找redis库中键。
举报/反馈