MySQL主从同步和读写分离如何配置

63次阅读
没有评论

共计 10879 个字符,预计需要花费 28 分钟才能阅读完成。

这篇文章主要为大家展示了“MySQL 主从同步和读写分离如何配置”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让丸趣 TV 小编带领大家一起研究并学习一下“MySQL 主从同步和读写分离如何配置”这篇文章吧。

  现在使用的两台服务器已经安装了 MySQL, 全是 rpm 包装的,能正常使用。

  为了避免不必要的麻烦,主从服务器 MySQL 版本尽量保持一致;

环境:192.168.0.1(Master)

  192.168.0.2 (Slave)

MySQL Version:Ver 14.14 Distrib 5.1.48, for pc-linux-gnu (i686) using readline 5.1

1、登录 Master 服务器, 修改 my.cnf, 添加如下内容;

server-id = 1  // 数据库 ID 号,为 1 时表示为 Master, 其中 master_id 必须为 1 到 232 ndash;1 之间的一个正整数值;

log-bin=mysql-bin  // 启用二进制日志;

binlog-do-db=data // 需要同步的二进制数据库名;

binlog-ignore-db=mysql  // 不同步的二进制数据库名; 这个同步后听说很麻烦,我没有同步;

log-bin=/var/log/mysql/updatelog // 设定生成的 log 文件名;

log-slave-updates // 把更新的记录写到二进制文件中;

slave-skip-errors // 跳过错误,继续执行复制;

2、建立复制所要使用的用户;

mysql grant replication slave on *.* to test@192.168.0.2 identified by ********

3、重启 mysql;

/usr/bin/mysqladmin -uroot shutdown;

/usr/bin/mysql_safe

4、现在备份 Master 上的数据;

  锁定后我直接 tar.gz data 这个库文件;

mysql FLUSH TABLES WITH READ LOCK;

cd /var/lib/mysql

tar data.tar.gz data

接着直接执行了远程 scp;

scp ./data.tar.gz root@192.168.0.2:/var/lib/mysql

5、登录 Slave 数据库服务器,修改 my.cnf;

server-id  = 3  // 2 已经被用在另一个服务器上了,如果以后要再加 Slave 号接着往后数就 OK 了;

log-bin=mysql-bin

master-host  =  192.168.0.1

master-user  =  test

master-password =  ******

master-port  = 3306

master-connect-retry=60  // 如果发现主服务器断线,重新连接的时间差;

replicate-ignore-db=mysql // 不需要备份的数据库;

replicate-do-db=data // 需要备份的数据库

log-slave-update

slave-skip-errors

6、解压刚才从 Master scp 过来的文件,此处不用改权限、属主,默认没有改变,可以根据实际情况进行修改;

7、上述完成后,可以启动 slave 了;查看 slave 状态;

mysql slave start; www.2cto.com

mysql show slave status\G;

*************************** 1. row ***************************

  Slave_IO_State: Waiting for master to send event

  Master_Host: 192.168.0.1

  Master_User: test

  Master_Port: 3306

  Connect_Retry: 60

  Master_Log_File: updatelog.000001

  Read_Master_Log_Pos: 106

  Relay_Log_File: onlinevc-relay-bin.000013

  Relay_Log_Pos: 1069

  Relay_Master_Log_File: updatelog.000001

  Slave_IO_Running: Yes

  Slave_SQL_Running: Yes

  Replicate_Do_DB: data

  Replicate_Ignore_DB: mysql

  Replicate_Do_Table:

  Replicate_Ignore_Table:

  Replicate_Wild_Do_Table:

Replicate_Wild_Ignore_Table:

  Last_Errno: 0

  Last_Error:

  Skip_Counter: 0

  Exec_Master_Log_Pos: 106

  Relay_Log_Space: 1681

  Until_Condition: None

  Until_Log_File:

  Until_Log_Pos: 0

   Master_SSL_Allowed: No

  Master_SSL_CA_File:

  Master_SSL_CA_Path:

  Master_SSL_Cert:

  Master_SSL_Cipher:

  Master_SSL_Key:

  Seconds_Behind_Master: 0

Master_SSL_Verify_Server_Cert: No

   Last_IO_Errno: 0

  Last_IO_Error:

  Last_SQL_Errno: 0

  Last_SQL_Error:

1 row in set (0.00 sec)

ERROR:

No query specified

8、查看 Master 上面的状态;

mysql show master status;

+——————+———-+————–+——————+

| File  | Position | Binlog_Do_DB | Binlog_Ignore_DB |

+——————+———-+————–+——————+

| updatelog.000012 |  15016 | data  | mysql   |

+——————+———-+————–+——————+

1 row in set (0.00 sec)

