CentOS6.6安装使用MyCat
https://blog.csdn.net/u012948302/article/details/78902092
1. 安装Java环境
MyCAT 是使用 JAVA 语言进行编写开发,使用前需要先安装 JAVA 运行环境(JRE),由于 MyCAT 中使用了JDK7 中的一些特性,所以要求必须在 JDK7 以上的版本上运行。
1.1 查看是否已经安装jdk
[root@localhost lmy]# rpm -qa | grep java
[root@localhost lmy]#
1
2
显示没有安装jdk,若是存在centOS自带的,openjdk,需要卸载。
1.2下载安装JDK
1.2.1首先新建文件夹,然后下载jdk,我下载的是64位的jdk8,需要根据需要到下载地址选择自己所需的版本。
[root@localhost lmy]# cd /
[root@localhost /]# cd usr/local
[root@localhost local]# mkdir java
[root@localhost local]# cd java
[root@localhost java]# wget http://202.119.24.249/cache/9/02/download.oracle.com/bcd3e06fe42195d3f3496e6548f0152a/jdk-8u151-linux-x64.tar.gz
[root@localhost java]# ls
jdk-8u151-linux-x64.tar.gz
1
2
3
4
5
6
7
8
1.2.2此时已经下载好了jdk,接下来就是解压配置了。
解压
[root@localhost java]# tar -zxvf jdk-8u151-linux-x64.tar.gz
[root@localhost java]# ls
jdk1.8.0_151 jdk-8u151-linux-x64.tar.gz
1
2
3
4
打开配置文件
[root@localhost java]# vi /etc/profile
1
将下面的配置信息放在最下面,保存退出。(注意地址要根据自己的来写。)
export JAVA_HOME=/usr/local/java/jdk1.8.0_151
export JRE_HOME=/usr/local/java/jdk1.8.0_151/jre
export PATH=$PATH:/usr/local/java/jdk1.8.0_151/bin
export
CLASSPATH=./:/usr/local/java/jdk1.8.0_151/lib:/usr/local/java/jdk1.8.0_151/jre/lib
1
2
3
4
5
6
7
8
使配置生效
[root@localhost java]# source /etc/profile
1
查看Java版本
[root@localhost java]# java -version
java version "1.8.0_151"
Java(TM) SE Runtime Environment (build 1.8.0_151-b12)
Java HotSpot(TM) 64-Bit Server VM (build 25.151-b12, mixed mode)
1
2
3
4
到这里Java环境就安装好了。
2. 安装MySQL
2.1 卸载原有的mysql
首先查看系统中是否已经安装mysql
[root@localhost java]# rpm -qa | grep mysql
mysql-libs-5.1.73-3.el6_5.x86_64
1
2
此时显示系统中并没有安装mysql,如果已经安装了,使用该命令卸载删除。
[root@localhost java]# rpm -e mysql //普通删除方式
[root@localhost java]# rpm -e --nodeps mysql // 强力删除模式,如果使用上面命令删除时,提示有依赖的其它文件,则用该命令可以对其进行强力删除
1
2
2.2 通过yum来进行mysql的安装
[root@localhost java]# yum install -y mysql-server mysql mysql-deve
1
出现如下提示就表明安装成功了!
我们可以查看一下安装完成的版本。
[root@localhost java]# rpm -qi mysql-server
1
当然,此时我们安装的并不是最新版本。我们可以启动一下mysql看看。
[root@localhost java]# service mysqld start
1
2.3配置mysql
为root用户设置密码:
[root@localhost java]# mysqladmin -u root password '123456' //设置密码为123456
1
设置mysql开机启动
[root@localhost java]# chkconfig mysqld on
[root@localhost java]# chkconfig --list | grep mysql
mysqld 0:off 1:off 2:on 3:on 4:on 5:on 6:off
1
2
3
接下来我们就可以登录我们的mysql数据库了。
[root@localhost java]# mysql -uroot -p123456
1
到这为止mysql也已经安装完成了。
3. 安装MyCat
MyCat的安装比较简单,只要下载下来解压,然后就是编写配置文件了。
3.1 下载解压MyCat
此时我下载的版本为1.6,你也可以根据自己的需要到下载地址选择需要的版本下载。
[root@localhost java]# cd /usr/local/java/ //下载到该目录
[root@localhost java]# wget http://dl.mycat.io/1.6-RELEASE/Mycat-server-1.6-RELEASE-20161028204710-linux.tar.gz
[root@localhost java]# tar -zxvf Mycat-server-1.6-RELEASE-20161028204710-linux.tar.gz //解压
[root@localhost java]# ls //可以看到解压后的文件夹名为mycat
jdk1.8.0_151
jdk-8u151-linux-x64.tar.gz
mycat
Mycat-server-1.6-RELEASE-20161028204710-linux.tar.gz
1
2
3
4
5
6
7
8
9
10
11
12
测试启动mycat.
Linux环境下启动mycat的方式为:进入bin目录下,使用 ./mycat start命令启动。
[root@localhost bin]# ./mycat start
Starting Mycat-server...
1
2
3.2 测试MyCat
整体的结构是这样的:有两个表,一个user表,一个goods表。user表放在db01数据库中,goods表使用分片的方法放在db02和db03数据库中。虽然goods表被分片存储在不同的数据库中,但是通过MyCat访问goods表时仍然像一张表一样。我们先在mysql中建立这三张表,然后通过MyCat将分片规则配置,再通过MyCat进行增删改查操作。
3.2.1建立数据库和表
首先我们先在mysql中新建三个数据库和这三张表。脚本分别如下:
create database db01;
use db01;
CREATE TABLE user (
id INT NOT NULL AUTO_INCREMENT,
name varchar(50) NOT NULL default '',
indate DATETIME NOT NULL default '0000-00-00 00:00:00',
PRIMARY KEY (id)
)AUTO_INCREMENT= 1 ENGINE=InnoDB DEFAULT CHARSET=utf8;
create database db02;
use db02;
CREATE TABLE goods(
id INT NOT NULL AUTO_INCREMENT,
value INT NOT NULL default 0,
indate DATETIME NOT NULL default '0000-00-00 00:00:00',
PRIMARY KEY (id)
)AUTO_INCREMENT= 1 ENGINE=InnoDB DEFAULT CHARSET=utf8;
create database db03;
use db03;
CREATE TABLE goods(
id INT NOT NULL AUTO_INCREMENT,
value INT NOT NULL default 0,
indate DATETIME NOT NULL default '0000-00-00 00:00:00',
PRIMARY KEY (id)
)AUTO_INCREMENT= 1 ENGINE=InnoDB DEFAULT CHARSET=utf8;
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
3.2.2配置MyCat.
下面我们要配置三个文件,在mycat/conf目录里面。
conf/server.xml 中定义用户以及系统相关变量,如端口等.
conf/schema.xml 中定义逻辑库,表、分片节点等内容.
conf/rule.xml 中定义分片规则.
以下为三个配置文件。
server.xml
<?xml version="1.0" encoding="UTF8"?>
<!DOCTYPE mycat:server SYSTEM "server.dtd">
<system>
<property name="defaultSqlParser">druidparser</property>
<property name="serverPort">8066</property>
<property name="managerPort">9066</property>
</system>
<!-- 新增一个user -->
<user name="mycat">
<property name="password">mycat</property>
<property name="schemas">TESTDB</property>
</user>
</mycat:server>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
schema.xml
<?xml version="1.0" encoding="UTF8"?>
<!DOCTYPE mycat:schema SYSTEM "schema.dtd">
<mycat:schema xmlns:mycat="http://io.mycat/">
<!-- 设置表的存储方式.schema name="TESTDB" 与 server.xml中的 TESTDB 设置一致 -->
<schema name="TESTDB" checkSQLschema="false" sqlMaxLimit="100">
<table name="user" primaryKey="id" dataNode="node_db01" />
<table name="goods" primaryKey="id" dataNode="node_db02,node_db03" rule="rule1" />
</schema>
<!-- 设置dataNode 对应的数据库,及 mycat 连接的地址dataHost -->
<dataNode name="node_db01" dataHost="dataHost01" database="db01" />
<dataNode name="node_db02" dataHost="dataHost01" database="db02" />
<dataNode name="node_db03" dataHost="dataHost01" database="db03" />
<!-- mycat 逻辑主机dataHost对应的物理主机.其中也设置对应的mysql登陆信息 -->
<dataHost name="dataHost01" maxCon="1000" minCon="10" balance="0" writeType="0" dbType="mysql" dbDriver="native">
<heartbeat>select user()</heartbeat>
<writeHost host="server1" url="127.0.0.1:3306" user="root" password="123456"/>
</dataHost>
</mycat:schema>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
rule.xml
<?xml version="1.0" encoding="UTF8"?>
<!DOCTYPE mycat:rule SYSTEM "rule.dtd">
<mycat:rule xmlns:mycat="http://io.mycat/">
<tableRule name="rule1">
<rule>
<columns>id</columns>
<algorithm>mod-long</algorithm>
</rule>
</tableRule>
<!-- 分片规则为模2运算 -->
<function name="mod-long" class="io.mycat.route.function.PartitionByMod">
<!-- how many data nodes -->
<property name="count">2</property>
</function>
</mycat:rule>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
三个配置文件配置完之后,重启mycat服务。
[root@localhost bin]# cd /usr/local/java/mycat/bin/
[root@localhost bin]# ./mycat restart
1
2
3.2.3测试结果
我们先访问mycat逻辑数据库,此时的视角是看不出分库分表的信息,这些表就好像在一个数据库中。
[root@localhost bin]# mysql -umycat -pmycat -h127.0.0.1 -P8066 -DTESTDB
1
*补充:后来我在其它机器上实验时,设置了两个datahost,启动mycat时一直报错
[lmy@localhost conf]$ mysql -umycat -pmycat -h127.0.0.1 -P8066 -Dtestdb
ERROR 2003 (HY000): Can’t connect to MySQL server on ‘127.0.0.1’ (111)
我查找了server.xml schema.xml发现用户名,密码都没有配置错,端口也开放了,最后发现有一个datahost的没有写,希望以后对碰到此类问题的朋友有帮助。*
ok,现在我们可以往这两个表中插入数据,看看mycat能否按照我们之前的规则,将数据插入到相应的数据库表中。
insert into user(name,indate) values('hello',now());
insert into user(name,indate) values('world',now());
insert into goods(id,value,indate) values(1,100,now());
insert into goods(id,value,indate) values(2,100,now());
1
2
3
4
可以看到,对于mycat的逻辑表来说,数据已经插入成功了,但是实际上数据是否按照规则存在那三个数据库中呢?我们登录实际的数据库来查看。
我们看到,插入到user表中的数据全部都在db01的user表中,插入到goods表中的数据分别放在了db02和db03数据库中的goods表中。完美的完成了分库分表的操作!
---------------------
作者:刘my
来源:CSDN
原文:https://blog.csdn.net/u012948302/article/details/78902092
版权声明:本文为博主原创文章,转载请附上博文链接!
CentOS6.6安装使用MyCat的更多相关文章
- vmware Centos6.6安装64位
Centos6.6安装64位 必须开启BIOS中的虚拟化技术 首先开机进入BIOS,一般机器是按F2,我的T420是按F1,然后进入Security,Virtualization,选择Enable即可 ...
- Gitlab完美安装【CentOS6.5安装gitlab-6.9.2】
摘要: 拆腾了几天,终于在今天找到了快速安装Gitlab的方法.CentOS6.5安装gitlab-6.9.2 参考网址:https://gitlab.com/gitlab-org/omnibus-g ...
- CentOS6.5安装Tomcat
安装说明 安装环境:CentOS-6.4 安装方式:源码安装 软件:apache-tomcat-7.0.56.tar.gz 下载地址:http://tomcat.apache.org/download ...
- Centos6 yum安装openldap+phpldapadmin+TLS+双主配置
原文地址:http://54im.com/openldap/centos-6-yum-install-openldap-phpldapadmin-tls-%E5%8F%8C%E4%B8%BB%E9%8 ...
- centos6.5安装oracle11g_2
centos7安装oracle数据库不成功,换成centos6.5安装,可以安装成功,记录一下 安装系统时,主机名如果不是用localhost,安装成功后,要用主机名和ip做映射,修改/etc/hos ...
- CentOS6.6安装vmware workstation报错
本人系统用的是centos6.6,安装了vmware workstation,启动后一直如下图报错,相关内核已经安装了的,哪位前辈如果解决过这样的问题,麻烦指点指点,小弟在此先谢过了.
- CentOS6.6安装virtualbox4.1.44
本人用的是centos6.6,安装了virtualbox 4.1.44,启动后一直如上图报错,哪位前辈如果解决过这样的问题,麻烦指点指点,小弟在此先谢过了.
- [转]CentOS-6.3安装配置cmake
CentOS-6.3安装配置cmake zhoulf 2013-02-03 原创 安装说明 安装环境:CentOS-6.3安装方式:源码编译安装 软件:cmake-2.8.10.2.tar.gz下 ...
- 实战CENTOS6.5安装docker并创建asp.net mvc 5 镜像,运行MVC 网站
Docker,容器,让研发.测试.生产同一环境,可在linux平台上混合使用JAVA与net 程序 Centos6.5安装docker 参考http://my.oschina.net/kcw/blog ...
随机推荐
- 事件总线(EventBus)
Vue.prototype.$EventBus = new Vue() 不建议用,尽量用vuex,eventbus过于消耗浏览器资源 傻瓜版状态管理 一般的状态传递是在同时显示的情况下,倘若是在不同时 ...
- 分布式-信息方式-JMS大纲
一.简介 JMS即Java消息服务(Java Message Service)应用程序接口,是一个Java平台中关于面向消息中间件(MOM)的API,用于在两个应用程序之间,或分布式系统中发送消息, ...
- 【每日一包0009】group-array
[github地址:https://github.com/ABCDdouyae...] group-array 对数组里面的多项按照指定的key进行整合 用法:group-array(arr, key ...
- 循环链表C语言实现
按照单链表的设计,稍加改动.和单向链表不一样的地方,头节点不指向NULL,而是指向自己head 循环链表的判满 1)判断next是不是头结点,2)判断size /* * CycleLinkList.h ...
- 2019-7-29未命名文件 sdfsdfsdf
2019-7-29未命名文件 sdfsdfsdf 新建模板小书匠 欢迎使用 小书匠(xiaoshujiang)编辑器,您可以通过设置里的修改模板来改变新建文章的内容.
- Android 的四大组件都需要在清单文件中注册吗?
Activity . Service . ContentProvider 如 果 要 使 用 则 必 须 在 AndroidManifest.xml 中 进 行 注 册 , 而BroadcastRec ...
- 【flask】处理表单数据
表单数据的处理涉及很多内容,除去表单提交不说,从获取数据到保存数据大致会经历以下步骤: 解析请求,获取表单数据. 对数据进行必要的转换,比如将勾选框的植转换为Python的布尔值. 验证数据是否符合 ...
- nodejs之express中间件body-parser使用
1.安装express和body-parser npm install express npm install body-parser 2‘.案例如下 var express = require('e ...
- mysql的性能优化简介
mysql性能下降的原因 sql语句本身有问题,或没建索引 索引失效,索引失效的原因本文后面会叙述 关联了过多的表,可能是前期设计缺陷,或者太奇葩的需求 服务器调优及参数设置,例如缓冲.线程等 mys ...
- 三十:数据库之定义ORM模型,并映射到数据库
连接数据库操作 sqlalchemy映射步骤: 1.创建ORM模型,这个模型必须继承sqlalchemy提供的基类2.在这个ORM模型中创建一些属性,与表中的字段一一映射,这些属性必须是sqlalch ...