信息发布→ 登录 注册 退出

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

发布时间:2025-10-21

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

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 Illuminate\Support\Facades\Cache;

// 存储缓存 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 作为队列驱动

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

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

QUEUE_CONNECTION=redis

创建一个队列任务:

php artisan make:job SendWelcomeEmail

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

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

在控制器中分发任务:

use App\Jobs\SendWelcomeEmail;

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 的组合让缓存和异步任务变得简单高效。只要配置正确,日常开发中几乎无需关心底层细节。
标签:# default  # 高性能  # 并可  # 可以使用  # 详细介绍  # 推荐使用  # 你也  # 序列化  # 发送邮件  # 你可以  # 数据库  # database  # 异步  # redis  # 数据结构  # red  # 异步任务  # ai  # app  # cad  # json  # js  # word  # php  # laravel  
在线客服
服务热线

服务热线

4008888355

微信咨询
二维码
返回顶部
×二维码

截屏,微信识别二维码

打开微信

微信号已复制,请打开微信添加咨询详情!