mysql中间件mycat怎么用

62次阅读
没有评论

共计 4211 个字符,预计需要花费 11 分钟才能阅读完成。

自动写代码机器人,免费开通

这篇文章将为大家详细讲解有关 mysql 中间件 mycat 怎么用,丸趣 TV 小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

一,什么是 mycat

一个彻底开源的,面向企业应用开发的大数据库集群

支持事务、ACID、可以替代 MySQL 的加强版数据库

一个可以视为 MySQL 集群的企业级数据库,用来替代昂贵的 Oracle 集群

一个融合内存缓存技术、NoSQL 技术、HDFS 大数据的新型 SQL Server

结合传统数据库和新型分布式数据仓库的新一代企业级数据库产品

一个新颖的数据库中间件产品

以上是官方说明。其实就是数据库的连接池。mysql proxy 也是一种连接池,但是效率很低。

二,mycat 安装

1,下载地址 mycat

http://dl.mycat.io/

2,安装 mycat

# tar zxvf Mycat-server-1.6-RELEASE-20161028204710-linux.tar.gz -C /usr/local/

三,配置 mycat

1,配置 server.xml

# vim /usr/local/mycat/conf/server.xml // 添加以下内容
  user name= user  //mycat 用户名
  property name= password user /property  //mycat 密码
  property name= schemas mytest /property  //mycat 虚拟数据库名
  property name= readOnly true /property  // 只读
  /user 
  user name= tankzhang 
  property name= password admin /property 
  property name= schemas mytest /property 
  /user

在这里要注意,默认的虚拟数据名是 TESTDB,如果 schema.xml 里面没有配置 testdb,那就要把 testdb 改成 schema.xml 里面有的虚拟数据名。这里定义的用户名和密码,虚拟数据库名,并不是在 mysql 中真实存在的。

2,配置 schema.xml

# cat schema.xml
 ?xml version= 1.0 ? 
 !DOCTYPE mycat:schema SYSTEM  schema.dtd 
 mycat:schema xmlns:mycat= http://io.mycat/ 
 schema name= mytest  checkSQLschema= false  sqlMaxLimit= 100  dataNode= my1  / // 定义虚拟数据库名 mytest
 dataNode name= my1  dataHost= test1  database= test  /  // 真实数据库名 test
 dataHost name= test1  maxCon= 1000  minCon= 10  balance= 1  writeType= 0  dbType= mysql  dbDriver= native   
 heartbeat select user() /heartbeat 
 writeHost host= hostM1  url= 192.168.5.213:3306  user= tank  password= 123456    // 真实数据库的连接方式
  readHost host= hostS1  url= 192.168.5.214:3306  user= tank  password= 123456  /  // 同上
  /writeHost 
  /dataHost 
 /mycat:schema

mycat 的配置参数,相当的多。重点说一下 balance= 1 与 writeType= 0

a. balance 属性负载均衡类型,目前的取值有 4 种:

1. balance= 0 , 不开启读写分离机制,所有读操作都发送到当前可用的 writeHost 上。

2. balance= 1,全部的 readHost 与 stand by writeHost 参与 select 语句的负载均衡,简单的说,当双主双从模式 (M1 – S1,M2- S2,并且 M1 与 M2 互为主备),正常情况下,M2,S1,S2 都参与 select 语句的负载均衡。

3. balance= 2,所有读操作都随机的在 writeHost、readhost 上分发。

4. balance= 3,所有读请求随机的分发到 wiriterHost 对应的 readhost 执行,writerHost 不负担读压力,注意 balance=3 只在 1.4 及其以后版本有,1.3 没有。

b. writeType 属性

负载均衡类型,目前的取值有 3 种:

1. writeType= 0 , 所有写操作发送到配置的第一个 writeHost,第一个挂了切到还生存的第二个

writeHost,重新启动后已切换后的为准,切换记录在配置文件中:dnindex.properties .

2. writeType= 1,所有写操作都随机的发送到配置的 writeHost。

3. writeType= 2,没实现。

具体参数:http://mycat.io/document/Mycat_V1.6.0.pdf

3,配置主从服务器,就不在这儿说了,博客中有

4,添加真实用户

grant all privileges on test.* to tank@ 192.168.%  identified by  123456 
flush privileges

在 213,214 二台机器上添加用户。

5,测试真实用户连接,确保 schema.xml 中配置的真实用户,能连上真实的数据库。注意防火墙。

四,启动 mycat

1,常用参数
./mycat start 启动
./mycat stop 停止
./mycat console 前台运行
./mycat restart 重启服务
./mycat pause 暂停
./mycat status 查看启动状态

2,启动,并查看 mycat

# ./mycat start
Starting Mycat-server...
# netstat -tpnl |grep 8066
tcp 0 0 :::8066 :::* LISTEN 31728/java 
# ./mycat status
Mycat-server is running (31726).

五,测试读写分离

# mysql -u tankzhang -p -P 8066 -h 127.0.0.1 // 一定要带上 127.0.0.1
Enter password:
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 1
Server version: 5.6.29-mycat-1.6-RELEASE-20161028204710 MyCat Server (OpenCloundDB)
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 |
+----------+
| mytest | // 虚拟数据库
+----------+
1 row in set (0.00 sec)
mysql  use mytest;
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A
mysql  CREATE TABLE IF NOT EXISTS `user` ( -  `id` int(11) unsigned NOT NULL DEFAULT  0  COMMENT  ID ,
 -  `name` varchar(20) NOT NULL DEFAULT   COMMENT  姓名 ,
 -  `create_time` int(10) NOT NULL DEFAULT  0  COMMENT  创建时间 ,
 -  PRIMARY KEY (`id`)
 -  ) ENGINE=MyISAM DEFAULT CHARSET=utf8 AUTO_INCREMENT=1 ;
Query OK, 0 rows affected (0.08 sec)
Database changed
mysql  show tables;
+----------------+
| Tables_in_test |
+----------------+
| user |
+----------------+
1 row in set (0.01 sec)
mysql  INSERT INTO `user` (`id` ,`name`)VALUES ( 1 ,  tank 
Query OK, 1 row affected (0.00 sec)
mysql  select * from user; // 修改从数据库的 user 表中的 name, 会发现读是从从数据库读取的
+----+-----------+-------------+
| id | name | create_time |
+----+-----------+-------------+
| 1 | tankzhang | 0 |
+----+-----------+-------------+
1 row in set (0.01 sec)

关于“mysql 中间件 mycat 怎么用”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

向 AI 问一下细节

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-12-16发表,共计4211字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)