由此可见两者的 File、Position 存在问题,所要要去 Slave 上设置对应主库的 Master_Log_File、Read_Master_Log_Pos;执行如下语句;

mysql slave stop;

mysql CHANGE MASTER TO MASTER_HOST= 192.168.0.1 ,MASTER_USER= test , MASTER_PASSWORD= ****** ,MASTER_LOG_FILE= updatelog.000012 ,MASTER_LOG_POS=15016;

确保 Slave_IO_Running: Yes、Slave_SQL_Running: Yes 都要为 YES 才能证明 Slave 的 I / O 和 SQL 进行正常。

9、解锁主库表;

UNLOCK TABLES;

到此主从 MySQL 服务器配置完成,测试结果如下;

mysql show master status;

+——————+———-+————–+——————+

| File  | Position | Binlog_Do_DB | Binlog_Ignore_DB |

+——————+———-+————–+——————+

| updatelog.000012 |  717039 | data | mysql  |

+——————+———-+————–+——————+

1 row in set (0.00 sec)

mysql show slave status\G;

*************************** 1. row ***************************

  Slave_IO_State: Waiting for master to send event

   Master_Host: 192.168.0.1

  Master_User: test

  Master_Port: 3306

  Connect_Retry: 60

  Master_Log_File: updatelog.000012

  Read_Master_Log_Pos: 717039

  Relay_Log_File: onlinevc-relay-bin.000013

  Relay_Log_Pos: 1222

  Relay_Master_Log_File: updatelog.000012

  Slave_IO_Running: Yes

  Slave_SQL_Running: Yes

  Replicate_Do_DB: data

   Replicate_Ignore_DB: mysql

  Replicate_Do_Table:

  Replicate_Ignore_Table:

  Replicate_Wild_Do_Table:

Replicate_Wild_Ignore_Table:

  Last_Errno: 0

  Last_Error:

  Skip_Counter: 0

   Exec_Master_Log_Pos: 717039

  Relay_Log_Space: 1834

  Until_Condition: None

  Until_Log_File:

  Until_Log_Pos: 0

  Master_SSL_Allowed: No

  Master_SSL_CA_File:

  Master_SSL_CA_Path:

  Master_SSL_Cert:

  Master_SSL_Cipher:

  Master_SSL_Key:

  Seconds_Behind_Master: 0

Master_SSL_Verify_Server_Cert: No

  Last_IO_Errno: 0

  Last_IO_Error:

  Last_SQL_Errno: 0

  Last_SQL_Error:

1 row in set (0.00 sec)

ERROR:

No query specified

####################################  如下是 MySQL 数据库读写分离操作步骤 ##########################################

此处使用 MySQL 自己(Mysql-proxy)的代理实现数据库的读写分离;

所需要安装包如下;

1、check-0.9.8

2、glib-2.18.4

3、libevent-2.0.6-rc

4、lua-5.1.4

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

5、pkg-config-0.23

6、mysql-5.0.56

7、mysql-proxy-0.8.0

  http://mysql.cdpa.nsysu.edu.tw/Downloads/MySQL-Proxy/mysql-proxy-0.8.0.tar.gz

别的安装包地址当时没有记地址,不过大部分都在这个网站上找的;http://sourceforge.net/

安装开始

1、tar -zxvf check-0.8.4.tar.gz

  cd check-0.8.4

  ./configure

  make

  make install

2、tar -zxvf glib-2.18.4.tar.gz  // 系统 rpm 包可能版本低出现了问题 3;

  ./configure

  make

  make install

3、tar -zxvf libevent-2.0.6-rc.tar.gz

  cd libevent-2.0.6-rc

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

  make make install

4、tar -zxvf lua-5.1.4.tar.gz

  INSTALL_TOP= /usr/local/lua  //  为了把 lua 安装到 /var/lib/lua 下,故要修改其下的 Makefile;

或者直接执行:sed -i s#INSTALL_TOP= /usr/local#INSTALL_TOP= /usr/local/lua# Makefile

root@testmysql [/software/lua-5.1.4]# make

Please do

  make PLATFORM

where PLATFORM is one of these:

  aix ansi bsd freebsd generic linux macosx mingw posix solaris

See INSTALL for complete instructions.

这处是要你选择服务器所使用的平台;

执行:make linux // 此处执行后出现了错误,解决办法在下面问题解决区 1 处,此处先跳过;

再执行:make install

设置环境变量:

  export LUA_CFLAGS= -I/usr/local/lua/include LUA_LIBS= -L/usr/local/lua/lib -llua -ldl LDFLAGS= -L/usr/local/libevent/lib -lm

  export CPPFLAGS= -I/usr/local/libevent/include

  export CFLAGS= -I/usr/local/libevent/include

