zoukankan      html  css  js  c++  java
  • ThinkPHP实现读写分离

    基于thinkphp3.2.3,官方手册:http://www.kancloud.cn/manual/thinkphp/1733

    注意事项:

    1、首先得配置好MySQL主从,可以多主多从

    2、在读写分离的情况下,默认第一个数据库配置是主服务器的配置信息,负责写入数据,如果设置了DB_MASTER_NUM参数,则可以支持多个主服务器写入。其它的都是从数据库的配置信息,负责读取数据,数量不限制。每次连接从服务器并且进行读取操作的时候,系统会随机进行在从服务器中选择
    3、调用模型的CURD操作的话,系统会自动判断当前执行的方法的读操作还是写操作,如果你用的是原生SQL,那么需要注意系统的默认规则: 写操作必须用模型的execute方法,读操作必须用模型的query方法,否则会发生主从读写错乱的情况

    config.php

    <?php  
    return array(  
        //'配置项'=>'配置值'  
        'DB_DEPLOY_TYPE'=> 1, // 设置分布式数据库支持  
        'DB_TYPE'       => 'mysql', //分布式数据库类型必须相同  
        'DB_HOST'       => '192.168.20.195,192.168.20.201',  
        'DB_NAME'       => 'hadoop', //如果相同可以不用定义多个  
        'DB_USER'       => 'open,open',  
        'DB_PWD'        => '123456,123456',  
        'DB_PORT'       => '3306',  
        'DB_PREFIX'     => '',  
    );  

    读写分离测试

    <?php  
    namespace HomeController;  
    use ThinkController;  
    class IndexController extends Controller {  
        //查询 从库  
        public function index(){  
            $obj=M("user");  
            $data=$obj->select();  
            print_r($data);exit;  
        }  
          
        //写入 主库  
        public function add() {  
            $obj=M("user");  
            $data["name"]="测试名字";  
            if ($obj->add($data)) {  
                //$this->success("数据添加成功") ;  
            }else {  
                //$this->error("数据添加失败");  
            }  
        }  
    }  
    1. <?php  
    2. return array(  
    3.     //'配置项'=>'配置值'  
    4.     'DB_DEPLOY_TYPE'=> 1, // 设置分布式数据库支持  
    5.     'DB_TYPE'       => 'mysql'//分布式数据库类型必须相同  
    6.     'DB_HOST'       => '192.168.20.195,192.168.20.201',  
    7.     'DB_NAME'       => 'hadoop'//如果相同可以不用定义多个  
    8.     'DB_USER'       => 'open,open',  
    9.     'DB_PWD'        => '123456,123456',  
    10.     'DB_PORT'       => '3306',  
    11.     'DB_PREFIX'     => '',  
    12. );  
  • 相关阅读:
    Python日志采集(详细)
    Python+Appium自动化测试(15)-使用Android模拟器(详细)
    Python+Appium自动化测试(14)-yaml配置Desired capabilities
    Python基础笔记2-ruamel.yaml读写yaml文件
    LoaRunner性能测试系统学习教程:SQL Server等待类型
    LoaRunner性能测试系统学习教程:CPU瓶颈
    LoaRunner性能测试系统学习教程:SQL监控与调优
    LoaRunner性能测试系统学习教程:垃圾回收器(12)
    LoaRunner性能测试系统学习教程:垃圾收集算法(11)
    LoadRunner性能测试系统学习教程:GC回收机制(10)
  • 原文地址:https://www.cnblogs.com/sky-yu/p/6734492.html
Copyright © 2011-2022 走看看