MyCat负载均衡 下篇

 

  之前在 一步一步在Windows中使用MyCat负载均衡 上篇 中已经讲了如何配置出MyCat。下面讲其相关的使用。

五、配置MyCat-eye

对于MyCat监控官网还提供一个MyCat-eye web系统来展示它的运行情况。

MyCat发展到目前的版本,已经不是一个单纯的MySQL代理了,它的后端可以支持MySQL、SQL Server、Oracle、DB2、PostgreSQL等主流数据库,也支持MongoDB这种新型NoSQL方式的存储,未来还会支持更多类型的存储。而在最终用户看来,无论是那种存储方式,在MyCat里,都是一个传统的数据库表,支持标准的SQL语句进行数据的操作,这样一来,对前端业务系统来说,可以大幅降低开发难度,提升开发速度

MyCAT-WEB就是基于mycat的一个性能监控工具,方便大家更有效的使用mycat管理mycat监控mycat,让大家的mycat工作更加高效。

下载:http://dl.mycat.io/

  运行eye之前还需要安 zookeeper,所以先安装 zookeeper ,

  解压到 D:\zookeeper-3.4.6

  到目录conf 下创建 zoo.cfg 文件,默认就是加载这个文件,文件内容 我直接copy 的sample里面的

#zoo.cfg 的内容
# 心跳检查的时间 2秒
tickTime=2000
# 初始化时 连接到服务器端的间隔次数,总时间10*2=20秒
initLimit=10
# ZK Leader 和follower 之间通讯的次数,总时间5*2=10秒
syncLimit=5
# 存储内存中数据库快照的位置,如果不设置参数,更新事务日志将被存储到默认位置。
dataDir=D:\\zookeeper-3.4.6\\zkdata
# 错误日志的存放位置
dataLogDir=F:\\zookeeper-3.4.6\\logs # ZK 服务器端的监听端口
clientPort=2181

  然后 cd 到bin 目录下 执行zkServer.cmd 就启动成功了。

  注意:dataDir  和  dataLogDir 目录不会自动创建,得手动创建才能启动。

  可以用netstat -ano|findstr "2181" 看看是否OK。

  也可以用JPS 查看启动的JAVA 进程的情况,会出现这样

C:\windows\system32>jps
8068
10040 QuorumPeerMain // 这东西是zk的东西,源码有介绍
10556 Jps

  也可以用自带客户端命令 :  zkCli.cmd -server 127.0.0.1:2181

  关于JPS的东西,可以自己去JAVA_HOME\bin 目录下去看,里面很多命令

  安装好zookeeper后,启动MyCat

  windows启动

  启动start.bat

  inux启动

  启动start.sh

  打开mycat-web窗口
  输入网址:http://localhost:8082/mycat/

若没配置好zookeeper会出现下面的页面

当配置好后会出现:

  添加mycat服务,用户名,密码为之前配置的mycat ,123456,保存

  还可以添加对mysql的监控,在mysql管理中添加。

  对SQL的监控我这测试了几天,还没数据,可能哪里配置没有加,所以后面再处理。eye具体的使用资料网上不是很多,需要自己探索。

六、在NET中使用MyCat

由于MyCAT与MySQL协议有些许差异,开发者可能不能够直接使用Oracle官方提供的Mysql.Data(ADO层)来与MyCAT直接连接,因此我们专门为.NET开发者设计了针对MyCAT优化过的ADO层驱动,即Pomelo.Data.MyCat,开发者通过使用MyCatConnection、MyCatCommand类可以实现对MyCAT的连接与查询。下面将展示一个简短的使用MyCat for ADO.NET来向MyCAT写入数据。

  在vs中nuget引入Pomelo.Data.MyCat,但安装报下面的错

  错误提示net框架4.5版本低了,所以调到4.6。

  MyCatConnection, MyCatCommand等内容在命名空间 Pomelo.Data.MyCat 中. 按照常规的ADO.NET开发流程即可实现对MyCAT的操作。

  Pomelo.Data.MyCat的使用与mysql一致:

  封装基础代码:

private static readonly string connectionString = "server=localhost;database=TESTDB;uid=mycat;pwd=123456";

