为了解决数据库服务的高可用问题以及负载均衡问题,

1正常情况下可以互为主从,均衡分担数据流量,

2防止数据库服务器在宕机的情况下可以顺利切换到正常的数据库服务器,减少公司的客户流量损失故公司需要搭建数据库集群以备不时之需。

一主一从

首先准备两台已安装好数据库的服务器:分别为A为主服务器和B从服务器

第一步初始化数据库:

1,备份A数据库服务器中所有的数据

[root@es1 ~]#mysql -uroot -p

mysql> reset master    #重置binlog日志

mysql> quit             #退出数据库

[root@es1 ~]# mysqldump -uroot -p --all-databases >/root/test.sql

[root@es1 ~]# ls         #查看备份结果

2在从库B中导入备份的数据

登录B服务器

[root@es2 ~]#mysql -uroot -p

mysql>drop database text;          # 清除所有测试数据

[root@es1 ~]# scp /root/mytest.sql root@192.168.12.118:/root/   #将数据库A中备份的数据上传至B数据库
root@192.168.12.118's password:
mytest.sql 100% 790 418.8KB/s 00:00

mysql -u root -p < /mytest.sql  将数据备份至B数据库,

第二步配置主从数据库

在AB数据库服务器数据一致,binlog还原点一致的情况下进行配置

1:配置主服务器,修改/etc/my.cnf

[root@es1 ~]# vim /etc/my.cnf

[client]
default-character-set=utf8

[mysqld]

character-set-server=utf8
validate_password_policy=0
validate_password_length=6

log-bin=mysql1-bin
server_id=1
binlog_format=MIXED

[root@es1 ~]# systemctl restart mysqld  #重启数据库

2:新建一个用户授予器复制权限允许其从从服务器slave访问

mysql> grant select replication slave on *.* to 'replicater'@'192.168.12.%' identified by 'pwd123';

mysql> show master status\G  #查看主服务器状态

注意 :当在授予权限时出现密码安全问题时

ERROR 1819 (HY000): Your password does not satisfy the current policy requirements

这个就是初始设置密码策略的问题:先查看密码策略

mysql> show variables like 'validate_password%';

解决方案:

mysql> set global validate_password_mixed_case_count=2;

关于 mysql 密码策略相关参数;
)、validate_password_length 固定密码的总长度;
)、validate_password_dictionary_file 指定密码验证的文件路径;
)、validate_password_mixed_case_count 整个密码中至少要包含大/小写字母的总个数;
)、validate_password_number_count 整个密码中至少要包含阿拉伯数字的个数;
)、validate_password_policy 指定密码的强度验证等级,默认为 MEDIUM;
关于 validate_password_policy 的取值:
/LOW:只验证长度;
/MEDIUM:验证长度、数字、大小写、特殊字符;
/STRONG:验证长度、数字、大小写、特殊字符、字典文件;
)、validate_password_special_char_count 整个密码中至少要包含特殊字符的个数;

3 配置从服务器

vi /etc/my.cnf

[client]

[client]
default-character-set=utf8   #设置数据库客户端编码utf8

[mysqld]

character-set-server=utf8     #设置服务端编码utf8
validate_password_policy=0    #密码策略密码复杂度
validate_password_length=6  #密码长度

log-bin=mysql2-bin            #bin-log日志前缀
server_id=2            #数据库服务器主机id
binlog_format=MIXED      #日志格式

[root@es2 ~]# systemctl restart mysqld

[root@es2 ~]# mysql -uroot -p

mysql> change master to master_host='192.168.12.119',     #指定主服务器的ip地址
-> master_user='replicater',                #指定主库授权用户用户名
-> master_password='',               #授权用户密码
-> master_log_file='mysql1-bin.0000001',        #主库bin-log日志
-> master_log_pos=;                   #指定备份节点
Query OK, rows affected, warnings (0.01 sec)

mysql> START SLAVE; //启动复制

[root@es2 ~]# ls -lh /var/lib/mysql/        注 :master.info  ,MASTER 主服务器的设置信息自动存为 master.info 文件

