- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章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–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; 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 mysql-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主从同步、读写分离配置步骤的文章就讲到这里了,如果你想了解更多关于MySQL主从同步、读写分离配置步骤的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我正在实现 IMAP 客户端,但 IMAP 邮箱同步出现问题。 首先,可以从 IMAP 服务器获取新邮件,但我不知道如何从邮箱中查找已删除的邮件。 我是否应该从服务器获取所有消息并将其与本地数据进行比
我研究线程同步。当我有这个例子时: class A { public synchronized void methodA(){ } public synchronized void met
嗨,我做了一个扩展线程的东西,它添加了一个包含 IP 的对象。然后我创建了该线程的两个实例并启动它们。他们使用相同的列表。 我现在想使用 Synchronized 来阻止并发更新问题。但它不起作用,我
我正在尝试使用 FTP 定期将小数据文件从程序上传到服务器。用户从使用 javascript XMLHttpRequest 函数读取数据的网页访问数据。这一切似乎都有效,但我正在努力解决由 FTP 和
我不知道如何同步下一个代码: javascript: (function() { var s2 = document.createElement('script'); s2.src =
关闭。这个问题需要更多focused .它目前不接受答案。 想改进这个问题吗? 更新问题,使其只关注一个问题 editing this post . 关闭 7 年前。 Improve this qu
一 点睛 1 Message 在基于 Message 的系统中,每一个 Event 也可以被称为 Message,Message 是对 Event 更高一个层级的抽象,每一个 Message 都有一个
一 点睛 1 Message 在基于 Message 的系统中,每一个 Event 也可以被称为 Message,Message 是对 Event 更高一个层级的抽象,每一个 Message 都有一个
目标:我所追求的是每次在数据库中添加某些内容时(在 $.ajax 到 Submit_to_db.php 之后),从数据库获取数据并刷新 main.php(通过 draw_polygon 更明显)。 所
我有一个重复动画,需要与其他一些 transient 动画同步。重复动画是一条在屏幕上移动 4 秒的扫描线。当它经过下面的图像时,这些图像需要“闪烁”。 闪烁的图像可以根据用户的意愿来来去去和移动。它
我有 b 个块,每个块有 t 个线程。 我可以用 __syncthreads() 同步特定块中的线程。例如 __global__ void aFunction() { for(i=0;i #
我正在使用azure表查询来检索分配给用户的所有错误实体。 此外,我更改了实体的属性以声明该实体处于处理模式。 处理完实体后,我将从表中删除该实体。 当我进行并行测试时,可能会发生查询期间,一个实体已
我想知道 SQLite 是如何实现它的。它基于文件锁定吗?当然,并不是每个访问它的用户都锁定了整个数据库;那效率极低。它是基于多个文件还是仅基于一个大文件? 如果有人能够简要概述一下 sqlite 中
我想post到php,当id EmpAgree1时,然后它的post变量EmpAgree=1;当id为EmpAgree2时,则后置变量EmpAgree=2等。但只是读取i的最后一个值,为什么?以及如何
CUBLAS 文档提到我们在读取标量结果之前需要同步: “此外,少数返回标量结果的函数,例如 amax()、amin、asum()、rotg()、rotmg()、dot() 和 nrm2(),通过引用
我知道下面的代码中缺少一些内容,我的问题是关于 RemoteImplementation 中的同步机制。我还了解到该网站和其他网站上有几个关于 RMI 和同步的问题;我在这里寻找明确的确认/矛盾。 我
我不太确定如何解决这个问题......所以我可能需要几次尝试才能正确回答这个问题。我有一个用于缓存方法结果的注释。我的代码目前是一个私有(private)分支,但我正在处理的部分从这里开始: http
我对 Java 非常失望,因为它不允许以下代码尽可能地并发移动。当没有同步时,两个线程会更频繁地切换,但是当尝试访问同步方法时,在第二个线程获得锁之前以及在第一个线程获得锁之前再次花费太长时间(比如
过去几周我一直在研究java多线程。我了解了synchronized,并理解synchronized避免了多个线程同时访问相同的属性。我编写此代码是为了在同一线程中运行两个线程。 val gate =
我有一个关于 Java 同步的简单问题。 请假设以下代码: public class Test { private String address; private int age;
我是一名优秀的程序员,十分优秀!