mysql主从复制

本来是在做sharding的,可是做好之后发现数据库的主从复制还没有做,所以在配置好了之后做了些记录:

mysql主从复制的方式

mysql主从复制有两种方式:基于日志(binlog)、基于GTID(全局事物标示符)本博文用的是基于日志(binlog)的复制。

mysql主从复制的原理

1、 Master将数据记录到二进制日志中,也就是mysql配置文件my.cnf的log-bin指定的文件,这些记录叫做二进制日志事件。
2、 Slave有两个线程,一个I/O线程,一个SQL线程。I/O线程请求Master,将得到的binlog日志写到relay log(中继日志) 文件中。
3、 SQL 线程,会读取relay log文件中的日志,并解析成具体操作,来实现主从的操作一致,而最终数据一致。

这里写图片描述

mysql的主从配置的具体实现方式

1、 Master配置

(1) 修改mysql的my.cnf配置文件,这里比较坑爹的是我用的mysql版本没有my.cnf 配置文件,连my-default.cnf都没有,一般来说my.cnf在/etc目录下, my-default.cnf在/usr/local/mysql/support-files中。最终我在网上复制了一份my.cnf文件放在了/etc中(朋友们可以自己去网上找,有很多的)。
(2) my.cnf中需要修改的配置主要有开启日志功能,设置server_id保证其唯一性(不能跟从库一样),过滤需备份的数据库。

bash-3.2# vim /etc/my.cnf# 设置server_id,不能重复,一般可以设置为主库的IPserver_id=81# 备份过滤:需要备份的数据库,输出binlogbinlog-do-db=demo_ds_master# 备份过滤:不需要备份的数据库,不输出binlog-ignore-db=mysql# 开启二进制日志,将主库数据记录到mysql-bin开头的日志文件中(可自定义)          log-bin=mysql-bin# 配置每个session的内存,在事物过程中用来存储二进制日志的缓存binlog_cache_size=1M# 主从复制的格式(mixed,statement,row 默认的是statement)binlog_format=mixed# 二进制日志自动删除/过期的天数,默认为0,不自动删除expire_logs_days=7# 用于跳过主从复制中遇到的所有错误或指定的错误类型,避免slave端的终端# 1062:主键冲突(具体的参数可以去网上查询)slave_skip_errors=1062
#授权这个机器可以备份主数据库的数据mysql> GRANT REPLICATION SLAVE, REPLICATION CLIENT ON *.* TO 'root'@'192.168.31.60' identified by 'password';#然后刷新权限mysql> flush privileges;#查看配置的主库信息mysql> show master status;
[root@develop etc]# vim my.cnf# 设置server_id,不能重复,这里设置的是从库的IPserver-id=60# 开启从数据库中继日志,将主数据库的binlog写到relay log中,中继日志以hehe-mysql-relay-bin开头(可自定义)relay_log=hehe-mysql-relay-bin# 设置从数据库为只读权限,防止主从数据不一致read_only=1

这里写图片描述

(3) 重启从库数据库,同步主库数据

# 运行主数据库的备份数据库[root@develop etc]# mysql -uroot -p demo_ds_master_1 < /tmp/demo_ds_master_1.sql# 登录从数据库[root@develop etc]# mysql -uroot -p# 设置该从节点的主节点mysql> change master to master_host='192.168.31.80', master_user='root',master_password='password',master_port=3306,master_log_file='mysql-bin.000001',master_log_pos=154;# 开启主从同步mysql> start slave;# 查看主从同步状态mysql> show slave status\G;# 查看主从线程状态mysql> show processlist\G;

更多相关文章

  1. 发现 developer.android.com 官网的一个单词错误:
  2. 背部如何画好?动漫人物背部画法步骤
  3. android 命令(adb shell)进入指定模拟器或设备
  4. Android--WebView+HTML+Javascript
  5. Android绘制简单折线图的步骤
  6. Android(安卓)Junit 单元测试步骤
  7. Android(安卓)TextToSpeech语音播放文本
  8. Android中LiveData+Room+Paging简单实现步骤
  9. android sdk支持ant自动构建jar步骤

随机推荐

  1. Android中的消息机制-源码分析
  2. Android系统自带样式(android:theme)
  3. Android本地动作
  4. Android(安卓)禁止屏幕旋转和重启Activit
  5. Android(安卓)游戏开发中横竖屏切换问题
  6. Android提供的系统服务之--WindowManager
  7. [转]: 两分钟彻底让你明白Android(安卓)A
  8. Android的控件属性
  9. 驾考一点通 android
  10. 扣丁学堂笔记第05天高级UI组件(一)