laravel框架的高级知识点(laravel配置Redis多个库的实现方法)
laravel框架的高级知识点
laravel配置Redis多个库的实现方法c导语
经过编译安装和安装扩展之后,Redis 已经可以正常使用了。但是在 laravel 中还需要其他的操作。
安装扩展
要想在 laravel 中使用 Redis,还需要安装 predis
扩展。使用 composer require predis/predis
进行安装就可以了。
修改配置
-
Redis 的配置在
config/database.php
文件,根据需求修改,我这里不需要改动; -
设置 Cache 默认缓存为 Redis,在
.evn
文件中CACHE_DRIVER=redis
; -
设置 Session 的驱动为 Redis,在
.env
文件中SESSION_DRIVER=redis
;
配置多个库
经过以上的配置后,多个服务都使用 Redis,如果都使用同一个库,这显然是不合理的。我们可以配置多个连接来解决这个问题。
Redis 默认有 16 个库,在服务器中设置 redis.conf
的 database
值可以修改。
先来看下 config/database.php
的默认连接
|
'redis' => [ 'client' => 'predis' , 'default' => [ 'host' => env( 'REDIS_HOST' , '127.0.0.1' ), 'password' => env( 'REDIS_PASSWORD' , null), 'port' => env( 'REDIS_PORT' , 6379), 'database' => env( 'REDIS_DB' , 0), ], 'cache' => [ 'host' => env( 'REDIS_HOST' , '127.0.0.1' ), 'password' => env( 'REDIS_PASSWORD' , null), 'port' => env( 'REDIS_PORT' , 6379), 'database' => env( 'REDIS_CACHE_DB' , 1), ], ], |
默认是有两个连接的,分别是 default
和 cache
。下面来看下 config/cache.php
中关于 Redis 的配置
|
'redis' => [ 'driver' => 'redis' , 'connection' => 'cache' , ], |
可以看到它的 connection
值是 cache
,也就是使用 config/database.php
中 Redis 的 cache
。
下面修改 config/database.php
的 Redis,添加一个 session 的连接,如下
|
'redis' => [ 'client' => 'predis' , 'default' => [ 'host' => env( 'REDIS_HOST' , '127.0.0.1' ), 'password' => env( 'REDIS_PASSWORD' , null), 'port' => env( 'REDIS_PORT' , 6379), 'database' => env( 'REDIS_DB' , 0), ], 'cache' => [ 'host' => env( 'REDIS_HOST' , '127.0.0.1' ), 'password' => env( 'REDIS_PASSWORD' , null), 'port' => env( 'REDIS_PORT' , 6379), 'database' => env( 'REDIS_CACHE_DB' , 1), ], 'session' => [ 'host' => env( 'REDIS_HOST' , '127.0.0.1' ), 'password' => env( 'REDIS_PASSWORD' , null), 'port' => env( 'REDIS_PORT' , 6379), 'database' => env( 'REDIS_SESSION_DB' , 2), ], ], |
接下来在 .env
中添加 SESSION_CONNECTION=session
。
测试
经过上面的操作,已经修改好了。总结下就是 default
使用的是 0 库,cache
使用的是 1 库,session
使用的是 2 库。
使用如下代码来测试下
|
/** * 测试 Redis 的存储 */ public function testRedis() { // Redis 门面 Redis::setex( 'facades' , 30, 'i am facades' ); // Cache Cache::put( 'cache' , 'i am cache' , now()->addMinute(30)); // 因为 Cache 默认是 Redis,所有和上面语句相同 // Cache::store('redis')->put('cache', now(), now()->addMinute(30)); } |
运行以上代码之后,在服务器中使用 redis-cli
来看下存储情况
可以看到各个库的存储情况
-
使用 Redis 门面操作,默认为
config/database.php
中 Redis 的default
连接,数据存入 0 库; -
使用 Cache 操作,因为
config/cache.php
中 Redis 的connection
设置为cache
,理所当然存入的是 1 库; -
Session 也根据
SESSION_CONNECTION=session
配置,正确的存入了 2 库;
使用 Redis 门面的时候,也可以指定连接
|
$redis = Redis::connection( 'session' ); $redis ->setex( 'facades_connection' , 30, 'i am facades_connection' ); |
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持开心学习网。
原文链接:https://segmentfault.com/a/1190000018811316
- phpredis怎么设置队列(php使用lua+redis实现限流,计数器模式,令牌桶模式)
- python操作redis(Python获取Redis所有Key以及内容的方法)
- docker配置redis集群(基于Docker搭建Redis主从集群的实现)
- php消息队列redis(redis+php实现微博二发布与关注功能详解)
- redis在php中的使用(PHP+Redis开发的书签案例实战详解)
- phpredis存储对象(PHP使用redis位图bitMap 实现签到功能)
- 查看linux上是否安装redis(Linux安装Redis实现过程及报错解决方案)
- docker部署redis集群查看版本(docker下的 redis 之持久化存储详解)
- Docker 部署单机版 Pulsar 和集群架构 Redis(开发神器)的方法(Docker 部署单机版 Pulsar 和集群架构 Redis开发神器的方法)
- phpredis怎么实现任务(PHP swoole和redis异步任务实现方法分析)
- php实现redis消息队列(redis+php实现微博三微博列表功能详解)
- django测试服务器静态资源放哪里(Django使用redis缓存服务器的实现代码示例)
- 用docker搭建redis集群(docker实现redis集群搭建的方法步骤)
- win7redis安装教程(Docke中安装redis的方法)
- phpredis常用方法(PHP针对redis常用操作实例详解)
- docker查找redis配置文件(解决docker重启redis,mysql数据丢失的问题)
- 我们现在吃的苹果是哪里来的 原来现代苹果引入中国仅有一百多年(我们现在吃的苹果是哪里来的)
- 买绿宝不能只挑黄绿色 菜农教你3招挑,个个皮薄肉脆,香甜爆汁(买绿宝不能只挑黄绿色)
- 大果肉搭配薄瓜皮, 绿宝 脆甜爽口,不愧是甜瓜中的 佼佼者(大果肉搭配薄瓜皮)
- 河南尉氏县因地制宜发展果蔬种植 水坡镇绿宝甜瓜变 金瓜(河南尉氏县因地制宜发展果蔬种植)
- 谢广坤,你这么欺负谢腾飞,良心不会痛吗(你这么欺负谢腾飞)
- 乡村爱情15 宋晓峰怀疑自己孩子,腾飞与姜奶奶亲子鉴定出结果(宋晓峰怀疑自己孩子)
热门推荐
- thinkphp5.1请求流程(ThinkPHP5.0框架使用build 自动生成模块操作示例)
- docker1.12.5容器假死(解决docker run后容器出现Exited 0情况的问题)
- dockerfile的镜像原理(dockerfile制作apache镜像的方法)
- python基于django的博客系统(利用django+wechat-python-sdk 创建微信服务器接入的方法)
- dedecms快速建站(Dedecms 生成静态页面速度优化方法)
- javascript如何操作文档元素(JavaScript操作元素实例大全)
- 怎样查看mysql的ddl窗口(详解MySQL8.0原子DDL语法)
- Web安全色
- 云服务器的使用技术(云服务器运行如何实现的原理)
- dede生成的路径有问题(dede查询列表中单独显示查到了多少条记录)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9