zoukankan      html  css  js  c++  java
  • MySQL主从同步

    MySQL主从同步:

    主从同步使得数据可以从一个数据库服务器复制到其他服务器上,在复制数据时,一个服务器充当主服务器(master),其余的服务器充当从服务器(slave)。因为复制是异步进行的,所以从服务器不需要一直连接着主服务器,从服务器甚至可以通过拨号断断续续地连接主服务器。通过配置文件,可以指定复制所有的数据库,某个数据库,甚至是某个数据库上的某个表。

    使用主从同步的好处:

    (1) 通过增加从服务器来提高数据库的性能,在主服务器上执行写入和更新,在从服务器上向外提供读功能,可以动态地调整从服务器的数量,从而调整整个数据库的性能。

    (2) 提高数据安全,因为数据已复制到从服务器,从服务器可以终止复制进程,所以,可以在从服务器上备份而不破坏主服务器相应数据

    (3) 在主服务器上生成实时数据,而在从服务器上分析这些数据,从而提高主服务器的性能

     配置主从同步的基本步骤

    有很多种配置主从同步的方法,可以总结为如下的步骤:

    (1) 在主服务器上,必须开启二进制日志机制和配置一个独立的ID

    (2) 在每一个从服务器上,配置一个唯一的ID,创建一个用来专门复制主服务器数据的账号

    (3) 在开始复制进程前,在主服务器上记录二进制文件的位置信息

    (4) 如果在开始复制之前,数据库中已经有数据,就必须先创建一个数据快照(可以使用mysqldump导出数据库,或者直接复制数据文件)

    (5) 配置从服务器要连接的主服务器的IP地址和登陆授权,二进制日志文件名和位置

    详细配置主从同步的方法

    安装

    docker image pull mysql:5.7.22

    复制配置

    cd
    mkdir mysql_slave
    cd mysql_slave
    mkdir data
    cp -a /etc/mysql/mysql.conf.d ./

    修改配置

    编辑 ~/mysql_slave/mysql.conf.d/mysqld.cnf 文件,让此台mysql运行在8306端口上,且编号为2

    port  =  8306
    general_log  = 0
    server-id  = 2

     

    运行镜像-----》创建docker容器,在容器中运行Mysql

    docker run --name mysql-slave -e MYSQL_ROOT_PASSWORD=mysql -d --network=host -v /home/python/mysql_slave/data:/var/lib/mysql -v /home/python/mysql_slave/mysql.conf.d:/etc/mysql/mysql.conf.d  mysql:5.7.22

    # 解释:
    --name : 容器名
    -e MYSQL_ROOT_PASSWORD=mysql :设置root账号的密码为mysql
    -d --network=host :使用主机的网络ip
    -v /home/python/mysql_slave/data:/var/lib/mysql : 指定数据文件的目录
    -v /home/python/mysql_slave/mysql.conf.d:/etc/mysql/mysql.conf.d : 指定配置文件的目录
    mysql:5.7.22 : 镜像名字

    测试,在ubuntu中使用mysql命令尝试连接docker容器中的mysql

    mysql -uroot -pmysql -h 127.0.0.1 --port=8306

    备份主服务器原有数据到从服务器

    如果在设置主从同步前,主服务器上已有大量数据,可以使用mysqldump进行数据备份并还原到从服务器以实现数据的复制。

    在主服务器Ubuntu上进行备份(导出数据),执行命令:

    mysqldump -uroot -pmysql --all-databases --lock-all-tables > ~/master_db.sql

    解释

    -u :用户名

    -p :示密码

    --all-databases :导出所有数据库

    --lock-all-tables :执行操作时锁住所有表,防止操作时有数据修改

    ~/master_db.sql :导出的备份数据(sql文件)位置,可自己指定

    在docker容器中导入数据

    mysql -uroot -pmysql -h127.0.0.1 --port=8306 < ~/master_db.sql

    配置主服务器master(Ubuntu中的MySQL)

    编辑设置mysqld的配置文件,设置log_bin和server-id

    sudo vim /etc/mysql/mysql.conf.d/mysqld.cnf

    添加

    server-id = 1 # 不和从的id一样就行
    
    log_bin =/var/log/mysql/mysql-bin.log

    重启mysql服务

    sudo service mysql restart

    登入主服务器Ubuntu中的mysql,创建用户slave,分配复制权限

    mysql –uroot –pmysql
    
    GRANT REPLICATION SLAVE ON *.* TO 'slave'@'%' identified by 'slave';
    
    FLUSH PRIVILEGES;

    获取主服务器的二进制日志信息

    SHOW MASTER STATUS;  # 记录下File,Position的值,配置从服务器会用到

    配置从服务器slave (docker中的mysql)

    进入docker中的mysql

    mysql -uroot -pmysql -h 127.0.0.1 --port=8306

    执行

    change master to master_host='127.0.0.1', master_user='slave', master_password='slave',master_log_file='mysql-bin.000006', master_log_pos=590;

    解释:

    master_host:主服务器Ubuntu的ip地址

    master_log_file: 前面查询到的主服务器日志文件名

    master_log_pos: 前面查询到的主服务器日志文件位置

    启动slave服务器,并查看同步状态---》两个yes

    start slave;
    show slave status G

    成功状态 Slave_IO_Running: Yes
    Slave_SQL_Running: Yes

     

     

  • 相关阅读:
    Nmap绕过防火墙&脚本的使用
    Nmap在实战中的高级用法
    kali&BT安装好之后无法上网或者无法获得内网IP
    [转]谈渗透测试方法和流程
    xssless
    国内外有名的安全扫描工具,你知道几个?
    Linux下如果忘记了Mysql的root密码该怎么办?
    JSP手动注入 全
    sqlmap用户手册 [详细]
    Windows系统如何使用sqlmap
  • 原文地址:https://www.cnblogs.com/xiaolu915/p/10510374.html
Copyright © 2011-2022 走看看