使用PHP实现Mysql读写分离

  次阅读 作者:智能小宝 来源:互联网 2016-03-02 15:29 我要评论(0)

本代码是从uchome的代码修改的,是因为要解决uchome的效率而处理的。这个思维其实很久就有了,只是一直没有去做,相信也有人有同样的想法,如果有类似的,那真的希望提出相关的建议。

封装的方式比较简单,增加了只读数据库连接的接口扩展,不使用只读数据库也不影响原代码使用。有待以后不断完善。。

为了方便,试试建立了google的一个项目:http://code.google.com/p/mysql-rw-php/希望给有需要的朋友带来帮助。

PHP实现的Mysql读写分离主要特性:1.简单的读写分离

2.一个主数据库,可以添加更多的只读数据库

3.读写分离但不用担心某些特性不支持

4.缺点:同时连接两个数据库 英文比较烂,也写几个字吧

php code for mysql read/write split

feature:

simply rw split

one master,can add more slaves

support all mysql feature

link to the master and slave at the same time PHP代码:mysql_rw_php.class.php

复制代码 代码如下:

<?php

/****************************************

*** mysql-rw-php version 0.1

*** code by hqlulu#gmail.com

*** http://www.aslibra.com

*** http://code.google.com/p/mysql-rw-php/

*** code modify from class_mysql.php (uchome)

****************************************/

class mysql_rw_php {

//查询个数

var $querynum = 0;

//当前操作的数据库连接

var $link = null;

//字符集

var $charset;

//当前数据库

var $cur_db = '';

//是否存在有效的只读数据库连接

var $ro_exist = false;

//只读数据库连接

var $link_ro = null;

//读写数据库连接

var $link_rw = null;

function mysql_rw_php(){

}

function connect($dbhost, $dbuser, $dbpw, $dbname = '', $pconnect = 0, $halt = TRUE) {

if($pconnect) {

if(!$this->link = @mysql_pconnect($dbhost, $dbuser, $dbpw)) {

$halt && $this->halt('Can not connect to MySQL server');

}

} else {

if(!$this->link = @mysql_connect($dbhost, $dbuser, $dbpw)) {

$halt && $this->halt('Can not connect to MySQL server');

}

}

//只读连接失败

if(!$this->link && !$halt) return false;

//未初始化rw时,第一个连接作为rw

if($this->link_rw == null)

$this->link_rw = $this->link;

if($this->version() > '4.1') {

本站文章信息来源于网络以及网友投稿,本站只负责对文章进行整理、排版、编辑,是出于传递更多信息之目的,并不意味着赞同其观点或证实其内容的真实性。如果您有什么意见或建议,请联系QQ28-1688-302!

人工智能实验室
相关文章相关文章
  • 英国研发“杀生”机器人 通过生命体获取能量

    英国研发“杀生”机器人 通过生命体获取能量

  • 韩春雨称已能重复实验结果 近期将有消息公布

    韩春雨称已能重复实验结果 近期将有消息公布

  • 无人驾驶汽车如何改变城市生活?听听他们怎么说

    无人驾驶汽车如何改变城市生活?听听他们怎么说

  • 未来两年人工智能要怎么走?看这篇就够了

    未来两年人工智能要怎么走?看这篇就够了

网友点评网友点评
阅读推荐阅读推荐

据国外媒体报道,在过去两年内,聊天机器人(chatbot)、人工智能以及机器学习的研发和采用取得了巨大进展。许多初创公司正利用人工智能和...

霍金 视觉中国 图 英国著名物理学家霍金(Stephen Hawking)再次就人工智能(AI)发声,他认为:对于人类来说,强大AI的出现可能是最美妙的...

文|郑娟娟 今年,人工智能(AI) 60岁了。在AI60岁的时候,笔者想要介绍一下AI100,一个刚刚2岁的研究项目,但它的预设寿命是100年,甚至更长...

AlphaGo与李世石的人机大战,为大众迅速普及了人工智能的概念。 但对谷歌而言,除了下围棋,现在的人工智能进展到哪一步了?未来,人工智能...