/// <summary>
/// 执行SQL语句,返回影响的记录数
/// </summary>
/// <param name="SQLString">SQL语句</param>
/// <returns>影响的记录数</returns>
public static int ExecuteSql(string SQLString, params MyCatParameter[] cmdParms)
{
using (MyCatConnection connection = new MyCatConnection(connectionString))
{
using (MyCatCommand cmd = new MyCatCommand())
{
try
{
PrepareCommand(cmd, connection, null, SQLString, cmdParms);
int rows = cmd.ExecuteNonQuery();
cmd.Parameters.Clear();
return rows;
}
catch (MyCatException e)
{
throw e;
}
}
}
} /// <summary>
/// 执行查询语句,返回DataSet
/// </summary>
/// <param name="SQLString">查询语句</param>
/// <returns>DataSet</returns>
public static DataSet Query(string SQLString)
{
using (MyCatConnection connection = new MyCatConnection(connectionString))
{
DataSet ds = new DataSet();
try
{
connection.Open();
MyCatDataAdapter command = new MyCatDataAdapter(SQLString, connection);
command.Fill(ds, "ds");
}
catch (MyCatException ex)
{
throw new Exception(ex.Message);
}
return ds;
}
} private static void PrepareCommand(MyCatCommand cmd, MyCatConnection conn, MyCatTransaction trans, string cmdText, MyCatParameter[] cmdParms)
{
if (conn.State != ConnectionState.Open)
conn.Open();
cmd.Connection = conn;
cmd.CommandText = cmdText;
if (trans != null)
cmd.Transaction = trans;
cmd.CommandType = CommandType.Text;//cmdType;
if (cmdParms != null)
{ foreach (MyCatParameter parameter in cmdParms)
{
if ((parameter.Direction == ParameterDirection.InputOutput || parameter.Direction == ParameterDirection.Input) &&
(parameter.Value == null))
{
parameter.Value = DBNull.Value;
}
cmd.Parameters.Add(parameter);
}
}
}

插入数据:

string name = textBox1.Text;
if (string.IsNullOrEmpty(name)) return; StringBuilder strSql = new StringBuilder();
strSql.Append("insert into hotnews(");
strSql.Append("newsname)");
strSql.Append(" values (");
strSql.Append("@newsname)");
MyCatParameter[] parameters = {
new MyCatParameter("@newsname", MyCatDbType.VarChar,100),
};
parameters[0].Value = name; int rows = ExecuteSql(strSql.ToString(), parameters);
if (rows > 0)
{
label1.Text = "添加成功";
}
else
{
label1.Text = "添加失败";
}

查询数据:

 StringBuilder strSql = new StringBuilder();
strSql.Append("select * ");
strSql.Append(" FROM hotnews "); DataSet ds = Query(strSql.ToString());
dataGridView1.DataSource = ds.Tables[0];

七、注意

MyCat 主键ID自增长配置,但保存时还是会出现下面的情况,当还是没指定ID时,插入的ID还是下面的ID会导致插入失败,因此想做分布式最好是将ID设置为自己生成GUID,这样不管哪个库都是全局唯一。若还是想自增型,可以参考园友这篇:MyCat 主键ID自增长配置

需要提醒的是MyCat不仅用于MySQL,而且支持Oracle、DB2、SQL Server、PostgreSQL等

基于心跳的自动故障切换,支持读写分离,支持MySQL主从,以及galera cluster集群

支持单库内部任意join,支持跨库2表join,甚至基于caltlet的多表join

支持数据的多片自动路由与聚合,支持sum,count,max等常用的聚合函数,支持跨库分页

更多功能请参考官网

MyCat官网:http://www.mycat.org.cn/

作者:欢醉 
公众号【一个码农的日常】 1号群: 437802986 2号群: 340250479 
出处:http://zhangs1986.cnblogs.com/ 

