我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Mysql数据库读写分离简单配置

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Mysql数据库读写分离简单配置

环境:

Master:192.168.71.128      mysql-sql-node1

Slave:192.168.71.140       mysql-data-node1

Mysql-Proxy:192.168.71.138 mysql-mgm-node

 

 

rpm -q libevent glib2 pkgconfig libtool mysql-devel 查看系统是否已安装以上包,如未安装,使用yum install 安装。

yum install -y libtermcap-devel ncurses-devel libevent-devel readline-devel gcc-c++

 

一、下载程序:

 

wget http://www.lua.org/ftp/lua-5.1.4.tar.gz

wget http://gd.tuwien.ac.at/db/mysql/Downloads/MySQL-Proxy/mysql-proxy-0.6.0.tar.gz

wget http://www.monkey.org/~provos/libevent-1.4.13-stable.tar.gz

 

二、安装lua

 

[root@mailtest /software]# tar zxvf lua-5.1.4.tar.gz

[root@mailtest lua-5.1.4]#  cd lua-5.1.4

[root@mailtest lua-5.1.4]# # vi Makefile

修改:

INSTALL_TOP= /usr/local/lua

 

[root@mailtest lua-5.1.4]#  make && make linux && make install

 

设置环境变量

[root@mailtest lua-5.1.4]# export LUA_CFLAGS="-I/usr/local/lua/include" LUA_LIBS="-L/usr/local/lua/lib -llua -ldl" LDFLAGS="-L/usr/local/libevent/lib -lm"

[root@mailtest lua-5.1.4]# export CPPFLAGS="-I/usr/local/libevent/include"

[root@mailtest lua-5.1.4]# export CFLAGS="-I/usr/local/libevent/include"

 

三、安装 libevent

 

tar zvxf libevent-1.4.13-stable.tar.gz

cd libevent-1.4.13-stable

./configure --prefix=/usr/local/libevent

make && make install

 

四、安装mysql-proxy

./configure --prefix=/usr/local/mysql-proxy --with-mysql=/usr/local/mysql --with-lua

make && make install

 

 

启动:

/usr/local/mysql-proxy/sbin/mysql-proxy --proxy-read-only-backend-addresses=192.168.71.140:3306 --proxy-backend-addresses=192.168.71.128:3306 --proxy-lua-

 

script=/usr/local/mysql-proxy/share/mysql-proxy/rw-splitting.lua &

 

查看进程:

netstat -ntlp | grep mysql

编辑启动脚本:

vi /etc/init.d/mysql-proxy

#!/bin/bash

PRODIR=/usr/local/mysql-proxy

LUA_PATH=$PRODIR/share/mysql-proxy

start(){

$PRODIR/sbin/mysql-proxy --proxy-read-only-backend-addresses=192.168.71.140:3306 --proxy-backend-addresses=192.168.71.128:3306 --proxy-lua-

 

script=/usr/local/mysql-proxy/share/mysql-proxy/rw-splitting.lua &

>>$PRODIR/mysql-proxy.log &

}

stop(){

kill $(pidof mysql-proxy)

if [ $? -ne 0 ];then

kill -9 $(pidof mysql-proxy)

fi

}

case "$1" in

start)

start

;;

stop)

stop

;;

restart)

stop

start

;;

*)

echo $"Usage: $0 {start|stop|restart}"

esac

 

 

 

修改权限:

chmod +x /etc/init.d/mysql-proxy

/etc/init.d/mysql-proxy start

 

测试:

在MySQL-Master 上创建测试数据库和用户。

mysql> create database unixhot;

mysql> GRANT ALL PRIVILEGES ON king.* to proxytest@'%' identified by 'bobo365';

连接测试

[root@MySQL-Proxy ~]# mysql -h 192.168.71.138 -P 4040 -u proxytest -p

输入密码即可登录。

 

 

mysql> show processlist;

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

| Id | User      | Host                 | db   | Command | Time | State | Info             |

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

| 14 | proxytest | 192.168.71.138:17350 | NULL | Sleep   |    2 |       | NULL             |

| 15 | proxytest | 192.168.71.138:17355 | NULL | Query   |    0 | NULL  | show processlist |

| 16 | proxytest | 192.168.71.138:17358 | NULL | Sleep   |    2 |       | NULL             |

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

3 rows in set (0.01 sec)


免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Mysql数据库读写分离简单配置

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

MySQL/MariaDB读写分离配置

实现数据库读写分离技术是有很多方法的,在这里我就用一个比较简单的mysql-proxy这个中间件来实现数据库的读写分离; 使用mysql-proxy实现mysql的读写分离,mysql-proxy实际上是作为后端mysql主从服务器的代理,它直接接受客户端的请
MySQL/MariaDB读写分离配置
2021-01-12

MySQL插入锁与数据库读写分离

MySQL插入锁是指在数据库中进行插入操作时会对相关数据行进行锁定,防止其他用户同时插入或修改该数据行。这可以确保数据的完整性和一致性,但也会影响数据库的并发性能。数据库读写分离是指将数据库的读操作和写操作分开到不同的数据库实例或服务器中
MySQL插入锁与数据库读写分离
2024-08-19

MySQL INSERT锁与数据库读写分离优化

在MySQL中,INSERT操作会涉及到行级锁和表级锁。当使用INSERT语句向某个表中插入数据时,会对表或者索引进行加锁,以确保数据的一致性和完整性。在插入大量数据时,可能会出现锁竞争和性能瓶颈的情况。为了优化数据库的性能,可以考虑使用
MySQL INSERT锁与数据库读写分离优化
2024-08-19

Spring+Mybatis 实现aop数据库读写分离与多数据库源配置操作

在数据库层面大都采用读写分离技术,就是一个Master数据库,多个Slave数据库。Master库负责数据更新和实时数据查询,Slave库当然负责非实时数据查询。因为在实际的应用中,数据库都是读多写少(读取数据的频率高,更新数据的频率相对较
2023-05-31

编程热搜

目录