我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Linux-Mycat-安装配置

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Linux-Mycat-安装配置

MyCat介绍

面向企业应用开发的“大数据库集群”支持事务、ACID、可以替代Mysql的加强版数据库
可以视为“Mysql”集群的企业级数据库,用来替代昂贵的Oracle集群
融合内存缓存技术、Nosql技术、HDFS大数据的新型SQL Server
结合传统数据库和新型分布式数据仓库的新一代企业级数据库产品
MyCat的目标是:
低成本的将现有的单机数据库和应用平滑迁移到“云”端,解决数据存储和业务规模迅速增长情况下的数据瓶颈问题。


MyCat的关键特性

支持 SQL 92标准
支持Mysql集群,可以作为Proxy使用
支持JDBC连接ORACLE、DB2、SQL Server,将其模拟为MySQL  Server使用
支持galera for mysql集群,percona-cluster或者mariadb cluster,提供高可用性数据分片集群
自动故障切换,高可用性
支持读写分离,支持Mysql双主多从,以及一主多从的模式
支持全局表,数据自动分片到多个节点,用于高效表关联查询
支持独有的基于E-R 关系的分片策略,实现了高效的表关联查询
多平台支持,部署和实施简单


MyCat架构

Linux-Mycat-安装配置

Mycat高可用参数

有关Mycat高可用的schema.xml配置参数相关说明:
balance属性 
负载均衡类型,目前的取值有如下4种。 

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

* balance="1" : 全部的readHost与stand by writeHost都参与select语句的负载均衡,简而言之,当为双主双从模式(M1->S1,M2->S2,并且M1与M2互为主备)时,在正常情况下,M2、S1和S2都参与select语句的负载均衡。 

* balance="2" : 所有的读操作都随机地在writeHost、readHost上分发。 

* balance="3" : 所有的读请求都随机分发到writeHost对应的readHost上执行,writeHost不负担读压力。
writeType属性 
负载均衡类型目前的取值有两种。 

* writeType="0" : 所有的写操作都发送到配置的第1个writeHost上,writeHost挂了则切到writeHost2上,重新恢复writeHost1节点后,不会再切回来,还是以writeHost2为准,切换记录在配置文件dnindex.properties中。 

* writeType="0" : 所有的写操作都随机地发送到配置的writeHost上,Mycat1.5版本以后不再推荐使用该值。
switchType属性 

* switchType="-1" : 表示不自动切换。 

* switchType="1" : 为默认值(或为0),表示自动切换。 

* switchType="2" : 表示基于MySQL主从同步的状态决定是否切换,心跳语句如下:
show slave status

switchType="3" : 表示基于 MySQL Galary Cluster的切换机制,心跳语句如下:
show status like 'wsrep%'


MySQL主从读写分离环境
项目 Mycat MySQL-master MySQL-slaveA MySQL-slaveB
IP 192.168.32.149 192.168.32.146 192.168.32.129 192.168.32.130
Port 8066/9066 3306 3306 3306


Java安装包:
http://www.oracle.com/technetwork/java/javase/downloads/jdk10-downloads-4416644.html
Mycat安装包:
http://www.mycat.io/

解压缩至目录/usr/local/

#cd /usr/local/

#tar zxf jdk-10.0.1_linux-x64_bin.tar.gz
#tar zxf Mycat-server-1.6-RELEASE-20161028204710-linux.tar.gz

#/usr/local/mycat/bin/mycat start
#ss -lnt | grep mycat

#cd mycat/conf/

先配置server.xml

×××为逻辑库

#vim server.xml

<user name="root">
<property name="password">123456</property>
<property name="schemas">TESTDB,aaa,bbb</property>

配置schema

#vim schema.xml

<?xml version="1.0"?>
<!DOCTYPE mycat:schema SYSTEM "schema.dtd">
<mycat:schema xmlns:mycat="http://io.mycat/">

    &lt;!-- 逻辑库配置 DB1,DB2是逻辑库并不是真的数据库--&gt; 
     &lt;schema name="TESTDB" checkSQLschema="false" sqlMaxLimit="100" dataNode="dn1"/&gt;
     &lt;schema name="aaa" checkSQLschema="false" sqlMaxLimit="100" dataNode="dn2"/&gt;
     &lt;schema name="bbb" checkSQLschema="false" sqlMaxLimit="100" dataNode="dn3"/&gt;

     &lt;!-- &lt;dataNode name="dn1$0-743" dataHost="localhost1" database="db$0-743"
             /&gt; --&gt;

<!-- 节点配置 db1,db2,db3才是真正的数据库(需要在mysql主上创建) -->
<dataNode name="dn1" dataHost="localhost1" database="db1" />
<dataNode name="dn2" dataHost="localhost1" database="db2" />
<dataNode name="dn3" dataHost="localhost1" database="db3" />
<!--<dataNode name="dn4" dataHost="sequoiadb1" database="SAMPLE" />

