PHP+MYSQL实现读写分离简单实战

发布时间 - 2026-01-11 00:09:06    点击率:

1、Introduction

之前写过2篇文章,分别是:

Mysql主从同步的原理 

Myql主从同步实战 

基于此,我们再实现简单的PHP+Mysql读写分离,从而提高数据库的负载能力。

2、代码实战

<?php
class Db
{
  private $res;
  function __construct($sql)
  {
    $querystr = strtolower(trim(substr($sql,0,6)));
    //如果是select,就连接slave服务器
    if($querystr == 'select')
    {
      $res=$this->slave_select($sql);
      $this->res=$res;
    }
    //如果不是select,就连接master服务器
    else
    {
      $res=$this->master_change($sql);
      $this->res=$res;
    }
  }

  /**
   * slave从库返回sql查询结果
   * @param $sql
   * @return array
   */
  private function slave_select($sql){
    //该处只是随机获取slave节点的ip,当然,还可以采用其他算法获取slave_ip
    $slave_server=$this->get_slave_ip();
    $dsn="mysql:host=$slave_server;dbname=test";
    $user='root';
    $pass='123456';
    $dbh=new PDO($dsn, $user, $pass);
    return $dbh->query($sql)->fetchAll(PDO::FETCH_ASSOC);
  }

  /**master主库返回sql执行结果
   * @param $sql
   * @return int
   */
  private function master_change($sql){
    $master_server='192.168.33.22';
    $dsn="mysql:host=$master_server;dbname=test";
    $user='root';
    $pass='123456';
    $dbh=new PDO($dsn, $user, $pass);
    return $dbh->exec($sql);
  }

  /**
   * 随机获取slave-ip
   * @return mixed
   */
  private function get_slave_ip(){
    $slave_ips=['192.168.33.33','192.168.33.44'];
    $count=count($slave_ips)-1;
    $random_key=mt_rand(0,$count);
    return $slave_ips[$random_key];
  }

  /**       
   * 获取结果
   * @return int
   */
  public function get_res(){
    return $this->res;
  }
}

$sql1 = "select * from t1";
$sql2 = "insert into t1 (name) values ('haha')";
$sql3 = "delete from t1 where id=1";
$sql4 = "update t1 set name='Jerry' where id=2";

$db = new Db($sql1);
//$db = new Db($sql2);
//$db = new Db($sql3);
//$db = new Db($sql4);

var_dump($db->get_res());

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# PHP  # mysql  # 读写分离  # php实现mysql读写分离  # Springboot + Mysql8实现读写分离功能  # springboot基于Mybatis mysql实现读写分离  # 基于mysql+mycat搭建稳定高可用集群负载均衡主备复制读写分离操作  # PHP实现的mysql读写分离操作示例  # mysql主从复制读写分离的配置方法详解  # 利用mycat实现mysql数据库读写分离的示例  # Mysql读写分离过期常用解决方案  # 还可以  # 如果不是  # 查询结果  # 写过  # 大家多多  # gt  # slave  # dsn  # slave_select  # trim  # strtolower  # select  # substr  # master  # ip  # array  # slave_ip  # slave_server  # get_slave_ip  # master_change 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Laravel如何使用Telescope进行调试?(安装和使用教程)  nginx修改上传文件大小限制的方法  网站制作大概多少钱一个,做一个平台网站大概多少钱?  标题:Vue + Vuex 项目中正确使用 JWT 进行身份认证的实践指南  香港服务器租用费用高吗?如何避免常见误区?  什么是JavaScript解构赋值_解构赋值有哪些实用技巧  如何彻底删除建站之星生成的Banner?  黑客如何通过漏洞一步步攻陷网站服务器?  香港服务器网站推广:SEO优化与外贸独立站搭建策略  Laravel怎么实现验证码功能_Laravel集成验证码库防止机器人注册  如何在IIS中配置站点IP、端口及主机头?  如何确认建站备案号应放置的具体位置?  iOS验证手机号的正则表达式  如何快速重置建站主机并恢复默认配置?  Laravel如何使用Facades(门面)及其工作原理_Laravel门面模式与底层机制  网页设计与网站制作内容,怎样注册网站?  edge浏览器无法安装扩展 edge浏览器插件安装失败【解决方法】  如何在IIS服务器上快速部署高效网站?  Laravel如何使用Passport实现OAuth2?(完整配置步骤)  如何制作一个表白网站视频,关于勇敢表白的小标题?  Android Socket接口实现即时通讯实例代码  如何在VPS电脑上快速搭建网站?  再谈Python中的字符串与字符编码(推荐)  香港服务器如何优化才能显著提升网站加载速度?  Laravel如何使用Vite进行前端资源打包?(配置示例)  敲碗10年!Mac系列传将迎来「触控与联网」双革新  香港网站服务器数量如何影响SEO优化效果?  大连网站制作公司哪家好一点,大连买房网站哪个好?  Laravel如何实现本地化和多语言支持?(i18n教程)  Laravel模型关联查询教程_Laravel Eloquent一对多关联写法  如何在阿里云服务器自主搭建网站?  Laravel如何创建自定义Facades?(详细步骤)  制作旅游网站html,怎样注册旅游网站?  香港服务器网站搭建教程-电商部署、配置优化与安全稳定指南  长沙企业网站制作哪家好,长沙水业集团官方网站?  如何在HTML表单中获取用户输入并结合JavaScript动态控制复利计算循环  怎么制作网站设计模板图片,有电商商品详情页面的免费模板素材网站推荐吗?  php在windows下怎么调试_phpwindows环境调试操作说明【操作】  iOS正则表达式验证手机号、邮箱、身份证号等  php中::能调用final静态方法吗_final修饰静态方法调用规则【解答】  Laravel如何发送邮件和通知_Laravel邮件与通知系统发送步骤  Laravel全局作用域是什么_Laravel Eloquent Global Scopes应用指南  晋江文学城电脑版官网 晋江文学城网页版直接进入  长沙做网站要多少钱,长沙国安网络怎么样?  如何用AI一键生成爆款短视频文案?小红书AI文案写作指令【教程】  Laravel的HTTP客户端怎么用_Laravel HTTP Client发起API请求教程  Laravel Debugbar怎么安装_Laravel调试工具栏配置指南  Laravel如何使用Service Container和依赖注入?(代码示例)  使用Dockerfile构建java web环境  Laravel怎么实现搜索高亮功能_Laravel结合Scout与Algolia全文检索【实战】