mysql> show slave status\G

无论是一主一从,一主多从,互为主从,其原理都是从库指定主库

注意点,就是主从库必须要一致才能同步,否则会受中继日志和bin-log日志中的pos点的影响而无法同步,配置主从同步时4关闭防火墙。

在配置主从同步可能遇到的问题

报错一

Last_IO_Errno: 2003

Last_IO_Error: error connecting to master 'coolcloud@XXXX:XX' - retry-time: 60  retries: 86400

这个就是防火墙的问题了,关闭防火墙即可

systemctl stop firewalld         关闭防火墙

systemctl disable firewalld     开机不启动防火墙

再重新指定主库

报错二

Last_IO_Errno: 1236

Last_IO_Error: Got fatal error 1236 from master when reading dat

这个问题时因为从库在指定主库配置的时候   master_log_pos=123; #指定pos节点错误导致需查看

解决方案是:

查看主库中的状态
mysql> show master status\G

在从库中

mysql>stop slave

change master to master_host='192.168.12.119',
master_user='replicater',
master_password='pwd123',
master_log_file='mysql1-bin.000006', # 需重新根据主库指定
master_log_pos=154; # 需重根据主库新指定

再启动

mysql>start slave

三:总结(更多报错)

1、须在主、从服务器配置文件 /etc/my.cnf指定
server_id (任意,建议指定不易混淆,有规律,有逻辑的)
binlog日志(一般不指定时日志名称默认为主机名-bin.00000x)
binlog-format="mixed" (指定日志格式,一般为混合格式“mixed”,根据需求而定)
注意: 如果以上没有指定,都会报错错;
2、在主库上面授权:允许用户对主库有复制权限 (replication:复制)
grant replication slave on . to 用户名@"服务器地址" identified by "密码";
必须要授权(从库无法指定主库并复制)
3指定组服务器:(缺一不可)
登录数据库
change master to master_host="主服务器地址"
master_user=“主库上的授权用户“
master_password="授权账户密码“
master_log_file= " 主服务器binlog日志名称“
master_log_pos=”binlog日志偏移量”
最后启动主从复制start slave
查看重服务器状态
Slave_IO_Running: (负责与主机的io通信)
Slave_SQL_Running: (负责自己的slave 数据库进程)
如果不出问题的话,主从同步就部署成功了,

但是这世界并不太平,如果IO线程启动失败
以下是我遇到的问题:
1、主服务器的防火墙没关,导致从服务器同步失败
解决方案:关闭防火墙;
2、主从服务器数据库中数据不一致,(部署主从服务时)
先将不同的部分备份到对方的数据库中保证数据的一致
(不建议删库删库删表)
3、binlog日志偏移量不对,从服务器找不到同步节点
打开主服务器binlog日志文件,找到数据偏移量,重新指定就可以了。
如果是SQL线程启动失败:
我碰到的情况如下:
1、Last_SQL_Error: Error 'Operation DROP USER failed for 'yy'@'192.168.4.10'' on query. Default database: 'alldb'. Query: 'drop user yy@192.168.4.10'
就是没有同步之前的的主库授权用户,在部署完之后发现从库上没有之前主库上的授权用户,然后我撤销了,从库的SQL线程就断了,所以要谨慎操作。
解决办法:一般都不是删除、撤销、当然就是在从库上做同样的授权。
2、Slave failed to initialize relay log info structure from the repository
当出现这种报错时:一般原因是默认中继日志relay_log被服务器上另一个mysql slave占用了;
解决方案:

  1、初始化中继日志, 即删除relay-log.info中继日志文件
  2、在配置文件/etc/my.cnf 中指定中继日志名称
  3、当配置高可用集群时,SQL线程启动失败报错如下
3、Master command COM_REGISTER_SLAVE failed: Access denied for user 'monitor'@'%' (using password: YES) (Errno: 1045)
当出现这种报错时:
  1主服务器的级联复制功能未开启
