mysql proxy 主從_【MYSQL知識必知必會】MySQL主從復制讀寫分離(基于mysql-proxy實現)...

MySQL主從復制讀寫分離(基于mysql-proxy實現)

http://mirror.bit.edu.cn/mysql/Downloads/MySQL-Proxy/mysql-proxy-0.8.4-linux-glibc2.3-x86-64bit.tar.gz

解壓

tar zxvf mysql-proxy-0.8.4-linux-glibc2.3-x86-64bit.tar.gz

創建mysql-proxy帳號并授權

分別在主從數據庫中創建mysqlproxy帳號

mysql> grant all on *.* to mysqlproxy@'192.168.64.%' identified by 'mysqlproxy';

mysql> flush privileges;

mysql> use mysql;

mysql> select User,Password,Host from user;

啟動mysql-proxy

sudo ./mysql-proxy \

--daemon \

--log-level=debug \

--keepalive \

--log-file=/var/log/mysql-proxy.log \

--plugins="proxy" \

--proxy-backend-addresses="192.168.64.131:3306" \

--proxy-read-only-backend-addresses="192.168.64.132:3306" \

--proxy-lua-script="/home/ubuntu/apps/mysql-proxy-0.8.4/share/doc/mysql-proxy/rw-splitting.lua" \

--plugins="admin" \

--admin-username="admin" \

--admin-password="admin" \

--admin-lua-script="/home/ubuntu/apps/mysql-proxy-0.8.4/lib/mysql-proxy/lua/admin.lua"

查看mysql-proxy進程

ubuntu@s4:~/apps/mysql-proxy-0.8.4/bin$ ps -ef | grep mysql-proxy

root 18249 1 0 02:22 ? 00:00:00 /home/ubuntu/apps/mysql-proxy-0.8.4/libexec/mysql-proxy --daemon --log-level=debug --keepalive --log-file=/var/log/mysql-proxy.log --plugins=proxy --proxy-backend-addresses=192.168.64.131:3306 --proxy-read-only-backend-addresses=192.168.64.132:3306 --proxy-lua-script=/home/ubuntu/apps/mysql-proxy-0.8.4/share/doc/mysql-proxy/rw-splitting.lua --plugins=admin --admin-username=admin --admin-password=admin --admin-lua-script=/home/ubuntu/apps/mysql-proxy-0.8.4/lib/mysql-proxy/lua/admin.lua

root 18250 18249 0 02:22 ? 00:00:00 /home/ubuntu/apps/mysql-proxy-0.8.4/libexec/mysql-proxy --daemon --log-level=debug --keepalive --log-file=/var/log/mysql-proxy.log --plugins=proxy --proxy-backend-addresses=192.168.64.131:3306 --proxy-read-only-backend-addresses=192.168.64.132:3306 --proxy-lua-script=/home/ubuntu/apps/mysql-proxy-0.8.4/share/doc/mysql-proxy/rw-splitting.lua --plugins=admin --admin-username=admin --admin-password=admin --admin-lua-script=/home/ubuntu/apps/mysql-proxy-0.8.4/lib/mysql-proxy/lua/admin.lua

ubuntu 18252 15744 0 02:22 pts/1 00:00:00 grep --color=auto mysql-proxy

查看mysql-proxy端口

ubuntu@s4:~/apps/mysql-proxy-0.8.4/bin$ sudo netstat -ntlp | grep mysql-proxy

tcp 0 0 0.0.0.0:4040 0.0.0.0:* LISTEN 18250/mysql-proxy

tcp 0 0 0.0.0.0:4041 0.0.0.0:* LISTEN 18250/mysql-proxy

4040是proxy端口,4041是admin端口

連接管理端口

mysql> mysql -uadmin -padmin -h192.168.64.131 -P4041 連接管理端口

具體如下

ubuntu@s4:~/apps/mysql-proxy-0.8.4/bin$ mysql -uadmin -padmin -h192.168.64.131 -P4041

Welcome to the MySQL monitor. Commands end with ; or \g.

Your MySQL connection id is 1

Server version: 5.0.99-agent-admin

Copyright (c) 2000, 2015, Oracle and/or its affiliates. All rights reserved.

Oracle is a registered trademark of Oracle Corporation and/or its

affiliates. Other names may be trademarks of their respective