5、tar -zxvf pkg-config-0.23.tar.gz

  cd pkg-config-0.23

  ./configure

  make

  make install

安装完之后要执行:cp etc/lua.pc /usr/local/lib/pkgconfig/lua5.1.pc  // 原因见下面的问题解决区 2 处;

6、安装 MySQL 客户端;

因为此服务器系统是默认安装了 MySQL, 没有安装客户端,我又装了 client、devel 如下所示已安装的 rpm 包;

  root@testmysql [/software/lua-5.1.4]# rpm -qa | grep MySQL

MySQL-client-5.1.48-0.glibc23

MySQL-bench-5.0.91-0.glibc23

MySQL-test-5.1.48-0.glibc23

MySQL-shared-5.1.48-0.glibc23

MySQL-server-5.1.48-0.glibc23

MySQL-devel-5.1.48-0.glibc23

此后的 Mysql-proxy 时总是一直报错,编译不过去,无奈之下用包客户端;(此时的 rpm 包都没有卸载,直接执行了下面的安装)// 此处问题见问题解决区 4 处;

  tar zxvf -5.0.56.tar.gz  // 此处我直接使用了 mysql 的 5.0.56 的源码包;

  cd mysql-5.0.56

  ./configure –prefix=/usr/local/mysql –without-server

  make make install

7、tar xvf mysql-proxy-0.8.0.tar.gz

  cd mysql-proxy-0.8.0

  ./configure –prefix=/usr/local/mysql-proxy –with-mysql=/usr/local/mysql –with-lua  // 问题解决处 4 有介绍;

  Make Make install

8、在 /var/lib/bin 创建 mysql-proxy.sh,内容如下;

  #!/bin/bash

  LUA_PATH= /usr/local/mysql-proxy/lib/mysql-proxy/lua/?.lua /usr/local/mysql-proxy/bin/mysql-proxy –proxy-backend-addresses=192.168.0.1:3306 –proxy-read-only-backend-addresses=192.168.0.2:3306 –proxy-lua-script=/usr/local/mysql-proxy/lib/mysql-proxy/rw-splitting.lua /var/log/mysql-proxy.log

  然后加上可执行权限;

  chmod a+x /var/lib/bin/mysql-proxy.sh

  执行:/var/lib/bin/mysql-proxy.sh 启动服务;

9、验证是否开户了:4040、4041;

  root@testmysql [/usr/local/bin]# netstat -an | grep 404*

  tcp  0  0 0.0.0.0:4040  0.0.0.0:*  LISTEN 

  tcp  0  0 0.0.0.0:4041   0.0.0.0:*  LISTEN 

10、测试读写分离,此步略过,所有配置已经完成。

  问题解决区  

1、在安装的第四步执行 make linux 时报错如下:

root@testmysql [/software/lua-5.1.4]# make linux

cd src make linux

make[1]: Entering directory `/software/lua-5.1.4/src

make all MYCFLAGS=-DLUA_USE_LINUX MYLIBS= -Wl,-E -ldl -lreadline -lhistory -lncurses

make[2]: Entering directory `/software/lua-5.1.4/src

gcc -O2 -Wall -DLUA_USE_LINUX  -c -o lapi.o lapi.c

gcc -O2 -Wall -DLUA_USE_LINUX  -c -o lcode.o lcode.c

gcc -O2 -Wall -DLUA_USE_LINUX  -c -o ldebug.o ldebug.c

gcc -O2 -Wall -DLUA_USE_LINUX  -c -o ldo.o ldo.c

gcc -O2 -Wall -DLUA_USE_LINUX  -c -o ldump.o ldump.c

gcc -O2 -Wall -DLUA_USE_LINUX  -c -o lfunc.o lfunc.c

gcc -O2 -Wall -DLUA_USE_LINUX  -c -o lgc.o lgc.c

gcc -O2 -Wall -DLUA_USE_LINUX  -c -o llex.o llex.c

gcc -O2 -Wall -DLUA_USE_LINUX  -c -o lmem.o lmem.c

gcc -O2 -Wall -DLUA_USE_LINUX  -c -o lobject.o lobject.c

gcc -O2 -Wall -DLUA_USE_LINUX  -c -o lopcodes.o lopcodes.c

gcc -O2 -Wall -DLUA_USE_LINUX  -c -o lparser.o lparser.c

gcc -O2 -Wall -DLUA_USE_LINUX  -c -o lstate.o lstate.c

gcc -O2 -Wall -DLUA_USE_LINUX  -c -o lstring.o lstring.c

gcc -O2 -Wall -DLUA_USE_LINUX  -c -o ltable.o ltable.c

gcc -O2 -Wall -DLUA_USE_LINUX  -c -o ltm.o ltm.c