解决方案:在配置文件中log_slave_updates # 允许级联复制,重起服务,还有是主库必须添加授权用户。
  2还有就是删除授权用户,(不建议)。
综上所述:部署主从同步时对数据库服务器具有高度的统一性。

第三步 使用keepalived实现数据库集群的故障切换功能,实现数据库的高可用

1下载安装keepalived 

安装依赖  yum install -y pcre-devel openssl-devel popt-devel

[root@es1 ~]# wget https://www.keepalived.org/software/keepalived-2.0.15.tar.gz

[root@es1 ~]# tar -axvf  keepalived-2.0.15.tar.gz

[root@es1 ~]# cd  keepalived-2.0.15

[root@es1 keepalived-2.0.15]# ./configure  --prefix=/opt/keepalived

[root@es1 keepalived-2.0.15]#make  && make install

[root@es1 keepalived-2.0.15]#systemctl start keepalived

报错如下

journalctl -xe 查看具体原因   如图因为未找到keepalived配置文件导致

解决方案

[root@es1 ~]# cp -r /opt/keepalived/etc/keepalived /etc/

2keepalived配置:

keepalived配置手册:https://www.keepalived.org/manpage.html

cat keepalived.conf  #注意主从均需安装配置keepalived

vrrp_script chk_mysql_port {     #检测mysql服务是否在运行。有很多方式,比如进程,用脚本检测等等
script "/opt/chk_mysql.sh" #这里通过脚本监测
interval #脚本执行间隔,每2s检测一次
weight - #脚本结果导致的优先级变更,检测失败(脚本返回非0)则优先级 -
fall #检测连续2次失败才算确定是真失败。会用weight减少优先级(-255之间)
rise #检测1次成功就算成功。但不修改优先级
}
vrrp_instance VI_1 {
state MASTER
interface ens33 #指定虚拟ip的网卡接口,不一定是eth0根据ifconfig确定
virtual_router_id #路由器标识,MASTER和BACKUP必须是一致的
priority #定义优先级,数字越大,优先级越高,在同一个vrrp_instance下,MASTER的优先级必须大于BACKUP的优先级。这样MASTER故障恢复后,就可以将VIP资源再次抢回来
advert_int
authentication {
auth_type PASS
auth_pass
}
virtual_ipaddress {
192.168.11.25
}
track_script {
chk_mysql_port
}
}

编写监控脚本

cat /opt/chk_mysql.sh

#!/bin/bash
counter=$(netstat -na|grep "LISTEN"|grep ""|wc -l)
if [ "${counter}" -eq ]
then
/etc/init.d/keepalived stop
else
echo "running..." >> /opt/keepalived-running-info.log
sleep
fi

启动keepalived服务

systemctl start keepalived

