如何在PHP上转储和恢复redis数据库,我在客户端上使用predis。
我可以以.rdb格式转储redis数据库吗?
已更新:
我使用以下命令
转储/备份数据库$redis->bgSave();
如何将其还原回我的数据库?
答案 0 :(得分:2)
作为Malinga,在重启redis服务器时发生了恢复。所以你需要设置appendonly no。这样它就会使用.rdb文件。
所以,我创建了一个示例程序来备份和恢复redis数据库,以下是code check
导出:
$i = 0;
$json = array();
foreach($redis->keys('*') as $key) {
$data = array();
$data['key'] = $key;
$data['ttl'] = $redis->ttl($key);
$data['value'] = bin2hex($redis->dump($key));
$json[$i] = $data;
$i++;
}
header('Content-disposition: attachment; filename=database.json');
header('Content-type: application/json');
echo json_encode($json);
导入:
if (isset($_POST['submit']) && $_POST['submit'] == 'Import') {
$types = array(
'application/json',
'application/octet-stream'
);
if (in_array($_FILES['upload']['type'], $types)) {
var_dump($_FILES);
if (move_uploaded_file($_FILES['upload']['tmp_name'], 'uploads/' . $_FILES['upload']['name']))
{
$file = file_get_contents('uploads/' . $_FILES['upload']['name'], "r");
$database = json_decode($file, true);
foreach($database as $data)
{
if ($data['ttl'] >= 0)
{
$data['ttl'] = $data['ttl'];
}
else
{
$data['ttl'] = 0;
}
if ($data['key'] && $data['value'] && !$redis->exists($data['key']))
{
$redis->restore($data['key'], $data['ttl'], hex2bin($data['value']));
}
}
}
}
}
可以通过GitHub
下载完整代码答案 1 :(得分:1)
在redis中,您可以使用SAVE或BGSAVE创建快照。但是建议使用BGSAVE,因为SAVE会阻止所有其他客户端。
要在predis中这样做,应该可以通过
$client->executeRaw(['BGSAVE']);
对不起,我没试用过普锐斯。因此,首先检查客户端是否允许类似
$client->bgsave();
如果没有尝试上面
重启redis服务器时发生恢复。所以你需要设置appendonly no。这样它就会使用.rdb文件