简单易行用数据库控制Redis开关(数据库控制redis开关)
在云环境下,当Redis数据库的开关需要由人民维护时,就会变得极其繁琐,因此对于Redis的开关我们最好通过数据库来控制。
我们在Redis集群中添加一张表,以处理Redis开关的信息,表中有一列叫做switch字段,用来表示当前哪一台服务器是Redis开关,其取值0或者1,0表示Redis服务器关闭,1表示Redis服务器开启。另外,还可以添加一个附加字段,用来存放服务器名称。
接下来,我们写一个更新服务器Redis开关的脚本,这也是这种方式控制Redis开关的核心。
我们先定义一个简单的更新数据库 Records 脚本:
// 获取服务器名称
$server_name = $_GET[‘name’];
// 获取开关状态
$status = $_GET[‘status’];
// 更新记录参数
$sql = “UPDATE Records SET switch = $status WHERE server = $server_name”;
// 执行更新
$conn = new PDO(‘mysql:host=localhost;dbname=redis_record’, ‘root’, ‘123456’);
$stmt = $conn->prepare($sql);
$stmt->execute();
// 返回状态
echo ‘success’;
我们只需要在服务器运行上面的脚本即可。下一次需要更新Redis服务器开关时,我们就只需要调用这个接口就可以实现,代码如下:
// 设置服务器名称及状态
$server_name = ‘redis_server_1’;
$status = 1;
// 调用脚本更新Redis开关
$url = url(‘/update_switch.php’, [
‘name’ => $server_name,
‘status’ => $status
]);
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
$msg = curl_exec($ch);
curl_close($ch);
//输出状态
echo $msg;
通过上面的方式,我们就可以用数据库来控制Redis开关了,只需要简单调用接口,就能更新Redis数据库开关,极大提升了建设和维护Redis数据库开关的效率。