Swoft 2.0 在 session 配置上和 1.0 还是有一些不同地方,而关于这些在 github 上完全没有任何说明,甚至连文档也没有。经过逐步梳理源代码(其中要理解他的 “注解”)对比默认的 1.0 和其他存储方式文件配置,稍微测通了。
首先 session 用 redis 存储时,要先根据 2.0 的文档把 redis 配置好,这里无须赘述,需要说的一点就是:它的 redis 连接池默认是‘redis.pool’。
现在附上 session 配置在 bean.php 里加上
'sessionManager' => [
'class' => Swoft\Http\Session\SessionManager::class,
'name' => 'MYSWOFT_SESSION_ID',
'handler' => bean('sessionHandler'),
'lifetime' => 1800,
'expire_on_close' => false,
'encrypt' => false,
//'storage' => '@runtime/sessions',
],
'sessionHandler' => [
'class' => Swoft\Http\Session\Handler\RedisHandler::class,
'redis' => bean('redis.pool')
// For storage session files
//'savePath' => alias('@runtime/sessions')
],
这里需要注意的几点:
1. 遵循这个结构配置,1.0 的配置结构不再适用,原因在于拓展模块文件的参数都变了;
2.’sessionManager’下’class’的路径,2.0 和 1.0 的路径有差异;
3.’sessionHandler’下’redis’这个参数,这个位置卡了半天,出现 redis 适用方法找不到情况,最后发现 RedisHandler 中的属性没有默认值,需要赋值。这个赋值也关联到前面的 redis 的连接池,如果你的连接池改了其他名称,这里也需要跟着改;
4. 和第三点差不多,如果用到了其他的存储方式要注意查看模块文件是否有需要在配置文件赋值的属性(比如文件存储时设置 savePath),这里需要多了解他里面的 “注解”;
更多PHP内容请访问:
腾讯T3-T4标准精品PHP架构师教程目录大全,只要你看完保证薪资上升一个台阶(持续更新)
以上内容希望帮助到大家,很多PHPer在进阶的时候总会遇到一些问题和瓶颈,业务代码写多了没有方向感,不知道该从那里入手去提升,对此我整理了一些资料,包括但不限于:分布式架构、高可扩展、高性能、高并发、服务器性能调优、TP6,laravel,YII2,Redis,Swoole、Swoft、Kafka、Mysql优化、shell脚本、Docker、微服务、Nginx等多个知识点高级进阶干货需要的可以免费分享给大家,需要的可以加入我的官方群点击此处。
网友评论