owners.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

mysql> show databases;

ERROR 1105 (07000): use 'SELECT * FROM help' to see the supported commands

mysql> SELECT * FROM help;

+------------------------+------------------------------------+

| command | description |

+------------------------+------------------------------------+

| SELECT * FROM help | shows this help |

| SELECT * FROM backends | lists the backends and their state |

+------------------------+------------------------------------+

2 rows in set (0.00 sec)

mysql> SELECT * FROM backends;

+-------------+---------------------+---------+------+------+-------------------+

| backend_ndx | address | state | type | uuid | connected_clients |

+-------------+---------------------+---------+------+------+-------------------+

| 1 | 192.168.64.131:3306 | up | rw | NULL | 0 |

| 2 | 192.168.64.132:3306 | unknown | ro | NULL | 0 |

+-------------+---------------------+---------+------+------+-------------------+

2 rows in set (0.00 sec)

多開幾個客戶端后其狀態變為

mysql> SELECT * FROM backends;

+-------------+---------------------+-------+------+------+-------------------+

| backend_ndx | address | state | type | uuid | connected_clients |

+-------------+---------------------+-------+------+------+-------------------+

| 1 | 192.168.64.131:3306 | up | rw | NULL | 0 |

| 2 | 192.168.64.132:3306 | up | ro | NULL | 0 |

+-------------+---------------------+-------+------+------+-------------------+

2 rows in set (0.00 sec)

state都為up表正常

連接同步端口

mysql> mysql -umysqlproxy -pmysqlproxy -h192.168.64.131 -P4040

多開啟幾個同步端口,在同步端口連接的客戶端中插入和查詢數據,觀察讀寫分離。

結論:192.168.64.131:3306只寫,192.168.64.132:3306只讀。

操作演示

不使用proxy連接數據庫,查詢192.168.64.131:3306上的數據

mysql> select * from zhang;

+------+-------+----------------+

| id | name | address |

+------+-------+----------------+

| 1 | zhang | this_is_master |

| 1 | zhang | this_is_master |

| 1 | zhang | this_is_master |

| 1 | zhang | this_is_master |

| 1 | zhang | this_is_master |

| 1 | zhang | this_is_master |

| 1 | zhang | this_is_master |

| 1 | zhang | this_is_master |

| 1 | zhang | this_is_master |

| 1 | zhang | this_is_master |

| 1 | zhang | this_is_master |

| 2 | zhang | this_is_master |

| 3 | zhang | this_is_master |

| 4 | zhang | this_is_master |

| 5 | zhang | this_is_master |

| 6 | zhang | this_is_master |

| 7 | zhang | this_is_master |

+------+-------+----------------+

17 rows in set (0.00 sec)

不使用proxy連接數據庫,查詢192.168.64.132:3306上的數據

mysql> select * from zhang;

+------+-------+---------------+

| id | name | address |

+------+-------+---------------+

| 2 | zhang | this_is_slave |

+------+-------+---------------+

1 row in set (0.00 sec)

使用proxy連接數據庫,執行查詢和插入操作

ubuntu@s4:~/apps$ mysql -umysqlproxy -pmysqlproxy -h192.168.64.131 -P4040

Welcome to the MySQL monitor. Commands end with ; or \g.

server default db: crm

client default db:

syncronizing

Your MySQL connection id is 45

Server version: 5.5.47-0ubuntu0.12.04.1-log (Ubuntu)

Copyright (c) 2000, 2015, Oracle and/or its affiliates. All rights reserved.

Oracle is a registered trademark of Oracle Corporation and/or its

affiliates. Other names may be trademarks of their respective

owners.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

mysql> use crm;

Reading table information for completion of table and column names

You can turn off this feature to get a quicker startup with -A

Database changed

mysql> select * from zhang;

+------+-------+---------------+

| id | name | address |

+------+-------+---------------+

| 2 | zhang | this_is_slave |

+------+-------+---------------+

1 row in set (0.00 sec)

# 此處數據為192.168.64.132:3306中的數據

mysql> insert into zhang values('8','zhang','this_is_master');

Query OK, 1 row affected (0.00 sec)

# 該數據將插入192.168.64.131:3306數據庫中

mysql> select * from zhang;

server default db:

client default db: crm

syncronizing

+------+-------+---------------+

