laravel如何使用Redis进行缓存和队列_Laravel Redis缓存与队列使用教程

laravel通过配置redis实现高性能缓存与队列,先在.env文件设置redis连接参数并指定CACHE_DRIVER=redis和QUEUE_CONNECTION=redis,结合phpredis扩展提升性能;使用Cache门面或cache()函数操作缓存,通过dispatch分发队列任务,配合queue:work命令处理异步逻辑,并可配置不同数据库分离缓存与队列、启用失败队列记录,实现高效稳定的任务管理。

laravel如何使用Redis进行缓存和队列_Laravel Redis缓存与队列使用教程

Laravel 使用 Redis 作为缓存和队列驱动非常方便,Redis 不仅性能高,还支持多种数据结构和持久化机制。下面详细介绍如何在 Laravel 中配置并使用 Redis 实现缓存和队列功能。

配置 Redis 环境

确保你的系统已安装并运行 Redis 服务。Laravel 默认使用 predis/predisphpredis 扩展与 Redis 通信。

推荐使用 phpredis 扩展(通过 PECL 安装),性能更好。

.env 文件中设置 Redis 连接信息:

 REDIS_HOST=127.0.0.1 REDIS_PASSword=null REDIS_PORT=6379 REDIS_DB=0 

config/database.php 中确认 Redis 配置项正确:

 'redis' => [     'client' => 'phpredis', // 或 '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),     ], ], 

使用 Redis 作为缓存驱动

将 Laravel 的缓存默认驱动切换为 redis。

修改 .env 文件:

 CACHE_DRIVER=redis 

之后你可以使用 Laravel 的 Cache 门面进行缓存操作:

 use IlluminateSupportFacadesCache;  // 存储缓存 10 分钟 Cache::put('user_1', ['name' => 'John', 'age' => 30], 600);  // 获取缓存 $user = Cache::get('user_1');  // 判断缓存是否存在 if (Cache::has('user_1')) {     // }  // 永久存储 Cache::forever('settings', $config);  // 删除缓存 Cache::forget('user_1'); Cache::flush(); // 清空所有(慎用) 

你也可以使用辅助函数 cache()

 cache(['key' => 'value'], 3600); $value = cache('key'); 

使用 Redis 作为队列驱动

队列用于异步处理耗时任务,如发送邮件、处理上传等。

laravel如何使用Redis进行缓存和队列_Laravel Redis缓存与队列使用教程

存了个图

视频图片解析/字幕/剪辑,视频高清保存/图片源图提取

laravel如何使用Redis进行缓存和队列_Laravel Redis缓存与队列使用教程17

查看详情 laravel如何使用Redis进行缓存和队列_Laravel Redis缓存与队列使用教程

修改 .env 文件启用 Redis 队列驱动:

 QUEUE_CONNECTION=redis 

创建一个队列任务:

 php artisan make:job SendWelcomeEmail 

在生成的 SendWelcomeEmail.php 中定义任务逻辑:

 public function handle() {     // 发送邮件逻辑     Mail::to($this->user)->send(new WelcomeMail()); } 

在控制器中分发任务:

 use appJobsSendWelcomeEmail;  dispatch(new SendWelcomeEmail($user)); // 或者 SendWelcomeEmail::dispatch($user); 

启动队列监听器处理任务:

 php artisan queue:work 

建议使用 supervisor 管理队列进程,保证常驻运行。

队列数据会存储在 Redis 的 queues:default list 中,你可以通过 redis-cli 查看:

 redis-cli LRANGE queues:default 0 -1 

高级配置与优化建议

  • 连接分离:可为缓存和队列配置不同的 Redis 数据库(如 DB 1 用于缓存,DB 2 用于队列)
  • 序列化方式:Redis 默认使用 PHP 序列化,可改为 jsON 提高跨语言兼容性
  • 超时控制:在队列任务中设置 timeout 和 tries 避免卡死
  • 失败队列:启用 failed_jobs 表记录失败任务,便于重试

启用失败队列:

 php artisan queue:failed-table php artisan migrate 

配置 .env

 QUEUE_FAILED_DATABASE=redis 

基本上就这些。Laravel + Redis 的组合让缓存和异步任务变得简单高效。只要配置正确,日常开发中几乎无需关心底层细节。

以上就是laravel如何使用Redis进行缓存和队列_Laravel Redis缓存与队列使用教程的详细内容,更多请关注php中文网其它相关文章!

上一篇
下一篇
text=ZqhQzanResources