gcc -O2 -Wall -DLUA_USE_LINUX  -c -o lundump.o lundump.c

gcc -O2 -Wall -DLUA_USE_LINUX  -c -o lvm.o lvm.c

gcc -O2 -Wall -DLUA_USE_LINUX  -c -o lzio.o lzio.c

gcc -O2 -Wall -DLUA_USE_LINUX  -c -o lauxlib.o lauxlib.c

gcc -O2 -Wall -DLUA_USE_LINUX  -c -o lbaselib.o lbaselib.c

gcc -O2 -Wall -DLUA_USE_LINUX  -c -o ldblib.o ldblib.c

gcc -O2 -Wall -DLUA_USE_LINUX  -c -o liolib.o liolib.c

gcc -O2 -Wall -DLUA_USE_LINUX  -c -o lmathlib.o lmathlib.c

gcc -O2 -Wall -DLUA_USE_LINUX  -c -o loslib.o loslib.c

gcc -O2 -Wall -DLUA_USE_LINUX  -c -o ltablib.o ltablib.c

gcc -O2 -Wall -DLUA_USE_LINUX  -c -o lstrlib.o lstrlib.c

gcc -O2 -Wall -DLUA_USE_LINUX  -c -o loadlib.o loadlib.c

gcc -O2 -Wall -DLUA_USE_LINUX  -c -o linit.o linit.c

ar rcu liblua.a lapi.o lcode.o ldebug.o ldo.o ldump.o lfunc.o lgc.o llex.o lmem.o lobject.o lopcodes.o lparser.o lstate.o lstring.o ltable.o ltm.o lundump.o lvm.o lzio.o lauxlib.o lbaselib.o ldblib.o liolib.o lmathlib.o loslib.o ltablib.o lstrlib.o loadlib.o linit.o

ranlib liblua.a

gcc -O2 -Wall -DLUA_USE_LINUX  -c -o lua.o lua.c

In file included from lua.h:16,

  from lua.c:15:

luaconf.h:275:31: error: readline/readline.h: No such file or directory

luaconf.h:276:30: error: readline/history.h: No such file or directory

lua.c: In function 鈥榩 ushline 鈥?

lua.c:182: warning: implicit declaration of function 鈥榬 eadline 鈥?

  lua.c:182: warning: assignment makes pointer from integer without a cast

lua.c: In function 鈥榣 oadline 鈥?

lua.c:210: warning: implicit declaration of function 鈥榓 dd_history 鈥?

  make[2]: *** [lua.o] Error 1

make[2]: Leaving directory `/software/lua-5.1.4/src

make[1]: *** [linux] Error 2

make[1]: Leaving directory `/software/lua-5.1.4/src

make: *** [linux] Error 2

解决方法:yum install libtermcap-devel

  yum install ncurses-devel 

  yum install libevent-devel 

  yum install readline-devel

2、安装 MySQL-proxy 时报错:

checking for LUA… configure: error: Package requirements (lua5.1 = 5.1) were not met:

No package lua5.1 found

Consider adjusting the PKG_CONFIG_PATH environment variable if you

installed software in a non-standard prefix.

Alternatively, you may set the environment variables LUA_CFLAGS

and LUA_LIBS to avoid the need to call pkg-config.

See the pkg-config man page for more details.

解决办法:

cp etc/lua.pc /usr/local/lib/pkgconfig/lua5.1.pc

3、安装 MySQL-proxy 时报错:

checking for GLIB… configure: error: Package requirements (glib-2.0 = 2.16.0) were not met:

No package glib-2.0 found

Consider adjusting the PKG_CONFIG_PATH environment variable if you

installed software in a non-standard prefix.

Alternatively, you may set the environment variables GLIB_CFLAGS

and GLIB_LIBS to avoid the need to call pkg-config.

See the pkg-config man page for more details.

解决办法:

  1、查看系统已经安装 glib 的 rpm 包;

  glibc-2.5-49.el5_5.4

  glibc-headers-2.5-49.el5_5.4

  glib2-2.12.3-4.el5_3.1

  glibc-common-2.5-49.el5_5.4

  glibc-devel-2.5-49.el5_5.4

  2、下载安装 glib-2.18.4.tar.gz

4、刚开始使用系统里 rpm 所指定的 mysq_config 时,mysql-proxy 安装报错,信息如下;

   configure: error: mysql_config not exists or not executable, use $ ./configure –with-mysql=/path/to/mysql_config

  看到帮助安装文档里要求如下:

  –with-mysql[=PATH]  Include MySQL support. PATH is the path to mysql_config。

解决办法就是:安装包中的第 6 步。

以上是“MySQL 主从同步和读写分离如何配置”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注丸趣 TV 行业资讯频道!

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-07-18发表,共计10879字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)