mysql配置主从

这篇具有很好参考价值的文章主要介绍了mysql配置主从。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

一、部署mysql

1.1、先部署好两台mysql数据库,部署mysql可以查看我的文档

写文章-CSDN创作中心

二、开始配置mysql主从

2.1、主机配置

vim /etc/my.cnf 或者 vi /etc/my.cnf

#增加一下配置

log-bin=mysql-bin
server_id=101

#选择增加的参数

binlog-do-db= 数据库名  #需要同步的数据库

binlog-ignore-db = 数据库名  #不需要同步的数据库

 重启数据库:systemctl resatrt mysql

 2.2、主机上创建用于复制的数据库账号,可以使用已经创建好的,也可以新建,需要注意的是mysql8及之后版本,需要先创建好数据库账号

#mysql -uxxx   -pxxx  进入数据库

#mysql8以下使用

grant replication slave on *.* to '数据库用户'@'%'identified by '123';

grant replication client on *.* to '数据库用户'@'%'identified by '123';

#mysql8及以上使用

grant replication client,replication slave on *.* to '数据库用户'@'%';

#刷新

flush privileges;

 2.3、查看主库信息  show master status;

要记住file 和 position的值,也就是第一和第二列,后面用的上

2.4、配置从库

vim /etc/my.cnf 或者 vi /etc/my.cnf

#增加一下配置
server_id=202 #不能和主库的值一样

重启数据库:systemctl resatrt mysql 

2.5、从库关联配置

 #进入mysql数据库mysql -uxxx   -pxxx 

#停掉从的服务,这里一定要停掉服务再去执行下面的

stop slave;  #8以下的可以试试slave stop

#配置关联master,3306可以默认不写,master_log_file和master_log_pos参考之前主库show masterstatus;查询出来的信息。

change master to master_host='192.168.3.206', master_port=3306,master_user='root', master_password='root',master_log_file='binlog.000004',master_log_pos=156;

#启动服务

start slave; #8以下的可以试试slave start 

#查看是否成功

show slave status \G;

 需要保证框起来的都是yes

2.6、show slave status \G;常见问题,本人部署中发现Slave_IO_Running: No,如果这里不正确,可以查看下他的报错

mysql主从配置,Linux,mysql,数据库

 这里常见的有三种报错,一个是报server ids,一个是server UUIDs,还有一种是主库端口不通

#遇见UUIDs

找到data文件夹下的auto.cnf文件,修改里面的uuid值,保证各个主从的uuid不一样,重启数据库即可,可使用find / -name auto.cnf  查找

#遇见ids

找到/etc/my.cnf配置文件中的server_id,修改从库的server_id保证和复制结构中的其他db不一样,重启数据库即可,但是我这里试了依然不行,后面使用下面的方法

#查看server_id

 show variables like 'server_id';

#停止slave后,手动修改server_id

mysql> stop slave;

mysql> set global server_id=2;#此处的数值和my.cnf里设置的一样就行

mysql> start slave;

再次查看show slave status \G;

 这里需要注意的是我本地部署的时候,发现只要一重启数据库,server_id就会重置成1,然后和主库就一样了,所以这里不能重启数据库,如果知道这个是什么问题,可以留言给我补充。

三、如果主库已经存在数据库,创建好主从之后,如何把之前的数据库同步过来

3.1、使用mysqldump

#在从库使用mysqldump命令复制数据

[root@slave2 ~]# mysqldump --single-transaction --all-databases --master-data=1 --host=192.168.2.138 --user=root --password=root --apply-slave-statements | mysql -uroot -proot-hlocalhost

参数说明

–single-transaction参数可以对Innodb表执行非锁定导出。此选项将事务隔离模式设置为REPEATABLE READ,并在转储数据之前向服务器发送START TRANSACTION SQL语句。它仅适用于Innodb等事务表,因为它会在发出START TRANSACTION时转储数据库的一致状态,而不会阻塞任何应用程序。因此这里假定:1. 所有的应用数据表都使用Innodb引擎。2. 所有系统表数据在备份过程中不会发生变化。

–master-data参数会导致转储输出包含类似 CHANGE MASTER TO MASTER_LOG_FILE=‘binlog.000004’, MASTER_LOG_POS=1480; 的SQL语句,该语句指示主库的二进制日志坐标(文件名和位置)。如果选项值为2,则CHANGE MASTER TO语句将写为SQL注释,因此仅提供信息,不会执行。如果参数值为1,则该语句不会写为注释,并在重新加载转储文件时执行。如果未指定选项值,则默认值为1。

–apply-slave-statements参数会在CHANGE MASTER TO语句之前添加STOP SLAVE语句,并在输出结尾处添加START SLAVE语句,用来自动开启复制。

mysqldump方式的优点是可以进行部分复制,如在配置文件中定义replicate-do-table=db1.*,则用这种方法可以只复制db1库而忽略其它复制事件。缺点是由于mysqldump会生成主库转储数据的SQL语句,实际是一种逻辑备份方式所以速度较慢,不适用于大库。

3.2、如果可以脱机复制直接的数据,可以使用下面的方法

