下面是一个更详细和丰富的 PHP Redis 分布式缓存示例:
// 使用 Predis 客户端连接到 Redis
require 'predis/autoload.php';
Predis\Autoloader::register();
$redis = new Predis\Client();
// 定义缓存键
$cacheKey = 'user:123';
// 尝试从缓存中获取数据
$cachedData = $redis->get($cacheKey);
if ($cachedData) {
// 如果缓存中有数据,直接使用缓存数据
$userData = unserialize($cachedData);
echo "Data fetched from cache:\n";
echo "User ID: " . $userData['id'] . "\n";
echo "Username: " . $userData['username'] . "\n";
echo "Email: " . $userData['email'] . "\n";
} else {
// 如果缓存中没有数据,从数据库中获取数据,并存入缓存
$dbData = [
'id' => 123,
'username' => 'john.doe',
'email' => 'john.doe@example.com'
];
$serializedData = serialize($dbData);
$redis->set($cacheKey, $serializedData);
$redis->expire($cacheKey, 60); // 设置缓存过期时间为60秒
echo "Data fetched from database:\n";
echo "User ID: " . $dbData['id'] . "\n";
echo "Username: " . $dbData['username'] . "\n";
echo "Email: " . $dbData['email'] . "\n";
}
在这个示例中,我们首先使用 get
命令尝试从 Redis 缓存中获取指定的键 $cacheKey
的数据。
如果缓存中有数据,我们将反序列化缓存数据,并打印出用户的 ID、用户名和邮箱地址。
如果缓存中没有数据,我们从数据库中获取数据,并将数据序列化后存入缓存,并设置缓存过期时间为 60 秒。
然后,我们打印出从数据库中获取的用户的 ID、用户名和邮箱地址。
这个示例演示了如何在 PHP 中使用 Redis 实现分布式缓存。通过缓存数据,我们可以减少对数据库的访问,提高应用程序的性能。你可以根据需要进行进一步的操作和扩展,例如设置不同的缓存过期时间、使用哈希表存储复杂的缓存数据等。