mysql主从同步与读写分离的更多相关文章

  1. MySQL主从同步、读写分离配置步骤、问题解决笔记

    MySQL主从同步.读写分离配置步骤.问题解决笔记 根据要求配置MySQL主从备份.读写分离,结合网上的文档,对搭建的步骤和出现的问题以及解决的过程做了如下笔记:       现在使用的两台服务器已经 ...

  2. mysql主从同步+mycat读写分离+.NET程序连接mycat代理

    背景 最近新项目需要用到mysql数据库,并且由于数据量大的原因,故打算采用1主1从(主数据库负责增.删.改操作:从数据库负责查操作)的数据库架构,在实现主从之后还要实现读写分离的代理,在网上搜寻了很 ...

  3. MySQL主从同步、读写分离配置步骤

    现在使用的两台服务器已经安装了MySQL,全是rpm包装的,能正常使用. 为了避免不必要的麻烦,主从服务器MySQL版本尽量保持一致; 环境:192.168.0.1 (Master) 192.168. ...

  4. MySQL主从同步和读写分离的配置

    主服务器:192.168.1.126 从服务器:192.168.1.163 amoeba代理服务器:192.168.1.237 系统全部是CentOS 6.7 1.配置主从同步 1.1.修改主服务器( ...

  5. mysql主从同步加读写分离

    首先主从同步,一旦建立,指定了用户,就不能更改了,否则会有错误.1063 Error 'Duplicate entry '%-test-' for key 'PRIMARY'' on query. D ...

  6. MySQL主从复制技术与读写分离技术amoeba应用

    MySQL主从复制技术与读写分离技术amoeba应用 前言:眼下在搭建一个人才站点,估计流量会非常大,须要用到分布式数据库技术,MySQL的主从复制+读写分离技术.读写分离技术有官方的MySQL-pr ...

  7. Redis系列之(二):Redis主从同步,读写分离

    1. Redis主从同步 Redis支持主从同步.数据可以从主服务器向任意数量的从服务器上同步,同步使用的是发布/订阅机制. 2. 配置主从同步 Mater Slave的模式,从Slave向Maste ...

  8. Redis系列之(二):Redis主从同步,读写分离(转)

    1. Redis主从同步 Redis支持主从同步.数据可以从主服务器向任意数量的从服务器上同步,同步使用的是发布/订阅机制. 2. 配置主从同步 Mater Slave的模式,从Slave向Maste ...

  9. windows mysql主 Linux mysql 从 主从同步,读写分离

    Mysql –master linux-slave 一.My.ini: Server-id=1 relay-log=relay-bin relay-log-index=relay-bin-index ...

随机推荐

  1. python for循环的遍历

    a = "你好啊"for i in range(len(a)): print(i) 解释:"len()" 意思是长度,a中有三个字,所以len(a) = 3,把 ...

  2. libcurl.a 跨平台

    编译成libxxx.a文件后, 通过lipo把多个不同架构的文件合并起来成为一个文件 在build setting 设置  head search path , library search path ...

  3. Cocos Creator LabelAtlas(艺术数字的使用)

    # 艺术数字资源 (LabelAtlas) **艺术数字资源** 是一种用户自定义的资源,它可以用来配置艺术数字字体的属性. ## 创建艺术数字资源 在 **资源管理器** 中右键,可以在如下菜单中找 ...

  4. Maven 学习笔记-maven属性

    Maven有六类属性: 1)内置属性 主要有两个常用内置属性 ${basedir}:表示项目根目录,即包含pom.xml文件的目录: ${version}:表示项目版本: 2)POM属性 ${M2_H ...

  5. oracle中 sql%rowcount 用法

    sql%rowcount用于记录修改的条数,必须放在一个更新或者删除等修改类语句后面执行,select语句用于查询的话无法使用, 当你执行多条修改语句时,按照sql%rowcount 之前执行的最后一 ...

  6. lua tonumber

    [1]应用tonumber函数 local function test(telnum) , )) == ) -- 5000~5999公司预留号码 , ) == ' or isLen or isRese ...

  7. Linux基础命令---tload显示系统负载

    tload tload指令以字符的方式显示当前系统的平均负载情况. 此命令的适用范围:RedHat.RHEL.Ubuntu.CentOS.Fedora.SUSE.openSUSE.   1.语法   ...

  8. 20190410Linux中磁盘管理及LVM(week2day1)

    Linux磁盘管理及LVM讲解(week2_day2)   硬盘接口 从整体的角度上,硬盘接口分为IDE.SATA.SCSI和SAS四种,IDE接口硬盘多用于家用产品中,也部分应用于服务器,SCSI接 ...

  9. git cherry-pick 的使用

    之前和同事在不同的分支开发一个功能的不同模块,在自己分支有用到同事分支的一些实现,被老大告诉用git cherry-pick来搞定! git cherry-pick  能够把另一个分支的一个或多个提交 ...

  10. 关于Oracle配置一些需要注意地方(IIS相关)

    说明:多重复,把各种坑走一次,并知道如何不走坑或者把坑填满,然后再复盘重新走一次,另外,你必须比一般人多付出一些,因为你起步慢了,另 外,你白天的效率不算高,精神状态不好,“试用期”就意味着有淘汰的可 ...