| id | name | address |

+------+-------+---------------+

| 2 | zhang | this_is_slave |

+------+-------+---------------+

1 row in set (0.00 sec)

# 該數據仍來自192.168.64.132:3306中數據

不使用proxy連接192.168.64.131:3306觀察數據是否插入

mysql> select * from zhang;

+------+-------+----------------+

| id | name | address |

+------+-------+----------------+

| 1 | zhang | this_is_master |

| 1 | zhang | this_is_master |

| 1 | zhang | this_is_master |

| 1 | zhang | this_is_master |

| 1 | zhang | this_is_master |

| 1 | zhang | this_is_master |

| 1 | zhang | this_is_master |

| 1 | zhang | this_is_master |

| 1 | zhang | this_is_master |

| 1 | zhang | this_is_master |

| 1 | zhang | this_is_master |

| 2 | zhang | this_is_master |

| 3 | zhang | this_is_master |

| 4 | zhang | this_is_master |

| 5 | zhang | this_is_master |

| 6 | zhang | this_is_master |

| 7 | zhang | this_is_master |

| 8 | zhang | this_is_master |

+------+-------+----------------+

18 rows in set (0.00 sec)

由此可見使用mysql-proxy讀寫分離成功。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/539673.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/539673.shtml
英文地址,請注明出處:http://en.pswp.cn/news/539673.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

SecureCRT防止自動斷開

今天在寧波連接上海的linux庫,是外網訪問內網,使用了nat123這個軟件映射的。 發現SecureCRT連接后,過幾分鐘就自動斷開,導致使用SecureCRT做跳轉機的其他應用使用起來很不方便。 于是設置了下SecureCRT。

mysql 主主結構_高性能mysql主主架構

(3)配置參數說明server-id:ID值唯一的標識了復制群集中的主從服務器,因此它們必須各不相同。master_id必須為1到232–1之間的一個正整數值,slave_id值必須為2到232–1之間的一個正整數值。log-bin:表示打開binlog,打開該選項才可以…

解決ios編譯swift報錯pcm was built: mtime changed

問題 編譯ios工程失敗時,其中的幾個swift文件報以下錯 /Users/tomes/code/project/xxx.swift File /Users/tomes/Library/Developer/Xcode/DerivedData/Spec-dgyhrnmgvfkjkqbboklnfgrudqip/Build/Products/Debug-iphoneos/xxxx.framework/Headers/xxxx.h has been…

AI工程師職業規劃和學習路線完整版

AI工程師職業規劃和學習路線完整版 如何成為一名機器學習算法工程師 成為一名合格的開發工程師不是一件簡單的事情,需要掌握從開發到調試到優化等一系列能 力,這些能力中的每一項掌握起來都需要足夠的努力和經驗。而要成為一名合格的機器學習算法工程師&…

oracle 多個with as

