搜索
首页后端开发php教程mysql Proxy读写分离配置与php mysql读写分离类

  1. mysql-proxy \
  2. –proxy-backend-addresses=narcissus:3306 \
  3. –proxy-backend-addresses=nostromo:3306
复制代码

3、数据库读写分离,192.168.18.110负责写入,192.168.18.107负责读取数据,当然也可以再增加读取数据的服务器。

  1. mysql-proxy \
  2. –proxy-backend-addresses=192.168.18.110:3306 \
  3. –proxy-read-only-backend-addresses=192.168.18.107:3306
复制代码

这种方式并不是读写分离。 mysql-proxy不能区分哪些是发往从服务器的,还需要自己用脚本控制,见第四种方式。

4、 Lua 脚本能很好的控制连接和分布, 以及查询及返回的结果集. 使用Lua脚本时,必须使用 –proxy-lua-script 指定脚本的名称。 直到产生连接时才会读取脚本,也就是修改脚本后不用重新启动服务。 mysql-proxy –proxy-lua-script=rw-splitting.lua –proxy-backend-addresses=192.168.18.110:3306 –proxy-read-only-backend-addresses=192.168.18.107:3306

注意问题: 1、proxy的读写分离机制是先把最初的几条查询发到master上建立连接, 当发送到master上的查询数超过连接池的最小值时开始把查询

2、LAST_INSERT_ID不能发送到主服务器上, 226 行修改为下面的就可以了 elseif not is_insert_id and token.token_name == “TK_FUNCTION” then

3、使用默认的rw-splitting.lua时,会提示找不到proxy-command,我把mysql-proxy的路径设置为系统路径,然后在 share目录下运行就一切Ok了,在运行中输入cmd,然 后cd C:\tools\mysql-proxy\share。