#1、停止复制的所有实例,在主从分别执行

ln -s /usr/local/mysql/bin/mysqladmin /usr/bin/mysqladmin

mysqladmin -hlocalhost -uroot -pwwwwww shutdown

#2、主库复制数据到从库

cd /data 

scp -r mysql/* root@192.168.3.208:/usr/local/mysql/data/  #从库的数据文件路径

#3、在从库执行命令,删除auto.cnf文件

cd /data/mysql

rm -rf auto.cnf

#4、重启 实例,主从都需要执行

systemctl start mysql文章来源地址https://www.toymoban.com/news/detail-553414.html

到了这里,关于mysql配置主从的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【MySQL数据库】主从复制与读写分离

    读写分离,基本的原理是让主数据库处理事务性增、改、删操作(INSERT、UPDATE、DELETE),而从数据库处理SELECT查询操作。数据库复制被用来把事务性操作导致的变更同步到集群中的从数据库。 因为数据库的“写”(写10000条数据可能要3分钟)操作是比较耗时的。 但是数据库

    2024年02月11日
    浏览(45)
  • Mysql主从数据库搭建(一主两从)

    目录 1、服务器规划 2、主从同步流程 3、主从搭建 3.1、master节点上配置文件修改 3.2、master节点创建同步用户和权限 3.3、slave1和slave2节点配置文件修改 3.4、slave1和slave2节点执行同步任务 3.5、解决虚拟机克隆导致mysql所有服务器uuid都一样的问题 4、bin-log相关说明 5、主从同步注

    2024年02月11日
    浏览(33)
  • 【数据库】mysql主从复制与读写分离

      读写分离,基本的原理是让主数据库处理事务性增、改、删操作(INSERT、UPDATE、DELETE ),而从数据库处理SELECT查询操作。数据库复制被用来把事务性操作导致的变更同步到集群中的从数据库。   因为数据库的\\\"写”(写10000条数据可能要3分钟)操作是比较耗时的。   

    2024年02月11日
    浏览(58)
  • MySQL数据库 主从复制与读写分离

    读写分离,基本的原理是让主数据库处理事务性增、改、删操作(INSERT、UPDATE、DELETE),而从数据库处理SELECT查询操作。数据库复制被用来把事务性操作导致的变更同步到集群中的从数据库。 因为数据库的“写”(写10000条数据可能要3分钟)操作是比较耗时的。 但是数据库

    2024年02月10日
    浏览(35)
  • 实现↝Mysql数据库主从复制搭建与同步

    一般数据库都是读取压力大于写数据压力,主从复制即为了实现数据库的负载均衡和读写分离。通过将Mysql的某一台主机的数据复制到其它主机(slaves)上,主服务器只负责写,而从服务器只负责读。 如生产环境中,使用redis数据库作为缓存数据库,用户访问业务数据时,先

    2024年02月10日
    浏览(31)
  • Docker 容器搭建mysql 集群(主从数据库)

    目录 1.背景         2.设备及软件版本 3.开始搭建(这里不介绍安装docker及mysql) 3.1创建主数据库容器(master) 3.2查看容器是否创建成功 3.3进入修改容器下的/etc/my.cnf文件 3.3.1先拷贝my.cnf到容器外修改完再覆盖容器原来的my.cnf文件 3.4重启mysql容器使配置文件生效 3.5查看是否

    2024年02月08日
    浏览(88)
  • Mysql数据库--实现主从复制搭建与同步

    一般数据库都是读取压力大于写数据压力,主从复制即为了实现数据库的负载均衡和读写分离。通过将Mysql的某一台主机的数据复制到其它主机(slaves)上,主服务器只负责写,而从服务器只负责读。 如生产环境中,使用redis数据库作为缓存数据库,用户访问业务数据时,先

    2024年02月08日
    浏览(40)
  • 【数据库七】MySQL主从复制与读写分离

    读写分离,基本的原理是让主数据库处理事务性增、改、删操作 (insert、update、delete),而 从数据库处理select查询操作 。 数据库复制被用来把事务性操作导致的变更同步到集群中的从数据库 。 因为数据库的“写”(写10000条数据可能要3分钟)操作是比较耗时的。 但是数据

    2024年02月11日
    浏览(48)
  • MariaDB数据库的主从配置

    首先准备两台可以互相ping通的机器,两台机器可以互为主从,示例:10.210.23.77主服务器 10.20.84.183从服务器 在两台机器上各自安装数据 解压MariaDB安装包;  安装MariaDB依赖包;  启动MariaDB服务  安全配置 # 开始安全配置   ① 输入当前密码,初次安装后是没有密码的,直接回

    2024年02月04日
    浏览(35)
  • 基于docker搭建MySql主从数据库(详细步骤)

    在 Linux 中建立对应文件夹,用于存放MySql数据库相关,文件夹路径: /usr/local/software/mysql 。 在mysql文件下创建如下目录结构的文件:(3306为主数据库文件夹,笔者这里以对端口号来命名;3310为从数据库文件夹,3311同理,可依次往下) 上传 my.cnf 文件到 conf 文件夹下 以下是

    2024年02月09日
    浏览(41)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包