MyCat负载均衡 下篇的更多相关文章

  1. 一步一步在Windows中使用MyCat负载均衡 下篇

    之前在 一步一步在Windows中使用MyCat负载均衡 上篇 中已经讲了如何配置出MyCat.下面讲其相关的使用. 五.配置MyCat-eye 对于MyCat监控官网还提供一个MyCat-eye w ...

  2. 一步一步在Windows中使用MyCat负载均衡

    一步一步在Windows中使用MyCat负载均衡 http://www.cnblogs.com/zhangs1986/p/6408981.html   mycat+sqlServer简单demo配置 ...

  3. 一步一步在Windows中使用MyCat负载均衡 上篇

    传统关系型数据库的分布式开发通常需要自己做,不仅耗时耗力而且效果不是很理想,当想快速搭建时,最初想到的是看有没有第三方,网上牛人还是很多的,做得比较好的其中之一Mycat,它是开源的分布式数据库系统, ...

  4. LVS+Keepalived搭建MyCAT高可用负载均衡集群

    LVS+Keepalived 介绍 LVS LVS是Linux Virtual Server的简写,意即Linux虚拟服务器,是一个虚拟的服务器集群系统.本项目在1998年5月由章文嵩博士成立,是中国 ...

  5. Dubbo入门到精通学习笔记(二十):MyCat在MySQL主从复制的基础上实现读写分离、MyCat 集群部署(HAProxy + MyCat)、MyCat 高可用负载均衡集群Keepalived

    文章目录 MyCat在MySQL主从复制的基础上实现读写分离 一.环境 二.依赖课程 三.MyCat 介绍 ( MyCat 官网:http://mycat.org.cn/ ) 四.MyCat 的安装 ...

  6. 「mysql优化专题」高可用性、负载均衡的mysql集群解决方案(12)

    一.为什么需要mysql集群? 一个庞大的分布式系统的性能瓶颈中,最脆弱的就是连接.连接有两个,一个是客户端与后端的连接,另一个是后端与数据库的连接.简单如图下两个蓝色框框(其实,这张图是我在悟空问答 ...

  7. mysql+mycat搭建稳定高可用集群,负载均衡,主备复制,读写分离

    数据库性能优化普遍采用集群方式,oracle集群软硬件投入昂贵,今天花了一天时间搭建基于mysql的集群环境. 主要思路 简单说,实现mysql主备复制-->利用mycat实现负载均衡. 比较了 ...

  8. Mycat - 高可用与负载均衡实现,满满的干货!

    前言 开心一刻 和朋友去吃小龙虾,隔壁桌一个小女孩问妈妈:"妈妈,小龙虾回不了家,它妈妈会不会着急?" 她妈妈愣住了,我扒虾的手停下了,这么善良的问题,怎么下得了口.这是老板急忙过 ...

  9. mycat实现简单的mysql集群负载均衡

    什么是mycat呢? 简单理解为一个MySQL中间件,它支持分流.基于心跳的自动故障切换,支持读写分离,支持mysql主从,基于Nio管理线程的高并发… 详见官网:http://www.mycat.i ...

随机推荐

  1. 希捷硬盘扩容软件-----DiscWizard

    SeagateDiscWizard可为Seagate磁盘驱动器的使用提供便利.DiscWizard可帮助您迅速安装新的磁盘驱动器.并通过安装向导指导您在磁盘驱动器上完毕分区的创建和格式化. DiscW ...

  2. POJ 3278 Catch That Cow(BFS 剪枝)

    题目链接:http://poj.org/problem?id=3278 这几次都是每天的第一道题都挺顺利,然后第二道题一卡一天. = =,今天的这道题7点40就出来了,不知道第二道题在下午7点能不能出 ...

  3. Windows下Nginx的下载安装、启动停止和配置浏览

    前言: 记录一下今天在Windows下载安装Nginx服务器的过程.因为网上关于Nginx的资料都太复杂了,大多数是在Linux下使用的方法. 1.下载 Nginx官网下载地址:http://ngin ...

  4. 谁要的手机用KRKR2 Onscripter 资源打包工具

    本软件能够把你手机上指定文件夹打包为文字冒险游戏资源文件 支持打包 1.Onscripter 的NSA格式 2.吉里吉里2(KRKR2)的XP3.(分2.29曾经的旧版本号和2.30以后新版本号) 3 ...

  5. 在Qtcreator中,KDE的Hello World(安装kdelibs5-dev)

    我刚开始为KDE编程,我面临的问题是我不知道KDE项目的pro文件是什么,我有一个想法. 我还尝试了 file: 库 += -lkdeui 我还是找不到KApplication的问题 代码 main. ...

  6. POJ 3628 Bookshelf 2 0-1背包

    传送门:http://poj.org/problem?id=3628 题目看了老半天,牛来叠罗汉- -|||和书架什么关系啊.. 大意是:一群牛来叠罗汉,求超过书架的最小高度. 0-1背包的问题,对于 ...

  7. ArcGIS 中要素的查询与修改

    转自nimeila的回答 求C# ArcGIS Engine修改选中要素的属性,单要素都行 RLAlterFrm RLalter = new RLAlterFrm(); RLalter.ShowDia ...

  8. Xcode6 模拟器路径

    Xcode6公布后,出现了非常多的变动,功能性的变动,在这里不进行过多的赘述,在WWDC上苹果已经进行了讲述,网上也有非常多文章,这里要介绍的是一些不太easy发现的,但非常重要的小地方.      ...

  9. MySQL建立双向主备复制server配置方法

    1.环境描写叙述 serverA(主) 192.85.1.175 serverB(从) 192.85.1.176 Mysql版本号:5.1.61 系统版本号:System OS:ubuntu 10.1 ...

  10. ios开发视频播放后台下载功能实现 :1,ios播放视频 ,包含基于AVPlayer播放器,2,实现下载,iOS后台下载(多任务同时下载,单任务下载,下载进度,下载百分比,文件大小,下载状态)(真机调试功能正常)

    ABBPlayerKit ios开发视频播放后台下载功能实现 : 代码下载地址:https://github.com/niexiaobo/ABBPlayerKit github资料学习和下载地址:ht ...