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

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

本文主要向您展示如何配置MySQL主从同步和读写分离。内容简单易懂,条理清晰。希望能帮你解开疑惑。让边肖带领大家学习学习《如何配置MySQL主从同步和读写分离》一文。

目前使用的两台服务器都已经安装了MySQL,所有服务器都是用rpm打包的,可以正常使用。

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

环境:192.168.0.1(主)

192.168.0.2(从机)

MySQL版本:版本14.14发行版5.1.48,适用于使用readline 5.1的pc-linux-gnu (i686)

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

Server-ID=1 //数据库ID号,为1时表示Master,其中master_id必须为1到232ndash介于1和之间的正整数值;

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

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

Binlog-ignore-db=mysql //非同步二进制数据库的名称;这次同步后,听说很麻烦。我没有同步。

log-bin=/var/log/MySQL/updatelog//设置生成的日志文件名;

Log-slave-updates //将更新的记录写入二进制文件;

从属跳过错误//跳过错误并继续复制;

2.建立用于复制的用户;

*上的mysqlgrant复制从机。*测试由“*******”标识的@192.168.0.2

3.重新启动mysql

/usr/bin/mysqladmin -uroot关闭;

/usr/bin/mysql_safe

4.现在备份主服务器上的数据;

锁定后,我直接tar.gz数据这个库文件;

带读锁定的MySQL刷新表;

cd /var/lib/mysql

焦油data.tar.gz数据

然后是远程scp直接执行;

scp。/data . tar . gz root @ 192 . 168 . 0 . 2:/var/lib/MySQL

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

服务器id=3 //2已在另一台服务器上使用。如果你想加上从机号码,然后再数回来,就可以了。

log-bin=mysql-bin

主主机=192.168.0.1

主用户=测试

主密码=* * * * * * *

主端口=3306

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

Replicate-ignore-db=mysql //无需备份的数据库;

复制数据库=数据//要备份的数据库

日志从属更新

从属跳过错误

6.解压缩刚刚从scp主机发送的文件。没有必要在这里更改权限和所有者。默认不变,可以根据实际情况修改。

7.以上完成后,可以启动从机;检查从机状态;

mysqlslave启动;www.2cto.com

mysqlshow从属状态\ G;

*************************** 1.行**************************

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

内容来源网络,如有侵权,联系删除,本文地址:https://www.230890.com/zhan/137947.html

(0)

相关推荐

  • 怎么创建PHP DI容器

    技术怎么创建PHP DI容器这篇文章主要讲解了“怎么创建PHP DI容器”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么创建PHP DI容器”吧!

    攻略 2021年12月1日
  • 抖音刷粉会被限流吗,抖音刷粉有什么影响?

    技术抖音刷粉会被限流吗,抖音刷粉有什么影响?抖音的爆火引发了新的产业链的产生,点开百度输入关键词抖音上热门涨粉等等,就会出现很多的机构打着上热门,涨粉的这种幌子,制定出各种诱人的套餐,对抖音进行刷量,刷赞,换句话说只要你

    测评 2021年11月10日
  • 【上接 9 年前的一篇文章】动态创建控件的一个坑和解决方案

    技术【上接 9 年前的一篇文章】动态创建控件的一个坑和解决方案 【上接 9 年前的一篇文章】动态创建控件的一个坑和解决方案提出问题
    昨天一位网友提出了这么一个问题:动态创建Disabled的文本输入框,

    礼包 2021年11月1日
  • 题解 CF852D Exploration plan

    技术题解 CF852D Exploration plan 题解 CF852D Exploration plan【题意翻译】
    给定一个\(V\) 个点\(E\) 条边的带权无向图,在图上有\(N\) 个人

    礼包 2021年11月4日
  • 飞牌,在澳门大赌场出千被抓会怎么样

    技术飞牌,在澳门大赌场出千被抓会怎么样我曾混迹世界各大赌场飞牌,无论在澳门的赌场也好,在欧美等世界各地的赌场也罢,它们只喜欢游客去“娱乐(输钱或各种形式的消费)”,而不是去赢钱!赌场特别不欢迎三天两头去赢“大钱”的游客。

    生活 2021年10月31日
  • oraclepdb库(oracle跨pdb互访)

    技术Oracle怎么实现跨平台传输PDB本篇内容主要讲解“Oracle怎么实现跨平台传输PDB”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Oracle怎么实现跨平台传输PD

    攻略 2021年12月21日