4、字符乱码 通过proxy连上数据库之后,查到的字符串始终是乱码,即便手工执行了set names ‘utf8′也没有效果。 解决办法,mysql server必须设置

  1. class mysql_rw_php {
  2. //查询个数
  3. var $querynum = 0;
  4. //当前操作的数据库连接
  5. var $link = null;
  6. //字符集
  7. var $charset;
  8. //当前数据库
  9. var $cur_db = '';
  10. //是否存在有效的只读数据库连接
  11. var $ro_exist = false;
  12. //只读数据库连接
  13. var $link_ro = null;
  14. //读写数据库连接
  15. var $link_rw = null;
  16. function mysql_rw_php(){
  17. }
  18. function connect($dbhost, $dbuser, $dbpw, $dbname = '', $pconnect = 0, $halt = TRUE) {
  19. if($pconnect) {
  20. if(!$this->link = @mysql_pconnect($dbhost, $dbuser, $dbpw)) {
  21. $halt && $this->halt('Can not connect to MySQL server');
  22. }
  23. } else {
  24. if(!$this->link = @mysql_connect($dbhost, $dbuser, $dbpw)) {
  25. $halt && $this->halt('Can not connect to MySQL server');
  26. }
  27. }
  28. //只读连接失败
  29. if(!$this->link && !$halt) return false;
  30. //未初始化rw时,第一个连接作为rw
  31. if($this->link_rw == null)
  32. $this->link_rw = $this->link;
  33. if($this->version() > '4.1') {
  34. if($this->charset) {
  35. @mysql_query("SET character_set_connection=$this->charset, character_set_results=$this->charset, character_set_client=binary", $this->link);
  36. }
  37. if($this->version() > '5.0.1') {
  38. @mysql_query("SET sql_mode=''", $this->link);
  39. }
  40. }
  41. if($dbname) {
  42. $this->select_db($dbname);
  43. }
  44. }
  45. //连接一个只读的mysql数据库
  46. function connect_ro($dbhost, $dbuser, $dbpw, $dbname = '', $pconnect = 0){
  47. if($this->link_rw == null)
  48. $this->link_rw = $this->link;
  49. $this->link = null;
  50. //不产生halt错误
  51. $this->connect($dbhost, $dbuser, $dbpw, $dbname, $pconnect, false);
  52. if($this->link){
  53. //连接成功
  54. //echo "link ro sussess!
    ";
  55. $this->ro_exist = true;
  56. $this->link_ro = $this->link;
  57. if($this->cur_db){
  58. //如果已经选择过数据库则需要操作一次
  59. @mysql_select_db($this->cur_db, $this->link_ro);
  60. }
  61. }else{
  62. //连接失败
  63. //echo "link ro failed!
    ";
  64. $this->link = &$this->link_rw;
  65. }
  66. }
  67. //设置一系列只读数据库并且连接其中一个
  68. function set_ro_list($ro_list){
  69. if(is_array($ro_list)){
  70. //随机选择其中一个
  71. $link_ro = $ro_list[array_rand($ro_list)];
  72. $this->connect_ro($link_ro['dbhost'], $link_ro['dbuser'], $link_ro['dbpw']);
  73. }
  74. }
  75. function select_db($dbname) {
  76. //同时操作两个数据库连接
  77. $this->cur_db = $dbname;
  78. if($this->ro_exist){
  79. @mysql_select_db($dbname, $this->link_ro);
  80. }
  81. return @mysql_select_db($dbname, $this->link_rw);
  82. }
  83. function fetch_array($query, $result_type = MYSQL_ASSOC) {
  84. return mysql_fetch_array($query, $result_type);
  85. }
  86. function fetch_one_array($sql, $type = '') {
  87. $qr = $this->query($sql, $type);
  88. return $this->fetch_array($qr);
  89. }
  90. function query($sql, $type = '') {
  91. $this->link = &$this->link_rw;
  92. //判断是否select语句
  93. if($this->ro_exist && preg_match ("/^(\s*)select/i", $sql)){
  94. $this->link = &$this->link_ro;
  95. }
  96. $func = $type == 'UNBUFFERED' && @function_exists('mysql_unbuffered_query') ?
  97. 'mysql_unbuffered_query' : 'mysql_query';
  98. if(!($query = $func($sql, $this->link)) && $type != 'SILENT') {
  99. $this->halt('MySQL Query Error', $sql);
  100. }
  101. $this->querynum++;
  102. return $query;
  103. }
  104. function affected_rows() {
  105. return mysql_affected_rows($this->link);
  106. }
  107. function error() {
  108. return (($this->link) ? mysql_error($this->link) : mysql_error());
  109. }
  110. function errno() {
  111. return intval(($this->link) ? mysql_errno($this->link) : mysql_errno());
  112. }
  113. function result($query, $row) {
  114. $query = @mysql_result($query, $row);
  115. return $query;
  116. }
  117. function num_rows($query) {
  118. $query = mysql_num_rows($query);
  119. return $query;
  120. }
  121. function num_fields($query) {
  122. return mysql_num_fields($query);
  123. }
  124. function free_result($query) {
  125. return mysql_free_result($query);
  126. }
  127. function insert_id() {
  128. return ($id = mysql_insert_id($this->link)) >= 0 ? $id : $this->result($this->query("SELECT last_insert_id()"), 0);
  129. }
  130. function fetch_row($query) {
  131. $query = mysql_fetch_row($query);
  132. return $query;
  133. }
  134. function fetch_fields($query) {
  135. return mysql_fetch_field($query);
  136. }
  137. function version() {
  138. return mysql_get_server_info($this->link);
  139. }
  140. function close() {
  141. return mysql_close($this->link);
  142. }
  143. function halt($message = '', $sql = '') {
  144. $dberror = $this->error();
  145. $dberrno = $this->errno();
  146. echo "
  147. MySQL Error
  148. Message: $message
  149. SQL: $sql
  150. Error: $dberror
  151. Errno.: $dberrno
";
  • exit();
  • }
  • }
  • ?>
  • 复制代码

    调用示例:

    1. /****************************************
    2. *** mysql-rw-php version 0.1
    3. *** http://bbs.it-home.org
    4. *** http://code.google.com/p/mysql-rw-php/
    5. *** code modify from class_mysql.php (uchome)
    6. ****************************************/
    7. require_once('mysql_rw_php.class.php');
    8. //rw info
    9. $db_rw = array(
    10. 'dbhost'=>'bbs.it-home.org',
    11. 'dbuser'=>'jbxue',
    12. 'dbpw'=>'bbs.it-home.org',
    13. 'dbname'=>'test'
    14. );
    15. $db_ro = array(
    16. array(
    17. 'dbhost'=>'bbs.it-home.org:4306',
    18. 'dbuser'=>'jbxue',
    19. 'dbpw'=>'bbs.it-home.org'
    20. )
    21. );
    22. $DB = new mysql_rw_php;
    23. //connect Master
    24. $DB->connect($db_rw[dbhost], $db_rw[dbuser], $db_rw[dbpw], $db_rw[dbname]);
    25. //Method 1: connect one server
    26. $DB->connect_ro($db_ro[0][dbhost], $db_ro[0][dbuser], $db_ro[0][dbpw]);
    27. //Method 2: connect one server from a list by rand
    28. $DB->set_ro_list($db_ro);
    29. //send to rw
    30. $sql = "insert into a set a='test'";
    31. $DB->query($sql);
    32. //send to ro
    33. $sql = "select * from a";
    34. $qr = $DB->query($sql);
    35. while($row = $DB->fetch_array($qr)){
    36. echo $row[a];
    37. }
    38. ?>
    复制代码


    声明
    本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
    可以在PHP会话中存储哪些数据?可以在PHP会话中存储哪些数据?May 02, 2025 am 12:17 AM

    phpsessionscanStorestrings,数字,数组和原始物。

    您如何开始PHP会话?您如何开始PHP会话?May 02, 2025 am 12:16 AM

    tostartaphpsession,usesesses_start()attheScript'Sbeginning.1)placeitbeforeanyOutputtosetThesessionCookie.2)useSessionsforuserDatalikeloginstatusorshoppingcarts.3)regenerateSessiveIdStopreventFentfixationAttacks.s.4)考虑使用AttActAcks.s.s.4)

    什么是会话再生,如何提高安全性?什么是会话再生,如何提高安全性?May 02, 2025 am 12:15 AM

    会话再生是指在用户进行敏感操作时生成新会话ID并使旧ID失效,以防会话固定攻击。实现步骤包括:1.检测敏感操作,2.生成新会话ID,3.销毁旧会话ID,4.更新用户端会话信息。

    使用PHP会话时有哪些性能考虑?使用PHP会话时有哪些性能考虑?May 02, 2025 am 12:11 AM

    PHP会话对应用性能有显着影响。优化方法包括:1.使用数据库存储会话数据,提升响应速度;2.减少会话数据使用,只存储必要信息;3.采用非阻塞会话处理器,提高并发能力;4.调整会话过期时间,平衡用户体验和服务器负担;5.使用持久会话,减少数据读写次数。

    PHP会话与Cookie有何不同?PHP会话与Cookie有何不同?May 02, 2025 am 12:03 AM

    PHPsessionsareserver-side,whilecookiesareclient-side.1)Sessionsstoredataontheserver,aremoresecure,andhandlelargerdata.2)Cookiesstoredataontheclient,arelesssecure,andlimitedinsize.Usesessionsforsensitivedataandcookiesfornon-sensitive,client-sidedata.

    PHP如何识别用户的会话?PHP如何识别用户的会话?May 01, 2025 am 12:23 AM

    phpientifiesauser'ssessionusessessionSessionCookiesAndSessionIds.1)whiwSession_start()被称为,phpgeneratesainiquesesesessionIdStoredInacookInAcookInamedInAcienamedphpsessidontheuser'sbrowser'sbrowser.2)thisIdAllowSphptptpptpptpptpptortoreTessessionDataAfromtheserverMtheserver。

    确保PHP会议的一些最佳实践是什么?确保PHP会议的一些最佳实践是什么?May 01, 2025 am 12:22 AM

    PHP会话的安全可以通过以下措施实现:1.使用session_regenerate_id()在用户登录或重要操作时重新生成会话ID。2.通过HTTPS协议加密传输会话ID。3.使用session_save_path()指定安全目录存储会话数据,并正确设置权限。

    PHP会话文件默认存储在哪里?PHP会话文件默认存储在哪里?May 01, 2025 am 12:15 AM

    phpsessionFilesArestoredIntheDirectorySpecifiedBysession.save_path,通常是/tmponunix-likesystemsorc:\ windows \ windows \ temponwindows.tocustomizethis:tocustomizEthis:1)useession_save_save_save_path_path()

    See all articles

    热AI工具

    Undresser.AI Undress

    Undresser.AI Undress

    人工智能驱动的应用程序,用于创建逼真的裸体照片

    AI Clothes Remover

    AI Clothes Remover

    用于从照片中去除衣服的在线人工智能工具。

    Undress AI Tool

    Undress AI Tool

    免费脱衣服图片

    Clothoff.io

    Clothoff.io

    AI脱衣机

    Video Face Swap

    Video Face Swap

    使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

    热工具

    mPDF

    mPDF

    mPDF是一个PHP库,可以从UTF-8编码的HTML生成PDF文件。原作者Ian Back编写mPDF以从他的网站上“即时”输出PDF文件,并处理不同的语言。与原始脚本如HTML2FPDF相比,它的速度较慢,并且在使用Unicode字体时生成的文件较大,但支持CSS样式等,并进行了大量增强。支持几乎所有语言,包括RTL(阿拉伯语和希伯来语)和CJK(中日韩)。支持嵌套的块级元素(如P、DIV),

    安全考试浏览器

    安全考试浏览器

    Safe Exam Browser是一个安全的浏览器环境,用于安全地进行在线考试。该软件将任何计算机变成一个安全的工作站。它控制对任何实用工具的访问,并防止学生使用未经授权的资源。

    螳螂BT

    螳螂BT

    Mantis是一个易于部署的基于Web的缺陷跟踪工具,用于帮助产品缺陷跟踪。它需要PHP、MySQL和一个Web服务器。请查看我们的演示和托管服务。

    适用于 Eclipse 的 SAP NetWeaver 服务器适配器

    适用于 Eclipse 的 SAP NetWeaver 服务器适配器

    将Eclipse与SAP NetWeaver应用服务器集成。

    VSCode Windows 64位 下载

    VSCode Windows 64位 下载

    微软推出的免费、功能强大的一款IDE编辑器