MySQL 5.5主从同步设置笔记分享
时间:2024-05-13 10:56:38 来源:未知 作者:站长技术网 点击:次
先修改Master(10.1.123.197)的 my.cnf 配置 在 [mysqld] 中新增以下内容: 复制代码 代码如下:
然后指定要做同步的数据库,并忽略掉不需要做同步的数据库 复制代码 代码如下:
在 [mysqldump] 中修改内容为 复制代码 代码如下: max_allowed_packet = 32M 注意:确保 max_allowed_packet 有比较大的值,比如 max_allowed_packet = 100M 重启 mysql: 复制代码 代码如下: service mysql restart 在Master上创建一个复制用户 复制代码 代码如下: CREATE USER funsion; + ---------------------------------------------------------- + 再修改 Slave(10.1.123.160)的配置,修改 my.cnf 在 [mysqld] 中新增以下内容 复制代码 代码如下:
sync_master_info = 1 # 以上三行话只使用于MySQL 5.5 输入 mysql -u root -p 复制代码 代码如下:
CHANGE MASTER TO MASTER_CONNECT_RETRY=30; 在输入 START SLAVE; + ----------------------- 如果发生错误无法启动 ------------------- + 进入Master 的数据库 然后进入Slave 的数据库 复制代码 代码如下: change master to master_log_file='mysql-bin.000001',master_log_pos=107; 最后输入 start slave; 最后在服务器上执行 复制代码 代码如下: yum -y install ntpdate 把几台服务器的时间同步 + ---------------------------- 一些可能用到的命令 ------------------------- + 执行锁表: 复制代码 代码如下: flush tables with read lock; 这一步的目的是使我们在制作主从的过程中,主库中不会有新的数据,否则会给我们的同步设置带来麻烦 主库执行解锁: 复制代码 代码如下: unlock tables; reset master命令删除了所有的二进制日志文件并清空了二进制日志索引文件。 + ----------------------- 其它参考文档(未验证)-------------------------- + 库业务不能停的情况下为从库制作镜像: 复制代码 代码如下: mysqldump -uroot -pxxxx -h127.0.0.1 --databases db1 db2 db3 --master-data=1 > bak.sql 3号服务器slave stop; 之后将bak.sql导入3号从服务器 复制代码 代码如下: slave start; 3号服务器会自动从导出的那一刻的节点更新。 因为--master-data=1 这个参数在导出sql文件后会在最下方加上change语句。如果--master-data=0,则不会带有。 非常的方便,但仅适合库不是太大的情况,该案例导出的库一共6G。 |