MySQL主从复制

主库my.ini配置

[mysqld]
# 端口(默认:3306)
port=10100
# 设置mysql的安装目录
basedir=C:\ProgramFiles\MySQL\mysql-master
# 设置mysql数据库的数据的存放目录
datadir=C:\ProgramFiles\MySQL\mysql-ats-master\data
# 设置默认时区
default-time_zone='+8:00'

# =================== 主库设置 Start ===================
# 启用二进制日志
log-bin=mysql-bin
# Master的id,这个要唯一,唯一是值,在主从中唯一
server-id=10100
# 自动清理7天前的log文件
expire_logs_days=7
# 配置要给Slave同步的数据库
binlog_do_db=db_test
# 不用给Slave同步的数据库,一般是Mysql自带的数据库就不用给Slave同步了
binlog_ignore_db=mysql
binlog_ignore_db=information_schema
binlog_ignore_db=performance_schema
binlog_ignore_db=sys
# =================== 主库设置 End ===================

主库SQL操作

# 查看log_bin日志是否启动成功
SHOW VARIABLES LIKE '%log_bin%';

# 创建用户并授权
mysql> CREATE USER 'user_replication' @'%' IDENTIFIED BY 'pwd_replication';
mysql> GRANT Replication SLAVE ON *.* TO `user_replication` @`%`;
mysql> FLUSH PRIVILEGES;

# 接着查看Master的状态:
SHOW MASTER STATUS;

从库my.ini配置

[mysqld]
# 端口(默认:3306)
port=10101
# 设置mysql的安装目录
basedir=C:\ProgramFiles\MySQL\mysql-slave
# 设置mysql数据库的数据的存放目录
datadir=C:\ProgramFiles\MySQL\mysql-slave\data
# 设置默认时区
default-time_zone='+8:00'

# =================== 从库设置 Start ===================
# 配置从服务器的ID,唯一的
server-id=10101
# 加上以下参数可以避免更新不及时,SLAVE 重启后导致的主从复制出错
read_only = 1
master_info_repository=TABLE
relay_log_info_repository=TABLE
# =================== 从库设置 Start ===================

从库SQL操作

# 关闭从库
STOP SLAVE;

# 改变主库连接配置
CHANGE MASTER TO master_host = 'localhost',
master_port = 10100,
master_user = 'user_replication',
master_password = 'pwd_replication',
master_log_file = 'mysql-bin.000008',
master_log_pos = 2666;

# 启动从库
START SLAVE;

# 查看从库的状态(Slave_IO_Running和Slave_SQL_Running都为Yes,才表示连接成功)
SHOW SLAVE STATUS;

可能遇到的问题

  • Slave_IO_Running: Connecting,解决方法:
# 使用mysql.exe重新登录一下就好了
C:\ProgramFiles\MySQL\mysql-master\bin> .\mysql.exe -hlocalhost -P10100 -uuser_replication -p 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MySQL主从复制MySQL内建的复制功能,用于构建基于MySQL的大规模、高性能应用。它的主要目的是实现高性能、高可用性、可扩展性、灾难恢复、备份以及数据仓库等功能。主从复制的常见用途包括以下几种: 1. 数据备份和灾难恢复:通过将主服务器上的数据复制到一个或多个从服务器上,可以实现数据的备份和灾难恢复。当主服务器发生故障时,可以快速切换到从服务器来保证系统的可用性。 2. 负载均衡:通过将读操作分发到多个从服务器上,可以减轻主服务器的负载,提高系统的性能和可扩展性。 3. 数据分析和报表生成:通过将主服务器上的数据复制到一个或多个从服务器上,可以在从服务器上进行数据分析和报表生成,而不会影响主服务器的性能。 4. 数据分发:通过将主服务器上的数据复制到多个从服务器上,可以将数据分发到不同的地理位置或不同的应用程序中,以满足不同的需求。 在MySQL主从复制中,可以使用一些工具来简化配置和管理,比如MySQL-Proxy。MySQL-Proxy是MySQL官方开源项目,通过其自带的lua脚本进行SQL判断,但MySQL官方并不建议将MySQL-Proxy用于生产环境。此外,还需要在主服务器和从服务器上进行一些配置,如设置server-id、开启二进制日志、允许从服务器更新二进制日志等。还需要为从服务器授权复制权限,并通过show master status命令查看主服务器的状态信息。\[1\]\[2\]\[3\] #### 引用[.reference_title] - *1* [MySQL主从复制详细介绍](https://blog.csdn.net/qq_44590469/article/details/126340217)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [MySQL主从复制](https://blog.csdn.net/m0_62473957/article/details/124140928)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值