linux下安装mysql-proxy 配置读写分离

[b]一、软件列表[/b]

[b]ncurses-5.7.tar.gz[/b]
wget http://ftp.gnu.org/pub/gnu/ncurses/ncurses-5.7.tar.gz
[b]mysql-proxy-0.8.1-linux-rhel5-x86-64bit.tar.gz[/b]
wget http://mirrors.dotsrc.org/mysql/Downloads/MySQL-Proxy/mysql-proxy-0.8.1-linux-rhel5-x86-64bit.tar.gz
[b]gettext-0.18.1.1.tar.gz[/b]
wget http://ftp.gnu.org/pub/gnu/gettext/gettext-0.18.1.1.tar.gz
[b]glib-2.26.1.tar.gz[/b]
wget http://ftp.acc.umu.se/pub/GNOME/sources/glib/2.26/glib-2.26.1.tar.gz
[b]pkg-config-0.25.tar.gz[/b]
wget http://pkg-config.freedesktop.org/releases/pkg-config-0.25.tar.gz
[b]lua-5.1.4.tar.gz[/b]
wget http://www.lua.org/ftp/lua-5.1.4.tar.gz
[b]libevent-1.4.13-stable.tar.gz[/b]
wget http://www.monkey.org/~provos/libevent-1.4.13-stable.tar.gz

[b]二、运行环境[/b]

192.168.111.101 mysql
192.168.111.102 mysql
192.168.111.103 mysql-proxy

[b]三、安装过程[/b]
注意:如果安装过程中因为gcc导致不能安装时,使用yum install gcc*或者yum update


1、 安装ncurses
./configure --prefix=/usr --with-shared &&
make &&
make install &&
chmod 755 /usr/lib/*.5.3 &&
mv /usr/lib/libncurses.so.5* /lib &&
ln -sf libncurses.a /usr/lib/libcurses.a &&
ln -sf ../../lib/libncurses.so.5 /usr/lib/libncurses.so &&
ln -sf ../../lib/libncurses.so.5 /usr/lib/libcurses.so

--with-shared: 使能建立共享的ncurses库文件。
chmod 755 /usr/lib/*.5.3: 共享库文件应该是可执行的。Ncurses 的安装程序没有正确设置文件权限,所以我们手动来设置好。
ln -sf libncurses.a libcurses.a: 有的程序会试图用 -lcurses 而不是 -lncurses 来链接。这个符号链接使这种程序能正确链接。
2.安装pkg-config

tar zxvf pkg-config-0.25.tar.gz
cd pkg-config-0.25
./configure
make && make install

vi /etc/profile
export PKG_CONFIG_PATH=$PKG_CONFIG_PATH:/usr/lib/pkgconfig

3.安装gettext

tar zxvf gettext-0.18.1.1.tar.gz
cd gettext-0.18.1.1
./configure
make && make install

4.安装libevent

tar zvfx libevent-1.4.13-stable.tar.gz
cd libevent-1.4.13-stable
./configure
make && make install

5.安装glib
tar zxvf glib-2.26.1.tar.gz
cd glib-2.26.1
./configure
make && make install
6.安装lua

tar zxvf lua-5.1.4.tar.gz
cd lua-5.1.4
如果是64位
vi src/Makefile
CFLAGS= -O2 -Wall $(MYCFLAGS) 改CFLAGS= -O2 -fPIC -Wall $(MYCFLAGS)
make linux

#在包含自 lua.h:16 的文件中,
#从 lua.c:15:
#luaconf.h:275:31: 错误:readline/readline.h:没有那个文件或目录
#luaconf.h:276:30: 错误:readline/history.h:没有那个文件或目录
#lua.c: In function ‘pushline’:
#lua.c:182: 警告:隐式声明函数 ‘readline’
#lua.c:182: 警告:赋值时将整数赋给指针,未作类型转换
#lua.c: In function ‘loadline’:
#lua.c:210: 警告:隐式声明函数 ‘add_history’
#make[2]: *** [lua.o] 错误 1
#make[2]: Leaving directory `/data0/software/lua-5.1.4/src’
#make[1]: *** [linux] 错误 2
#make[1]: Leaving directory `/data0/software/lua-5.1.4/src’
#make: *** [linux] 错误 2

yum install libtermcap-devel ncurses-devel libevent-devel readline-devel
make install
cp etc/lua.pc /usr/local/lib/pkgconfig/lua5.1.pc


7.安装MYSQL-Proxy

tar zxvf mysql-proxy-0.8.1-linux-rhel5-x86-64bit.tar.gz –C /usr/local/
cd /usr/local
mv mysql-proxy-0.8.1-linux-rhel5-x86-64bit mysql-proxy-0.8.1

vi /etc/profile
export PATH=$PATH:/usr/local/mysql-proxy-0.8.1/bin/

#查看版本
mysql-proxy -V

vi /etc/init.d/mysql-proxy
在/etc/init.d/目录下创建mysql-proxy

#!/bin/bash
export LUA_PATH=/usr/local/mysql-proxy-0.8.1/share/doc/mysql-proxy/?.lua
mode=$1
if [ -z "$mode" ] ; then
mode="start"
fi
case $mode in
start)
mysql-proxy --daemon \
--admin-username='root' \
--admin-password='123456' \
--admin-lua-script=/usr/local/mysql-proxy-0.8.1/share/doc/mysql-proxy/rw-splitting.lua \
--proxy-read-only-backend-addresses=192.168.111.101:3306 \
--proxy-backend-addresses=192.168.111.102:3306 \
--proxy-lua-script=/usr/local/mysql-proxy-0.8.1/share/doc/mysql-proxy/rw-splitting.lua &
;;
stop)
killall -9 mysql-proxy
;;
restart)
if $0 stop ; then
$0 start #不知道为何不生效
else
echo "retart failed!!!"
exit 1
fi
;;
esac
exit 0


运行、关闭
chmod 755 /etc/init.d/mysql-proxy
/etc/init.d/mysql-proxy start
/etc/init.d/mysql-proxy stop

测试
lsof –i:4040
mysql-proxy 默认端口为4040 4041

配置

vim /usr/local/mysql-proxy-0.8.1/share/doc/mysql-proxy/rw-splitting.lua

a. 修改如下部分代码段:

proxy.global.config.rwsplit = {

#这样可以进行快速测试,因为mysql-proxy要连接数达到下限时才读写分离
min_idle_connections = 1, #默认是4
max_idle_connections = 1, #默认是8

#打开这个选项,可以在控制台得到很多提示,让我们清除的看到访问的哪个数据库
is_debug = true
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值