《MYSQL数据库mysql数据库 主从复制的配置方法》要点:
本文介绍了MYSQL数据库mysql数据库 主从复制的配置方法,希望对您有用。如果有疑问,可以联系我们。
MYSQL应用MySQL支持单向、异步复制,复制过程中一个服务器充当主服务器,而一个或多个其它服务器充当从服务器.主服务器将更新写入二进制日志文件,并维 护日志文件的一个索引以跟踪日志循环.当一个从服务器连接到主服务器时,它通知主服务器从服务器在日志中读取的最后一次成功更新的位置.从服务器接收从那 时起发生的任何更新,然后封锁并等待主服务器通知下一次更新.
MYSQL应用为什么使用主从复制?
MYSQL应用1、主服务器/从服务器设置增加了健壮性.主服务器出现问题时,你可以切换到从服务器作为备份.
MYSQL应用2、通过在主服务器和从服务器之间切分处理客户查询的负荷,可以得到更好的客户响应时间.但是不要同时在主从服务器上进行更新,这样可能引起冲突.
MYSQL应用3、使用复制的另一个好处是可以使用一个从服务器执行备份,而不会干扰主服务器.在备份过程中主服务器可以继续处理更新.
MYSQL应用MySQL 使用3个线程来执行复制功能(其中1个在主服务器上,另两个在从服务器上.当发出START SLAVE时,从服务器创建一个I/O线程,以连接主服务器并让主服务器发送二进制日志.主服务器创建一个线程将二进制日志中的内容发送到从服务器.从服 务器I/O线程读取主服务器Binlog Dump线程发送的内容并将该数据拷贝到从服务器数据目录中的本地文件中,即中继日志.第3个线程是SQL线程,从服务器使用此线程读取中继日志并执行日志中包含的更新.SHOW PROCESSLIST语句可以查询在主服务器上和从服务器上发生的关于复制的信息.
MYSQL应用默认中继日志使用 host_name-relay-bin.nnnnnn形式的文件名,其中host_name是从服务器主机名,nnnnnn是序 列号.用连续序列号来创建连续中继日志文件,从000001开始.从服务器跟踪中继日志索引文件来识别目前正使用的中继日志.默认中继日志索引文件名为 host_name-relay-bin.index.在默认情况,这些文件在从服务器的数据目录中被创建.中继日志与二进制日志的格式相同,并且可以用 mysqlbinlog读取.当SQL线程执行完中继日志中的所有事件后,中继日志将会被自动删除.
MYSQL应用从服务器在数据目录中另外创建两个状态文件--master.info和relay-log.info.状态文件保存在硬盘上,从服务器关闭时不会丢失.下次从服务器启动时,读取这些文件以确定它已经从主服务器读取了多少二进制日志,以及处理自己的中继日志的程度.
MYSQL应用1.配置主服务器
MYSQL应用打开mysql的配置
MYSQL应用
vim/usr/local/webserver/mysql/my.cnf
MYSQL应用开启server_id和bin-log日志
MYSQL应用server_id = '唯一值'(开启server_id)
MYSQL应用log-bin = /data/mysql/3306/binlog/binlog
MYSQL应用2. 配置从服务器
MYSQL应用打开mysql的配置
MYSQL应用
vim /usr/local/webserver/mysql/my.cnf
MYSQL应用开启server_id和bin-log日志
MYSQL应用server_id = '唯一值'(开启server_id)
MYSQL应用
log-bin = /data/mysql/3306/binlog/binlog
MYSQL应用修改完配置后记得重启数据库 service mysqld restart
MYSQL应用关键点:从数据库中必须有一个用户可以在从数据库的机器上去连接主服务器
MYSQL应用3.在主数据库中给从数据库一个用户
MYSQL应用进入mysql /usr/local/webserver/mysql/bin/mysql -p 密码
MYSQL应用mysql> grant all on *.* to 用户@从数据库的ip identified by '密码';
MYSQL应用flush privileges;刷新权限
MYSQL应用在主数据库中查看 show master status;主数据库的最新的bin-log日志文件名
MYSQL应用4.进入从数据库,执行下边的sql语句
MYSQL应用检查从数据库是否可以进入
MYSQL应用
mysql /usr/local/webserver/mysql/bin/mysql -u
MYSQL应用主数据库给的用户 -p 密码 -h主数据库的ip ,如果可以进入,则退出
MYSQL应用
mysql /usr/local/webserver/mysql/bin/mysql -u
MYSQL应用密码
MYSQL应用特别,在执行change之前必须关闭从库 stop slave;
MYSQL应用mysql> change master to master_host='主数据库ip',master_user='主数据库授权的用户名',master_password='主数据库授权的密码',master_log_file='主数据库的bin-log日志的文件名',master_log_pos='主数据库的bin-log日志的position值'
MYSQL应用5.开启从库 start slave;
MYSQL应用6.查看从库状态 show slave status\G;
MYSQL应用
change master to master_host='101.200.136.226',master_user='zt',master_password='zt',master_log_file=' binlog.000001 ',master_log_pos=4826;
MYSQL应用如果
Slave_IO_Running: Yes
Slave_SQL_Running: Yes
MYSQL应用 OK没问题
MYSQL应用主从配置完毕
MYSQL应用binlog命令
MYSQL应用
/usr/local/webserver/mysql/bin/mysqlbinlog binlog.000001
MYSQL应用查看binlog日志文件
MYSQL应用reset master 初始化binlog日志
MYSQL应用show master status; 查看最新的日志文件和position值
MYSQL应用flush logs 刷新log日志文件
MYSQL应用start slave 开启从库
MYSQL应用stop slave 停止从库
MYSQL应用show slave status;查看从库状态
MYSQL应用通过binlog日志恢复数据
MYSQL应用进入binlog目录
MYSQL应用
cd /data/mysql/3306/binlog/
MYSQL应用查看binlog列表 ls
MYSQL应用查看binlog日志文件
MYSQL应用
/usr/local/webserver/mysql/bin/mysqlbinlog binlog.000001
MYSQL应用恢复数据
MYSQL应用 /usr/local/webserver/mysql/bin/mysqlbinlog binlog.000001 | /usr/local/webserver/mysql/bin/mysql -p(在没有清空binlog日志之前可以恢复)
MYSQL应用如果执行了 reset master 就无法恢复
MYSQL应用以上就是对 mysql 数据库 主从复制的配置资料整理,开发数据库需要的朋友可以看下.
转载请注明本页网址:
http://www.vephp.com/jiaocheng/2331.html