解决session_start启动慢(治标的方法)
公司使用memcache来缓存session,但最近用户登录很慢,检查了mysql慢查询,最后锁定php中的session_start();这句,单独写了个页面来测试,还真是他的问题.下面是治标的解决方法,要治本还要靠各位大牛来帮忙啊.
下面是我们的测试页面,就几句
CPU,IO,磁盘,内存……这些没问题的,都有排查过,刚开始以为网络问题、被墙、过滤、内存……问题,最后确定都不是.应该不是硬件资源问题了.
现在用额外加段代码能解决这问题,治标不治本,还没找到是什么原因导致session_start启动慢.
先自动创建一PHPSESSID,不用session_start自动分配的.
最后的样子如下:
这样就不会再卡了,问题暂时解决,观察几天看看.
下面是我们的测试页面,就几句
<?php session_start(); echo '111';exit ?>
CPU,IO,磁盘,内存……这些没问题的,都有排查过,刚开始以为网络问题、被墙、过滤、内存……问题,最后确定都不是.应该不是硬件资源问题了.
现在用额外加段代码能解决这问题,治标不治本,还没找到是什么原因导致session_start启动慢.
先自动创建一PHPSESSID,不用session_start自动分配的.
if(!isset($_COOKIE['PHPSESSID'])) { setcookie('PHPSESSID', time(), time()+60*60, '/' ); header('location:index.php'); exit; }
最后的样子如下:
<?php if(!isset($_COOKIE['zenid']) && $_SERVER['HTTP_USER_AGENT']!='UDROBOT') { setcookie('zenid', md5(md5(time().rand(999,1000)).rand(999,1000)), time()+60*60, '/' ); header('location:'.$_SERVER['REQUEST_URI']); exit; } ..... ?>
这样就不会再卡了,问题暂时解决,观察几天看看.
评论: