mysql主从复制

作者: 麦子先生R | 来源:发表于2017-10-12 14:35 被阅读31次

    构建MySQL主从复制

    -----------主MySQL------------从MySQL----------从MySQL------------
            192.168.1.1         192.168.1.2      192.168.1.3
    

    MySQL的主从复制和mysql的读写分离两者有着紧密联系,数据的读写分离实在主从复制的基础之上完成的,也就是说只有主从复制完成了,才能在此基础上做数据读写分离

    MySQL支持的复制类型:
    
     1.基于语句的复制:在主服务器上执行的SQL语句,在从服务器上再执行同样的语句句,默认采用基于语的
    复制,效率比较高
     2.基于行的复制:把改变的内容复制过去,而不是把命令在从服务器上执行一遍 (比较精准)
     3.混合类型的复制:默认采用基于语的复制,一旦发现基于语句无法精确复制时,就会采用基于行的复制
    

    一、准备工作

    1.保证服务器之间正常通讯
    2.保证时间同步一至
    
    1、配置IP地址
    2、关闭防火墙
    [root@localhost ~]# service iptables stop
    [root@localhost ~]# chkconfig iptables off
    

    二、时间同步服务器

    1、在主数据库上搭建NTP时间同步服务器
    
    [root@localhost ~]# yum -y install ntp
    [root@localhost ~]# vim /etc/ntp.conf
    添加:
    server 127.127.1.0
    fudge 127.127.1.0 stratum 8
    [root@localhost ~]# service ntpd restart
    2、在从数据库上安装ntp时间服务
    [root@localhost ~]# yum -y install ntpdate
    [root@localhost ~]# ntpdate 192.168.1.1
    

    二、安装MySQL服务(三台数据库服务器安装保持一致)

    1、安装cmake软件
    [root@localhost ~]# tar -zxvf cmake-2.8.6.tar.gz -C /usr/src/
    [root@localhost ~]# cd /usr/src/cmake-2.8.6/
    [root@localhost cmake-2.8.6]# ./configure && gmake && gmake install
    2、安装mysql软件
    [root@localhost ~]# tar -zxvf mysql-5.5.22.tar.gz -C /usr/src/
    [root@localhost ~]# cd /usr/src/mysql-5.5.22/
    [root@localhost mysql-5.5.22]# cmake  DCMAKE_INSTALL_PREFIX=/usr/local/mysql
     -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci -DSYSCONFDIR=/etc 
     -DWITH_EXTRA_CHARSETS=all
    [root@localhost mysql-5.5.22]# make && make install
    [root@localhost ~]# cp /usr/src/mysql-5.5.22/support-files/mymedium.cnf /etc/my.cnf
    [root@localhost ~]# cp /usr/src/mysql-5.5.22/support-files/mysql.server 
    /etc/init.d/mysqld
    [root@localhost ~]# chmod +x /etc/init.d/mysqld
    [root@localhost ~]# chown -R mysql:mysql /usr/local/mysql
    [root@localhost ~]# ln -s /usr/local/mysql/bin/* /usr/local/bin/
    [root@localhost ~]# /usr/local/mysql/scripts/mysql_install_db --
    user=mysql --basedir=/usr/local/mysql/ --datadir=/usr/local/mysql/data/
    [root@localhost ~]# service mysqld restart
    [root@localhost ~]# chkconfig --add mysqld
    [root@localhost ~]# chkconfig mysqld on
    验证:
    [root@localhost ~]# mysqladmin -u root password '123.com'
    [root@localhost ~]# mysql -u root -p123.com
    3、主从配置
    1)主数据库服务器配置
    [root@localhost ~]# vim /etc/my.cnf
    添加:
    server-id=11 //修改
    log-bin=master-bin //修改 启用二进制
    log-slave-updates=true //添加 允许从服务器同步
    [root@localhost ~]# service mysqld restart
    [root@localhost ~]# mysql -u root -p123.com
       mysql> grant replication slave on *.* to 'slave'@'192.168.1.%' identified by '123.com';
       mysql> flush privileges;
       mysql> show master status;                                                      
       mysql> quit
    2)从数据库服务器配置
    [root@localhost ~]# vim /etc/my.cnf
    添加:
    server-id=22 //修改  :主—从的ID不能相同。
    relay-log=relay-log-bin //添加
    relay-log-index=slave-relay-bin.index //添加
    
    [root@localhost ~]# service mysqld restart
    [root@localhost ~]# mysql -u root -p123.com
    mysql> change master to
    master_host='192.168.1.1',master_user='slave',master_password='123.com',master_log_file='mast
    er-bin.000001',master_log_pos=107;
    mysql> start slave;
    mysql> show slave status\G; //结尾不能加; 否则或报错。
    Slave_IO_Running: Yes //确保为YES
    Slave_SQL_Running: Yes //确保为YES
    mysql> quit
    问题说明:
    1、如果出现ERROR: No query specified
    则:原因是语法错误,去掉语句后的;号。
    2、如果bin-log日志不更新,或者无法进行数据同步,
    则:删除bin-log日志,重新启动服务即可。
    4、验证:
    1)主数据库服务器:
    [root@localhost ~]# mysql -u root -p123.com
       mysql> show databases;
       mysql> create database hehe;
       mysql> show databases;
       mysql> use hehe;
       mysql> create table biao1 (id int(5),name char(12));
       mysql> show tables;
       mysql> quit
    2)从数据库服务器:
     [root@localhost ~]# mysql -u root -p123.com
       mysql> show databases;
       mysql> show databases;
       mysql> use hehe
       mysql> show tables;
       mysql> quit

    相关文章

      网友评论

        本文标题:mysql主从复制

        本文链接:https://www.haomeiwen.com/subject/vktoyxtx.html