mycat实现读写分离_mybatis读写分离实现

mycat实现读写分离_mybatis读写分离实现环境:四台主机,两台mysql做主从:master和slave一台mysql做测试,ip:10.30.162.142一台mycat做读写分离,ip:192.168.122.230客户端访问mycat端的虚拟数据库mycat端虚拟数据库设定如下:user:adminpassword:redhatmycat通过一个真实数据库授过权的用户来对数据库端进行数据的操作,在这个实验中这个用户为m…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

环境:四台主机,两台mysql做主从:master和slave
一台mysql做测试,ip:10.30.162.142
一台mycat做读写分离,ip:192.168.122.230

客户端访问mycat端的虚拟数据库
mycat端虚拟数据库设定如下:
user:admin
password:redhat

mycat通过一个真实数据库授过权的用户来对数据库端进行数据的操作,在这个实验中这个用户为mycatuser,密码为123,能访问的数据库是mycat。
一、实现mysal主从,创建mycat库。
过程略,master:192.168.122.82
slave: 192.168.122.217
二、在master端对mycatuser授权给mycatuser授权,
mysql> GRANT all ON *.* TO "mycatuser"@"%" IDENTIFIED BY "123"; Query OK, 0 rows affected, 1 warning (0.11 sec)
(授权最好是针对mycat端,某个具体的数据库。也可以给所有库所有表,如上)
三、mycat端进行登陆测试

[root@mycat ~]# mysql -umycatuser -p'123' -h 192.168.122.82
mysql: [Warning] Using a password on the command line interface can be insecure.
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 20
Server version: 5.7.17-log Source distribution

Copyright (c) 2000, 2016, Oracle and/or its affiliates. All rights reserved.

Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mycat              |
| mysql              |
| performance_schema |
| sys                |
+--------------------+
5 rows in set (0.00 sec)

四、配置mycat
4.1、安装
MyCat的官方网站:http://www.mycat.org.cn/
(mycat需要jdk环境的支持)
4.2、启动服务
不一定成功,一定要看端口,或者jps命令看java进程

/usr/local/mycat/bin/mycat  start
[root@kvm3 mycat]# ss -antp | grep -E "8066|9066"
LISTEN     0      100         :::9066                    :::*                   users:(("java",pid=18644,fd=72))
LISTEN     0      100         :::8066                    :::*                   users:(("java",pid=18644,fd=76))

4.3、修改配置文件()
server.xml:配置虚拟数据库的用户名和密码,让客户端通过虚拟的用户名和密码进行访问。

#主要修改
[root@mycat ~]# vim  /usr/local/mycat/conf/server.xml
        <user name="admin">
                <property name="password">redhat</property>
                <property name="schemas">game</property>
          </user> 

user name=”admin”指定虚拟用户名
redhat 指定admin用户的密码是redhat
game 指定admin用户相应的schema是game
在server.xml中一套 必须对应schema.xml配置中相应的schemal
否则有语法错误。
server.xml本来有配置如下:

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

但在schema.xml中没有做相应的schema配置,则出现语法错误,这一段不用则必须删掉。
在schema.xml中设置与后端数据库相连的真实用户等。

[root@kvm3 ~]# cat /usr/local/mycat/conf/schema.xml
<?xml version="1.0"?>
<!DOCTYPE mycat:schema SYSTEM "schema.dtd">
<mycat:schema xmlns:mycat="http://io.mycat/">
	<schema name="game" checkSQLschema="false" sqlMaxLimit="100" dataNode="dn1">
	</schema>
	<!-- <dataNode name="dn1$0-743" dataHost="localhost1" database="db$0-743"
		/> -->
	<dataNode name="dn1" dataHost="localhost1" database="mycat" />
	<dataHost name="localhost1" maxCon="1000" minCon="10" balance="1"
			  writeType="0" dbType="mysql" dbDriver="native" switchType="1"  slaveThreshold="100">
		<heartbeat>select user()</heartbeat>
		<writeHost host="hostM1" url="192.168.122.82:3306" user="mycatuser" password="123">
			<readHost host="hostS2" url="192.168.122.217:3306" user="mycatuser" password="123" />
		</writeHost>
	</dataHost>
</mycat:schema>
<schema name="game" checkSQLschema="false" sqlMaxLimit="100" dataNode="dn1">

给server.xml中配置的scheal(game)设置相应的节点为dn1。

<dataNode name="dn1" dataHost="localhost1" database="mycat" />

给dn1设置对应的主机池localhost1(逻辑上的,并不真实存在),对应的真实数据库mycat

<dataHost name="localhost1" maxCon="1000" minCon="10" balance="1"
			  writeType="0" dbType="mysql" dbDriver="native" switchType="1"  slaveThreshold="100">

