mysql 中间件mycat安装与使用方法实例分享

本文主要和大家分享mysql 中间件mycat安装与使用方法实例,mycat是mysql中间件,前身是阿里大名鼎鼎的cobar,cobar在开源了一段时间后,不了了之。于是mycat扛起了这面大旗,在大数据时代,其重要性愈发彰显。这篇文章主要是mycat的入门部署。

一,什么是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 //添加以下内容   //mycat用户名 user //mycat密码 mytest  //mycat虚拟数据库名 true  //只读   admin mytest 

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

2,配置schema.xml

# cat schema.xml//定义虚拟数据库名mytest //真实数据库名testselect user() //真实数据库的连接方式  //同上  

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 没有。

代码小浣熊 代码小浣熊

代码小浣熊是基于商汤大语言模型的软件智能研发助手,覆盖软件需求分析、架构设计、代码编写、软件测试等环节

代码小浣熊 396 查看详情 代码小浣熊

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 startStarting Mycat-server...# netstat -tpnl |grep 8066tcp 0 0 :::8066 :::* LISTEN 31728/java # ./mycat statusMycat-server is running (31726).

五,测试读写分离

# mysql -u tankzhang -p -P 8066 -h 127.0.0.1 //一定要带上127.0.0.1Enter password:Welcome to the MySQL monitor. Commands end with ; or g.Your MySQL connection id is 1Server 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 itsaffiliates. Other names may be trademarks of their respectiveowners.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 namesYou can turn off this feature to get a quicker startup with -Amysql> 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 changedmysql> 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)

六,小结

mycat支持 mysql的分表,分片等等,但是不建议使用。mycat支持的集群不多,如果能配合mha使用就比较牛B了。

相关推荐:

Mycat读写分离在MySQL主从复制基础上实现的实例

如何进行MyCat的配置

MySQL分布式集群之MyCAT(一)简单介绍

以上就是mysql 中间件mycat安装与使用方法实例分享的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/786601.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月26日 12:09:12
下一篇 2025年11月26日 12:14:20