<dataNode name="jdbc_dn1" dataHost="jdbchost" database="db1" />
<dataNode name="jdbc_dn2" dataHost="jdbchost" database="db2" />
<dataNode name="jdbc_dn3" dataHost="jdbchost" database="db3" /> -->

  &lt;!-- 读写分离的配置(blance="1") --&gt; 

<dataHost name="localhost1" maxCon="1000" minCon="10" balance="1"
writeType="0" dbType="mysql" dbDriver="native" switchType="1" slaveThreshold="100">
<heartbeat>select user()</heartbeat>
<!-- can have multi write hosts -->
<!--注意:writeHost host=是主mysql readHost host=从mysql -->
<writeHost host="hostM1" url="192.168.32.146:3306" user="root"password="123456">
<!-- can have multi read hosts -->
<!-- 可以在这配置它对应的多个读库 -->
<readHost host="hostS2" url="192.168.32.129:3306" user="root" password="123456" />
</writeHost>
<!--主故障,顶替写节点,主正常是分担读压力-->
<writeHost host="hostS1" url="localhost:3316" user="root"
password="123456" />


#/usr/local/mycat/bin/mycat restart
#mysql -u root -p123456 -P 8066 -h 127.0.0.1


mysql> show databases;
+----------+
| DATABASE |
+----------+
| TESTDB |
| aaa |
| bbb |
+----------+
3 rows in set (0.00 sec)


mysql> use aaa;
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> show tables;
+---------------+
| Tables_in_db2 |
+---------------+
| bbb |
+---------------+
1 row in set (0.00 sec)


mysql> insert into bbb values(1,'lijialiang');
Query OK, 1 row affected (0.04 sec)

MySQL-slaveB:


mysql> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| db1 |
| db2 |
| db3 |
| mysql |
| performance_schema |
| sys |
+--------------------+
7 rows in set (0.10 sec)


mysql> use db2;
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> show tables;
+---------------+
| Tables_in_db2 |
+---------------+
| bbb |
+---------------+
1 row in set (0.01 sec)


mysql> select * from bbb;
+------+------------+
| id | name |
+------+------------+
| 1 | lijialiang |
+------+------------+
1 rows in set (0.00 sec)

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Linux-Mycat-安装配置

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

MyCat教程三:安装及配置介绍

一、安装MyCat 1.安装准备环境 1.1 安装JDK   因为MyCat是java开发的,所以需要java虚拟机环境,在Linux节点中安装JDK是必须的。 1.2 放开相关端口   在主从节点上都放开对端口3306的访问,或者直接关闭防火墙。 # 临时
MyCat教程三:安装及配置介绍
2015-06-08

Linux下安装配置maven

一、安装以及配置maven 1.下载maven安装包 首先需要切换到自己需要安装的目录 我自己是把配置都放到了:/home/sunny 路径下 cd /home/sunny 下载maven安装包:wget https://archive.a
2023-08-19

linux 安装配置 postfix+p

首先介绍下环境与提前准备。            postfix      192.168.6.121    1.在自己的域名服务商添加 域名 与A记录,我的是内部测试也就在自己的内部DNS 上添加了 以下记录               
2023-01-31

Linux mysql安装配置教程 linux中mysql最新安装配置教程

本篇文章提供了在 linux 系统中安装和配置 mysql 数据库的详细教程。该教程适用于希望在 linux 服务器或个人计算机上运行 mysql 数据库的用户,涵盖从安装 mysql 软件包到配置服务器和数据库实例的各个步骤。通过遵循本教
Linux mysql安装配置教程 linux中mysql最新安装配置教程
2024-10-17

Linux(Centos 7) 安装配置 redis

Linux(Centos 7)  安装配置 redis 1.下载reids ( 官网:redis.io,中文网:www.redis.cn)   我下载的是5.0.8版本的 第二步:安装解压(到opt目录) tar -zxvf redis-5.0.8.tar.g
Linux(Centos 7)  安装配置 redis
2018-05-26

Linux下如何安装配置Typora

这篇文章主要介绍Linux下如何安装配置Typora,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!Typora是一款轻便简洁的Markdown编辑器,支持即时渲染技术,这也是与其他Markdown编辑器最显著的区别,
2023-06-28

Linux下Hbase安装配置教程

目录Linux下Hbase安装配置1. Hbase安装包下载2. 安装3. 配置java_HOME环境变量4. (可选)配置hbase-site.xml5. 启动HbasePhoenix安装和配置1. Hbase安装包下载2. 安装
2022-06-04

linux下rsync的安装和配置

这篇文章主要讲解了“linux下rsync的安装和配置”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“linux下rsync的安装和配置”吧!Redhat中安装rsync1、 首先在服务端和
2023-06-09

Linux下如何安装配置composer

这篇文章主要介绍了Linux下如何安装配置composer,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。Composer 是 PHP5.3以上 的一个依赖管理工具。它允许你声
2023-06-28

Linux下怎么安装配置V2Ray

这篇文章主要介绍“Linux下怎么安装配置V2Ray”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Linux下怎么安装配置V2Ray”文章能帮助大家解决问题。Linux下安装v2Ray具体步骤修改权
2023-06-28

编程热搜

目录