MYSQL双主全库同步复制的示例详解
技术百科
黄舟
发布时间:2018-05-10
浏览: 次 环境:
A、B两台服务器分别安装mysql-5.7.18服务端,配置成互为主从同步。
linux系统版本为CentOS7
A服务器ip:192.168.1.7 主机名:test1
B服务器ip:192.168.1.8 主机名:test2
(同一局域网下)
一、准备
1.修改主机名
命令:hostnamectl set-hostname xxx
(查看主机名 命令:hostname)
2.关闭防火墙
1)查看防火墙状态
命令:firewall-cmd --state
结果:running
2)防火墙是运行状态,先关闭防火墙服务
命令:systemctl mask firewalld
3)关闭防火墙
命令:systemctl stop firewalld
4)检查防火墙状态
命令:firewall-cmd --state
结果:not running
3.关闭selinux策略
1)查看selinux运行状态
命令:getenforce
结果:Enforcing
2)永久性关闭(需重启电脑),编辑selinux文件vi /etc/sysconfig/selinux修改SELINUX=disabled
3)为关闭状态
二、配置主服务器(master)从服务器(slave)
1.打开A服务器的my.cnf文件vi /etc/my.cnf,在文件的[mysqld]下添加如下内容
server-id=1 #必须与其他服务器不同,且必须为1~232之间的正整数值
log-bin=mysql-bin log-bin-index=mysql-bin
在B服务器my.cnf文件中的[mysqld]下添加上图内容,只更改server-id值即可。
server-id=2 log-bin=mysql-bin log-bin-index=mysql-bin
2.在A服务器中的mysql安装路径下(rpm安装路径为/var/lib/mysql)创建全库备份文件all.sql。
创建命令:
touch /var/lib/mysql/all.sql
备份命令:
[root@test1 mysql]# mysqldump -uroot -p123 --all-databases > /var/lib/mysql/all.sql
把all.sql文件拷贝到B服务器中的某个路径下(以/var/lib/mysql路径为例)进行恢复。
恢复命令:
[root@test2 /]# mysql -uroot -p123 < /var/lib/mysql/all.sql
3.在A、B服务器的mysql中创建用户用于同步。
创建用户:
mysql> create user 'tongbu'@'%' identified by 'tongbu';
授权:
mysql> grant all on *.* to 'tongbu'@'%';
删除用户:
mysql> drop user '用户名'@'%';
A、B服务器用户创建完成后,测试用户相互是否可以远程登陆mysql。
[root@test1 /]# mysql -utongbu -ptongbu -h192.168.1.8 [root@test2 /]# mysql -utongbu -ptongbu -h192.168.1.7
测试无问题后重启A、B服务器中的mysql服务:[root@test /]# service mysqld restart
4.设置A为主服务器,B为从服务器。
1)查看A服务器mysql中的二进制日志名和偏移量值
命令:mysql> show master status\G
如下图
2)在B服务器中配置连接服务器
mysql> stop slave; mysql> change master to -> master_host='192.168.1.7', -> master_user='tongbu', -> master_password='tongbu', -> master_log_file='mysql-bin.000024', -> master_log_pos=154; mysql> start slave;
mysql> show slave status\G 输入此命令查看Slave_IO_Running和Slave_SQL_Running的值是否为Yes,如下图
5.设置B为主服务器,A为从服务器。
1)查看B服务器mysql中的二进制日志名和偏移量
命令:mysql> show master status\G
2)在A服务器中配置连接服务器。
mysql> stop slave; mysql> change master to -> master_host='192.168.1.8', -> master_user='tongbu', -> master_password='tongbu', -> master_log_file='mysql-bin.000027', -> master_log_pos=154; mysql> start slave; mysql> show slave status\G 查看Slave_IO_Running和Slave_SQL_Running的值是否为Yes
至此两台mysql数据库互为主从同步配置完成。
错误排查:
1.Slave_IO_Running状态错误
检查MySQL> show slave status\G;时,Slave_
IO_Running状态为Connecting错误,出现的原因主要分为三种,需要检查配置:
1)网络不通
2)账户权限配置错误,如密码不对、账号错误、地址错误
3)二进制文件位置不对
2.主备数据冲突或不同造成的异常
主键冲突、表已存在等错误代码如1062,1032,1060等,可以在mysql配置文件指定略过此类异常并继续下条sql同步,这样可以避免很多主从同步的异常中断。打开/etc/ mysql下的my.cnf文件,在[mysqld]后添加如下代码:
slave-skip-errors = 1062,1032,1060
3. 跳过异常恢复同步
mysql >slave stop; mysql >SET GLOBAL sql_slave_skip_counter = 1; mysql >slave start;
# 重启
# 此类
# 如下图
# 跳过
# 三种
# 为例
# 器中
# 运行状态
# 配置文件
# linux
# 数据库
# var
# mysql
# sql
# 两台
相关栏目:
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
AI推广<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
SEO优化<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
技术百科<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
谷歌推广<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
百度推广<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
网络营销<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
案例网站<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
精选文章<?muma echo $count; ?>
】
相关推荐
- Win11怎么设置虚拟内存最佳大小_Windows
- Win11怎么清理C盘系统错误报告_Win11清理
- windows如何禁用驱动程序强制签名_windo
- 如何使用正则表达式提取以编号开头、后跟多个注解的完
- Win11如何设置自动关机 Win11定时关机命令
- Windows10系统怎么查看硬盘健康_Win10
- PHP 中如何在函数内持久修改引用变量所指向的目标
- Mac的访达(Finder)怎么用_Mac文件管理
- Python网页解析流程_html结构说明【指导】
- 如何使用Golang实现错误包装与传递_Golan
- 如何使用Golang开发基础文件下载功能_Gola
- Win10怎样清理C盘阿里旺旺缓存_Win10清理
- Win11更新后变慢怎么办_Win11系统更新后卡
- php怎么捕获异常_trycatch结构处理运行时
- 如何在 PHP 单元测试中正确模拟带方法的图像处理
- LINUX如何查看文件类型_Linux中file命
- Windows10如何更改日期格式_Win10区域
- Win11怎么关闭应用权限_Windows11相机
- 如何在Golang中实现服务熔断与限流_Golan
- Win11文件扩展名怎么显示 Win11查看文件后
- c++协程和线程的区别 c++异步编程模型对比【核
- Windows 10怎么把任务栏放在屏幕上方_Wi
- Mac如何开启夜览模式_Mac护眼模式设置与定时
- 如何在Golang中捕获结构体方法错误_Golan
- 如何在同包不同文件中正确引用 Go 结构体
- 如何有效拦截拼接式恶意域名的垃圾信息
- Python正则表达式实战_模式匹配说明【教程】
- 如何将竖排文本文件转换为横排字符串
- windows 10专注助手怎么关闭_window
- 企业SEO优化选择网站建设模板的技巧
- php下载安装包太大怎么下载_分卷压缩下载方法【教
- php中self::能调用子类重写的方法吗_静态绑
- c++如何使用std::bind绑定函数参数_c+
- Win11怎么设置单手模式_Win11触控键盘布局
- Win11怎么关闭任务栏小图标_Windows11
- Win11怎么恢复出厂设置_Win11重置此电脑保
- Win11怎样激活系统密钥_Win11系统密钥激活
- php控制舵机角度怎么调_php发送pwm信号控制
- Windows 10自带杀毒软件在哪_Window
- 如何在 Go 中创建包含映射(map)的切片(sl
- windows如何备份注册表_windows导出和
- c++中如何使用std::variant_c++1
- Windows10电脑怎么连接蓝牙设备_Win10
- Win11怎么开启专注模式_Windows11时钟
- Win11任务栏天气怎么关闭 Win11隐藏天气小
- 如何使用Golang实现文件追加操作_向已有文件追
- c# 在高并发下使用反射发射(Reflection
- Win11应用商店下载慢怎么办 Win11更改DN
- Windows10如何更改任务栏高度_Win10解
- 如何在 Go 结构体中正确初始化 map 字段

QQ客服