MySQL一主一从的配置主要涉及到主服务器(Master)和从服务器(Slave)的配置文件,通常是`my.cnf`或`my.ini`,具体配置如下:
### 主服务器(Master)配置:
1. **server-id**:为每个MySQL服务器设置一个唯一的ID。
server-id=1
2. **log-bin**:启用二进制日志,用于记录所有修改数据的语句。
log-bin=mysql-bin
3. **binlog-do-db**:如果需要复制特定的数据库,可以使用此选项指定。
binlog-do-db=db_name
4. **binlog-ignore-db**:如果需要忽略复制特定的数据库,如MySQL自带的数据库。
binlog-ignore-db=mysql
binlog-ignore-db=information_schema
binlog-ignore-db=performance_schema
#binlog-do-db=需要备份的数据库名,可写多行
#binlog-ignore-db=不需要备份的数据库名,可写多行
5. **expire_logs_days**:设置二进制日志文件的过期时间,单位为天。
expire_logs_days=7
### 从服务器(Slave)配置:
1. **server-id**:同样需要设置一个唯一的ID,不能与主服务器的ID相同。
server-id=2
2. **relay-log**:设置中继日志文件的名称。
relay-log=relay-log
3. **read-only**:设置从服务器为只读模式,防止在从服务器上执行写操作。
read-only=1
### 主从复制配置步骤:
1. **配置文件设置**:按照上述配置修改主从服务器的配置文件。
2. **创建复制用户**:在主服务器上创建用于复制的专用用户。
```sql
CREATE USER 'repl'@'%' IDENTIFIED BY 'password';
GRANT REPLICATION SLAVE ON *.* TO 'repl'@'%';
&