对该主机池的设置,balance=1表示开启读写分离,默认为0指不开启。

<writeHost host="hostM1" url="192.168.122.82:3306" user="mycatuser" password="123">
			<readHost host="hostS2" url="192.168.122.217:3306" user="mycatuser" password="123" />
		</writeHost>

配置后端真实的数据库用于读写,用mycat端用后端数据库中的真实用户mycatuser和密码去连接后端数据库对mycat库进行读写。
4.4、重启服务
五、客户端进行测试
首先在master端的mycat数据库创建一个表

mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mycat              |
| mysql              |
| performance_schema |
| sys                |
+--------------------+
5 rows in set (0.01 sec)
mysql> use  mycat
Database changed
mysql> create table table1(name int(3),age tinyint);
Query OK, 0 rows affected (0.05 sec)

客户端可以通过虚拟帐号登陆来查看

[root@chenjiaqi ~]# mysql -uadmin -p -h 192.168.122.230 -P 8066
MySQL [(none)]> show databases;
+----------+
| DATABASE |
+----------+
| game     |
+----------+
MySQL [(none)]> show tables from game;
+-----------------+
| Tables_in_mycat |
+-----------------+
| table1          |
+-----------------+

在客户端插入数据

MySQL [game]> insert into table1 values(777,12);
Query OK, 1 row affected (0.02 sec)

master端查看

mysql> use mycat
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A
Database changed
mysql> select * from table1;
+------+------+
| name | age  |
+------+------+
|  777 |   12 |
+------+------+
1 row in set (0.00 sec)
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/182357.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 路由器刷机教程图解_小米路由器刷机教程[通俗易懂]

    路由器刷机教程图解_小米路由器刷机教程[通俗易懂]小米路由器刷机教程小米路由器刷机教程登陆路由器设置页面,刷新官方固件.使用路由器助手,自动检查并自动更新固件.使用u-boot模式,可刷新任何固件.小编温馨提示:你需要先在小米官网下载好相应固件到本地,再进入路由器设置,进入系统升级,选择下载好的固件进行系统升级….其他2016/06/10小米助手刷机教程小米助手刷机教程小米助手的刷机功能只能算是小米MIUI系统升级功能,如果无法开机…

    2022年7月21日
    52
  • scrapy安装步骤_scrapy官网

    scrapy安装步骤_scrapy官网安装scrapy过程中出现各种包安装错误,所以自己一直看教程知道scrapy安装需要准备好各种环境。这些包按照从下到上的顺序下载,lxml这个包按下文教程安装。不想看过多文字和图片的懒人们可看教程视频:http://www.iqiyi.com/w_19rz36pjft.html利用pipinstall命令安装pywin32,pyopenssl.这两个包可在cmd安装成功pip…

    2022年9月18日
    3
  • 设置eclipse代码自动补全功能

    设置eclipse代码自动补全功能1.选择Eclipse菜单条中的Windows菜单下的Preferences项2.在左侧找到“Java”->“Editor”->“ContentAssist”3.在右侧“AutoActivation”项目下找到“AutoactivationtriggersforJava:”(可以看到设置框中默认的只有“.”,这就是为什么默认只有点“.”可以触发自动补全…

    2022年5月31日
    53
  • MySql数据库备份与恢复——使用mysqldump 导入与导出方法总结[通俗易懂]

    MySql数据库备份与恢复——使用mysqldump 导入与导出方法总结[通俗易懂]MySql数据库备份与恢复——使用mysqldump导入与导出方法总结mysqldump客户端可用来转储数据库或搜集数据库进行备份或将数据转移到另一个sql服务器(不一定是一个mysql服务器)。转储包含创建表和/或装载表的sql语句。ps、如果在服务器上进行备份,并且表均为myisam表,应考虑使用mysqlhotcopy,因为可以更快地进行备份和恢复。本文从三部分介绍了mys…

    2022年6月13日
    33
  • 算法-DFA算法-敏感词过滤算法(OC、Swift、Python)「建议收藏」

    前言前段时间,公司的IMSDK想做敏感词过滤,但是后端的小伙伴《比较忙》,在开产品需求会的时候想把敏感词过滤放到前端,让iOS、安卓自己搞,但是前端小伙伴写了一个方法来检测一段文本,耗时一两秒钟而且比较耗CPU,这样肯定不行的,最后后端小伙伴妥协了,把敏感词过滤放到后端了。一般的思路可能是遍历敏感词库,然后把一段文字的敏感词过滤掉,但是针对比较大的词库时(比如我们的敏感词库10万),这样非…

    2022年4月10日
    200
  • Ubuntu下很给力的下载工具

    Ubuntu下很给力的下载工具

    2021年12月9日
    53

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号