相关推荐

  • 如何在 VS Code 中解决折叠代码复制问题?

    解决 VS Code 折叠代码复制问题 在 VS Code 中使用折叠功能可以帮助组织长代码,但使用复制功能时,可能会遇到只复制可见部分的问题。以下是如何解决此问题: 当代码被折叠时,可以使用以下简单操作复制整个折叠代码: 按下 Ctrl + C (Windows/Linux) 或 Cmd + C …

    2025年12月24日
    000
  • 网络进化!

    Web 应用程序从静态网站到动态网页的演变是由对更具交互性、用户友好性和功能丰富的 Web 体验的需求推动的。以下是这种范式转变的概述: 1. 静态网站(1990 年代) 定义:静态网站由用 HTML 编写的固定内容组成。每个页面都是预先构建并存储在服务器上,并且向每个用户传递相同的内容。技术:HT…

    2025年12月24日
    000
  • 为什么多年的经验让我选择全栈而不是平均栈

    在全栈和平均栈开发方面工作了 6 年多,我可以告诉您,虽然这两种方法都是流行且有效的方法,但它们满足不同的需求,并且有自己的优点和缺点。这两个堆栈都可以帮助您创建 Web 应用程序,但它们的实现方式却截然不同。如果您在两者之间难以选择,我希望我在两者之间的经验能给您一些有用的见解。 在这篇文章中,我…

    2025年12月24日
    000
  • 姜戈顺风

    本教程演示如何在新项目中从头开始配置 django 和 tailwindcss。 django 设置 创建一个名为 .venv 的新虚拟环境。 # windows$ python -m venv .venv$ .venvscriptsactivate.ps1(.venv) $# macos/linu…

    2025年12月24日
    000
  • 粘性定位怎么用

    粘性定位怎么用,需要具体代码示例 在前端开发中,粘性定位是一种常用的布局技术,可以将元素固定在页面的某个位置,当页面滚动时,该元素将会保持在固定位置不动,给用户带来更好的视觉体验。本文将介绍粘性定位的用法,并提供具体的代码示例。 一、CSS实现粘性定位CSS的position属性可以用来实现粘性定位…

    2025年12月24日 好文分享
    000
  • 使用绝对定位来定位元素参数的方法介绍

    如何使用绝对定位的参数进行定位? 随着网页设计的发展,对元素位置的精确控制成为了设计师和开发者追求的目标。而绝对定位(Absolute Positioning)提供了一种让元素根据其父元素进行定位的方法。在这篇文章中,我将向大家介绍如何使用绝对定位的参数进行定位,并提供一些具体的代码示例。 理解绝对…

    2025年12月24日
    000
  • 在CI框架中如何引入外部CSS样式表?

    CI框架中如何使用外部CSS样式,需要具体代码示例 引言:CI(CodeIgniter) 是一个轻量级的PHP开发框架,被广泛用于构建Web应用程序。在开发Web应用程序时,外部CSS样式起着至关重要的作用,可以帮助我们美化页面、提升用户体验。本文将介绍在CI框架中如何使用外部CSS样式,并提供具体…

    2025年12月24日
    000
  • 学习CSS框架必不可少:从基础开始掌握CSS框架的使用方法

    初学者必备:从零开始学习CSS框架的使用方法,需要具体代码示例 引言:随着Web设计和开发的快速发展,CSS框架已经成为每个前端工程师必备的工具。使用CSS框架可以大大提高开发效率,简化页面布局和样式的编写,同时还能够让网站呈现出更加统一和美观的外观。本文将介绍如何从零开始学习CSS框架的使用方法,…

    2025年12月24日
    000
  • 深入剖析CSS高级选择器的应用技巧

    深入探讨CSS高级选择器的使用方法,需要具体代码示例 CSS作为一种样式表语言,不仅可以用来美化网页的外观,还可以让我们更好地对网页元素进行控制和选择。在CSS中,除了基础的选择器(如元素选择器、类选择器和ID选择器)外,还有一些高级选择器,可以根据更复杂的条件来选择特定的元素。本文将深入探讨CSS…

    2025年12月24日
    000
  • 掌握id选择器的语法使用方法

    学习id选择器的语法使用方法,需要具体代码示例 在学习CSS(层叠样式表)时,了解和掌握选择器的语法和使用方法是非常重要的。其中,id选择器是一种常用的选择器,它允许我们通过给HTML元素添加id属性,通过该属性来选择特定的元素并对其应用样式。 首先,让我们来了解一下id选择器的语法。在CSS中,使…

    2025年12月24日 好文分享
    000
  • CSS行内元素与块级元素的使用场景和方法详解

    CSS行内元素和块级元素详解:探索它们的应用场景和使用方法 在CSS中,元素可以根据其显示特性分为两种类型:行内元素和块级元素。对于网页开发者来说,理解这两个概念非常重要,因为它们的不同特性决定了它们的应用场景和使用方法。 行内元素行内元素是指在网页中只占据一行的元素。常见的行内元素有、、、等。行内…

    2025年12月24日
    000
  • CSS如何实现任意角度的扇形(代码示例)

    本篇文章给大家带来的内容是关于CSS如何实现任意角度的扇形(代码示例),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 扇形制作原理,底部一个纯色原形,里面2个相同颜色的半圆,可以是白色,内部半圆按一定角度变化,就可以产生出扇形效果 扇形绘制 .shanxing{ position:…

    2025年12月24日
    000
  • css中的float属性的一些使用方法

    本篇文章给大家带来的内容是关于css中的float属性的一些使用方法,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 在CSS浮动中,元素浮动后将自动转为块级元素,可以移动到当前行的左侧或右侧,切记没有浮动到中间的概念,所以记住只会浮动到两侧。 float:left float:ri…

    2025年12月24日
    000
  • CSS中zoom属性或overflow:auto的使用方法

    这次给大家带来CSS中zoom属性或overflow:auto的使用方法,使用CSS中zoom属性或overflow:auto的注意事项有哪些,下面就是实战案例,一起来看一下。 前言 其实在CSS中的Zoom这个属性一般不为人知,甚至有些CSS手册中都查询不到。其实Zoom属性是IE浏览器的专有属性…

    好文分享 2025年12月24日
    000
  • CSS3的linear-gradient线性渐变使用方法

    这次给大家带来CSS3的linear-gradient线性渐变使用方法,使用CSS3的linear-gradient线性渐变注意事项有哪些,下面就是实战案例,一起来看一下。 在商城项目中,购物车是一个很重要的功能。其中最常见的是购物车中对库存的“+-”操作,包括抢购后面有很多算法。但是作为前端来说,…

    2025年12月24日
    000
  • CSS的Word中的列表详解

    在word中,列表也是使用频率非常高的元素。在css中,列表和列表项都是块级元素。也就是说,一个列表会形成一个块框,其中的每个列表项也会形成一个独立的块框。所以,盒模型中块框的所有属性,都适用于列表和列表项。 除此之外,列表还有 3 个特有的属性 list-style-type、list-style…

    2025年12月24日
    000
  • 详解css中border-image的使用方法

    border-image-source 属性设置边框的图片的路径[none | ] p { border: 20px solid #000; border-image-source: url(border.png);} border-image-slice 属性图片边框向内偏移[ | ](1,4) …

    2025年12月23日
    000
  • html5能否禁用搜索框自动填充_html5autocomplete关闭方法【教程】

    禁用HTML5搜索框自动填充有五种方法:一、设autocomplete=”off”;二、随机化name/id值;三、用无效autocomplete值如”nope”;四、JS动态设置autocomplete;五、设autocomplete=”…

    2025年12月23日
    000
  • 如何查看编写的html_查看自己编写的HTML文件效果【效果】

    要查看HTML文件的浏览器渲染效果,需确保文件以.html为扩展名保存、用浏览器直接打开、利用开发者工具调试、必要时启用本地HTTP服务器、或使用编辑器实时预览插件。 如果您编写了HTML代码,但无法直观看到其在浏览器中的实际渲染效果,则可能是由于文件未正确保存、未使用浏览器打开或文件扩展名设置错误…

    2025年12月23日
    400
  • html5怎么插入文档_HT5用object或iframe嵌入PDF/Word文档显示【插入】

    可在HTML5中用iframe或object标签嵌入PDF,需设宽高及可访问路径;Word文档需借OneDrive等第三方服务代理渲染;须处理跨域限制并提供下载降级方案。 如果您希望在HTML5页面中嵌入PDF或Word文档并直接显示,可以使用或标签实现。以下是几种可行的嵌入方法: 一、使用ifra…

    2025年12月23日
    200

发表回复

登录后才能评论
关注微信