使用Mycat实现数据库高可用

1.如何实现数据库高可用?

实现数据库互为主从(双向进行数据库挂载)是实现数据库高可用前提.
在这里插入图片描述
**搭建说明:**实现互为主从的结构,双向进行数据库挂载.配置如下
主机A: 192.168.138.128:3306
从机B: 192.168.138.129:3306
从机B-----主机A进行挂载
主机A------>从机B进行挂载

1.1.1修改主库二进制文件配置

1.修改文件: vim /etc/my.cnf
在这里插入图片描述
2.重启mysql数据库
在这里插入图片描述
3.检查二进制日志文件是否正确
在这里插入图片描述

1.1.2修改从库二进制文件配置

此步骤与修改主库二进制文件相同,重复以上操作

注意:如果启动不了 需要杀进程
ps -ef |grep mysql 查询mysql的服务项
Kill -9 1956 2133 //表示强制删除 1956 2133表示端口号

1.1.3实现数据库主从挂载

1.检查主库的状态
在128中执行命令,此时128充当主库
在这里插入图片描述
主表锁定操作
FLUSH TABLE WITH READ LOCK; //在挂载过程中需要对表进行锁定,不允许读写操作

2.从库挂载主库

/*挂载指令:
change master to 主机IP 主机端口号 用户名 密码
二进制日志文件名称 文件位置
*/
CHANGE MASTER TO MASTER_HOST=“192.168.138.128”,
MASTER_PORT=3306,
MASTER_USER=“root”,
MASTER_PASSWORD=“root”,
MASTER_LOG_FILE=“mysql-bin.000001”,
MASTER_LOG_POS=120;

#开启主从服务
START SLAVE;

#检查主从状态
SHOW SLAVE STATUS;

3.检查从库状态
在这里插入图片描述
主表解除锁定操作
UNLOCK TABLES;

#如果主从同步搭建完成,测试
#如果程序报错 没有2个yes 则根据日志修改
STOP SLAVE;

4.检查主库的状态
在129中执行命令,此时129充当主库
在这里插入图片描述
主表锁定操作
FLUSH TABLE WITH READ LOCK; //在挂载过程中需要对表进行锁定,不允许读写操作

5.从库挂载主库

/*挂载指令:
change master to 主机IP 主机端口号 用户名 密码
二进制日志文件名称 文件位置
*/
CHANGE MASTER TO MASTER_HOST=“192.168.138.129”,
MASTER_PORT=3306,
MASTER_USER=“root”,
MASTER_PASSWORD=“root”,
MASTER_LOG_FILE=“mysql-bin.000001”,
MASTER_LOG_POS=120;

#开启主从服务
START SLAVE;

#检查主从状态
SHOW SLAVE STATUS;

6.检查从库状态
在这里插入图片描述
主表解除锁定操作
UNLOCK TABLES;

1.2实现数据库高可用

1.2.1Mycat介绍
在这里插入图片描述
1.2.2上传文件部署项目

上传文件/解压

tar -xvf Mycat-server-1.7.0-DEV-20170416134921-linux.tar.gz

在这里插入图片描述
1.2.3编辑server.xml文件
定义用户信息

<user name="root">
	<property name="password">root</property>
	<!--与schema.xml中的配置相同 注意数据库的大小写-->
	<property name="schemas">jtdb</property>
</user>

<user name="user">
	<property name="password">user</property>
	<property name="schemas">jtdb</property>
	<property name="readOnly">true</property>
</user>

1.2.4编辑schema.xml文件

<?xml version="1.0"?>

<mycat:schema xmlns:mycat=“http://io.mycat/”>

<!--name属性是自定义的  dataNode表示数据库的节点信息-->
<schema name="jtdb" checkSQLschema="false" sqlMaxLimit="100" dataNode="jtdb"/>

<!--定义节点名称/节点主机/数据名称-->
<dataNode name="jtdb" dataHost="localhost1" database="jtdb" />
	<!--参数介绍-->
	<!--balance 0表示所有的读操作都会发往writeHost主机 -->  
	<!--1表示所有的读操作发往readHost和闲置的主节点中-->
	<!--writeType=0 所有的写操作都发往第一个writeHost主机-->	
	<!--writeType=1 所有的写操作随机发往writeHost中-->
	<!--dbType 表示数据库类型 mysql/oracle-->
	<!--dbDriver="native"  固定参数 不变-->
	<!--switchType=-1 表示不自动切换, 主机宕机后不会自动切换从节点-->
	<!--switchType=1  表示会自动切换(默认值)如果第一个主节点宕机后,Mycat会进行3次心跳检测,如果3次都没有响应,则会自动切换到第二个主节点-->
	<!--并且会更新/conf/dnindex.properties文件的主节点信息 localhost1=0 表示第一个节点.该文件不要随意修改否则会出现大问题-->
<dataHost name="localhost1" maxCon="1000" minCon="10" balance="1"
		  writeType="0" dbType="mysql" dbDriver="native" switchType="1"  slaveThreshold="100">
	<heartbeat>select 1</heartbeat>

	<!--配置第一台主机主要进行写库操作,在默认的条件下Mycat主要操作第一台主机在第一台主机中已经实现了读写分离.因为默认写操作会发往137的数据库.读的操作默认发往141.如果从节点比较忙,则主节点分担部分压力.
	-->
	<writeHost host="hostM1" url="192.168.138.128:3306" user="root" password="root">
		<!--读数据库-->
		<readHost host="hostS1" url="192.168.138.129:3306" user="root" password="root" />
		
	</writeHost>

		<!--定义第二台主机 由于数据库内部已经实现了双机热备.-->
		<!--Mycat实现高可用.当第一个主机137宕机后.mycat会自动发出心跳检测.检测3次.-->
		<!--如果主机137没有给Mycat响应则判断主机死亡.则回启东第二台主机继续为用户提供服务.-->
		<!--如果137主机恢复之后则处于等待状态.如果141宕机则137再次持续为用户提供服务.-->
		<!--前提:实现双机热备.-->
	
	<writeHost host="hostM2" url="192.168.138.129:3306" user="root" password="root">
		<readHost host="hostS1" url="192.168.138.128:3306" user="root" password="root" />
	</writeHost>
</dataHost>

</mycat:schema>
文件修改完成后,将文件上传到服务器中.

1.2.5Mycat启动测试
./mycat console 打印控制台信息
start 启动Mycat
stop 停止
restart 重启
status 状态
dump 备份
[root@localhost bin]# ./mycat start
Starting Mycat-server…
[root@localhost bin]# ./mycat console
Running Mycat-server…
Mycat-server is already running.
[root@localhost bin]# ./mycat status
Mycat-server is running (14774).
[root@localhost bin]# ./mycat dump
Dumping Mycat-server…
Dumped Mycat-server.
[root@localhost bin]#

1.2.6关于mycat报错说明
如果程序启动报错,需要进入log日志目录中.检查报错信息.
cat /more/less/tail等命令

一般都是配置文件报错. 如果报错信息中出现utf-8报错.则是因为中文注释的问题.需要将配置文件中的中文删除即可.

以上是本人以前学习的资料以及自己的总结,希望对同学们有帮助!

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值