主要看多個with的格式 [sql] view plaincopy WITH T3 AS ( SELECT T1.ID, T1.CODE1, T2.DESCRIPTION FROM TB_DATA T1, TB_CODE T2 WHERE T1.CODE1 T2.CODE ), T4 AS ( SELECT T1.ID, T1.CODE2, T2.DESCRIPTION FROM TB_DATA T1, TB_CODE T2 WHERE T1.C…

mysql主鍵 命中率_mysql主鍵問題

MySQL主鍵一. MySQL主鍵設計原則MySQL主鍵應當是對用戶沒有意義的。MySQL主鍵應該是單列的,以便提高連接和篩選操作的效率(當然復合主鍵是可以的,只是不建議)永遠也不要更新MySQL主鍵MySQL主鍵不應包含動態變化的數據,如時間戳、創建時間列、…

Centos7常用命令[掛載文件系統]

Centos7常用命令[掛載文件系統]------------------------------------------------------------------------------# 掛載一個叫做hda2的盤-確定目錄/mnt/hda2已經存在[rootlocalhost ~]# mount /dev/hda2 /mnt/hda2# 卸載一個叫做hda2的盤-先從掛載點/mnt/hda2退出[rootlocalh…

hadoop SecondNamenode

一、定義 * The Secondary Namenode is a helper to the primary Namenode. * The Secondary is responsible for supporting periodic checkpoints * of the HDFS metadata. The current design allows only one Secondary * Namenode per HDFs cluster. * The Secondary Nam…

Tensorflow Python API 翻譯(sparse_ops)

作者:chen_h 微信號 & QQ:862251340 微信公眾號:coderpai 我的博客:請點擊這里計劃現將 tensorflow 中的 Python API 做一個學習,這樣方便以后的學習。 原文鏈接該章介紹有關稀疏張量的API稀疏張量表示對于多維稀疏…

高性能mysql 小查詢_高性能MySql進化論(十一):常見查詢語句的優化

總結一下常見查詢語句的優化方式1 COUNT1. COUNT的作用 COUNT(table.filed)統計的該字段非空值的記錄行數 COUNT(*)或者是COUNT(not nullable field) 統計的是全表的行數如果要是統計全表記錄數,COUNT(*)效率會比COUNT(not nullable fie…

ORA-01861: 文字與格式字符串不匹配

select to_date(20160401000000,yyyy-mm-dd) from dual; ---------- 報錯:ORA-01861: 文字與格式字符串不匹配 原因:字符串20160401000000與要轉換的格式 yyyy-mm-dd 格式不對。 20160401000000 是 yyyymmddhh24miss 格式的 -------- select to_da…

首席架構師徐海峰眼中的架構和出色的架構師

CSDN架構領域編輯采訪了一些與會講師,談談他們將在會上分享的內容、相關技術和程序人生,帶你領略講師風采。 本期我們采訪的講師是來自閱文集團首席架構師徐海峰,主要負責內容中心的網站架構和分布式存儲、分布式計算工作。10年互聯網開發經驗…

java socket建立長連接_Java Web項目中使用Socket通信多線程、長連接的方法

很多時候在javaweb項目中我們需要用到Socket通信來實現功能,在web中使用Socket我們需要建立一個監聽程序,在程序啟動時,啟動socket監聽。我們的應用場景是在java項目中,需要外接如一個硬件設備,通過tcp通信&#xff0c…

hadoop-eclipse-plugin使用

下載hadoop安裝包:http://www.carfab.com/apachesoftware/hadoop/common/hadoop-1.0.2/ 但是沒有plugin,我到這個地方下載的:http://ishare.iask.sina.com.cn/f/23642243.html?fromlikecopy到你的eclipse_home的plugins下面。配置map/reduce…

hadoop eclipse plugin windows下載集合

收集了hadoop穩定版本的eclipse plugin for windows。資源分一律為0分 hadoop-eclipse-plugin-1.2.1.jar http://download.csdn.net/detail/zengmingen/9488180 hadoop-eclipse-plugin-2.2.0.jar http://download.csdn.net/detail/zengmingen/9488182 hadoop-eclipse-pl…

java 記事本界面_JAVA/GUI程序之記事本

自上半年JAVA課程結束后,再也沒有看過JAVA了,最近不是很忙,又簡單的看了看,本博客純屬記錄學習過程,請大神們別笑,其中錯誤是難免的,畢竟是新手寫的博客。下面就進入我們的正題吧,復…

104. Maximum Depth of Binary Tree

104. Maximum Depth of Binary Tree 題目 Given a binary tree, find its maximum depth.The maximum depth is the number of nodes along the longest path from the root node down to the farthest leaf node. 解析 // Maximum Depth of Binary Tree class Solution { publ…

mapper-reducer word count 實例

統計一個文件里各單詞的個數,假設這個文件很大。 原理如下圖: 編寫代碼: WCMapper.java package zengmg.hadoop.mr.wordcount;import java.io.IOException;import org.apache.hadoop.io.LongWritable; import org.apache.hadoop.io.Text; …

java 遠程調用url_使用Java的URL/HttpURLConnection進行遠程調用(POST請求)

利用Java的HttpURLConnection進行遠程url請求(調用遠程接口)測試類:請求類型為json,以post方式請求,利用OutputStream寫入數據實體類:public class User implementsSerializable {privateString name;privateString password;publicString ge…

LindDotNetCore~職責鏈模式的應用

回到目錄 職責鏈模式 它是一種設計模塊,主要將操作流程與具體操作解耦,讓每個操作都可以設置自己的操作流程,這對于工作流應用是一個不錯的選擇! 下面是官方標準的定義:責任鏈模式是一種設計模式。在責任鏈模式里&…