CentOS6.6安装使用MyCat

2024-08-22 16:48
文章标签 centos6.6 mycat 安装 使用

本文主要是介绍CentOS6.6安装使用MyCat,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1. 安装Java环境

MyCAT 是使用 JAVA 语言进行编写开发,使用前需要先安装 JAVA 运行环境(JRE),由于 MyCAT 中使用了JDK7 中的一些特性,所以要求必须在 JDK7 以上的版本上运行。

1.1 查看是否已经安装jdk

    [root@localhost lmy]# rpm -qa | grep java[root@localhost lmy]# 

显示没有安装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.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

打开配置文件

[root@localhost java]# vi /etc/profile

将下面的配置信息放在最下面,保存退出。(注意地址要根据自己的来写。)

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

使配置生效

[root@localhost java]# source /etc/profile

查看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)

到这里Java环境就安装好了。

2. 安装MySQL

2.1 卸载原有的mysql

首先查看系统中是否已经安装mysql

[root@localhost java]#  rpm -qa | grep mysql
mysql-libs-5.1.73-3.el6_5.x86_64

此时显示系统中并没有安装mysql,如果已经安装了,使用该命令卸载删除。

[root@localhost java]# rpm -e mysql         //普通删除方式
[root@localhost java]# rpm -e --nodeps mysql    // 强力删除模式,如果使用上面命令删除时,提示有依赖的其它文件,则用该命令可以对其进行强力删除

2.2 通过yum来进行mysql的安装

[root@localhost java]# yum install -y mysql-server mysql mysql-deve

出现如下提示就表明安装成功了!
这里写图片描述

我们可以查看一下安装完成的版本。

[root@localhost java]# rpm -qi mysql-server

当然,此时我们安装的并不是最新版本。我们可以启动一下mysql看看。

[root@localhost java]# service mysqld start

这里写图片描述

2.3配置mysql

为root用户设置密码:

[root@localhost java]# mysqladmin -u root password '123456' //设置密码为123456

设置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

接下来我们就可以登录我们的mysql数据库了。

[root@localhost java]# mysql -uroot -p123456

这里写图片描述

到这为止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

测试启动mycat.
Linux环境下启动mycat的方式为:进入bin目录下,使用 ./mycat start命令启动。

[root@localhost bin]# ./mycat start
Starting Mycat-server...

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; 

这里写图片描述

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>

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>

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>

三个配置文件配置完之后,重启mycat服务。

[root@localhost bin]# cd /usr/local/java/mycat/bin/
[root@localhost bin]# ./mycat restart

3.2.3测试结果
我们先访问mycat逻辑数据库,此时的视角是看不出分库分表的信息,这些表就好像在一个数据库中。

[root@localhost bin]# mysql -umycat -pmycat -h127.0.0.1 -P8066 -DTESTDB

*补充:后来我在其它机器上实验时,设置了两个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());

这里写图片描述

可以看到,对于mycat的逻辑表来说,数据已经插入成功了,但是实际上数据是否按照规则存在那三个数据库中呢?我们登录实际的数据库来查看。

这里写图片描述
这里写图片描述
这里写图片描述

我们看到,插入到user表中的数据全部都在db01的user表中,插入到goods表中的数据分别放在了db02和db03数据库中的goods表中。完美的完成了分库分表的操作!

这篇关于CentOS6.6安装使用MyCat的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1096835

相关文章

Zookeeper安装和配置说明

一、Zookeeper的搭建方式 Zookeeper安装方式有三种,单机模式和集群模式以及伪集群模式。 ■ 单机模式:Zookeeper只运行在一台服务器上,适合测试环境; ■ 伪集群模式:就是在一台物理机上运行多个Zookeeper 实例; ■ 集群模式:Zookeeper运行于一个集群上,适合生产环境,这个计算机集群被称为一个“集合体”(ensemble) Zookeeper通过复制来实现

CentOS7安装配置mysql5.7 tar免安装版

一、CentOS7.4系统自带mariadb # 查看系统自带的Mariadb[root@localhost~]# rpm -qa|grep mariadbmariadb-libs-5.5.44-2.el7.centos.x86_64# 卸载系统自带的Mariadb[root@localhost ~]# rpm -e --nodeps mariadb-libs-5.5.44-2.el7

Centos7安装Mongodb4

1、下载源码包 curl -O https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-rhel70-4.2.1.tgz 2、解压 放到 /usr/local/ 目录下 tar -zxvf mongodb-linux-x86_64-rhel70-4.2.1.tgzmv mongodb-linux-x86_64-rhel70-4.2.1/

中文分词jieba库的使用与实景应用(一)

知识星球:https://articles.zsxq.com/id_fxvgc803qmr2.html 目录 一.定义: 精确模式(默认模式): 全模式: 搜索引擎模式: paddle 模式(基于深度学习的分词模式): 二 自定义词典 三.文本解析   调整词出现的频率 四. 关键词提取 A. 基于TF-IDF算法的关键词提取 B. 基于TextRank算法的关键词提取

使用SecondaryNameNode恢复NameNode的数据

1)需求: NameNode进程挂了并且存储的数据也丢失了,如何恢复NameNode 此种方式恢复的数据可能存在小部分数据的丢失。 2)故障模拟 (1)kill -9 NameNode进程 [lytfly@hadoop102 current]$ kill -9 19886 (2)删除NameNode存储的数据(/opt/module/hadoop-3.1.4/data/tmp/dfs/na

Hadoop数据压缩使用介绍

一、压缩原则 (1)运算密集型的Job,少用压缩 (2)IO密集型的Job,多用压缩 二、压缩算法比较 三、压缩位置选择 四、压缩参数配置 1)为了支持多种压缩/解压缩算法,Hadoop引入了编码/解码器 2)要在Hadoop中启用压缩,可以配置如下参数

Makefile简明使用教程

文章目录 规则makefile文件的基本语法:加在命令前的特殊符号:.PHONY伪目标: Makefilev1 直观写法v2 加上中间过程v3 伪目标v4 变量 make 选项-f-n-C Make 是一种流行的构建工具,常用于将源代码转换成可执行文件或者其他形式的输出文件(如库文件、文档等)。Make 可以自动化地执行编译、链接等一系列操作。 规则 makefile文件

使用opencv优化图片(画面变清晰)

文章目录 需求影响照片清晰度的因素 实现降噪测试代码 锐化空间锐化Unsharp Masking频率域锐化对比测试 对比度增强常用算法对比测试 需求 对图像进行优化,使其看起来更清晰,同时保持尺寸不变,通常涉及到图像处理技术如锐化、降噪、对比度增强等 影响照片清晰度的因素 影响照片清晰度的因素有很多,主要可以从以下几个方面来分析 1. 拍摄设备 相机传感器:相机传

Centos7安装JDK1.8保姆版

工欲善其事,必先利其器。这句话同样适用于学习Java编程。在开始Java的学习旅程之前,我们必须首先配置好适合的开发环境。 通过事先准备好这些工具和配置,我们可以避免在学习过程中遇到因环境问题导致的代码异常或错误。一个稳定、高效的开发环境能够让我们更加专注于代码的学习和编写,提升学习效率,减少不必要的困扰和挫折感。因此,在学习Java之初,投入一些时间和精力来配置好开发环境是非常值得的。这将为我

pdfmake生成pdf的使用

实际项目中有时会有根据填写的表单数据或者其他格式的数据,将数据自动填充到pdf文件中根据固定模板生成pdf文件的需求 文章目录 利用pdfmake生成pdf文件1.下载安装pdfmake第三方包2.封装生成pdf文件的共用配置3.生成pdf文件的文件模板内容4.调用方法生成pdf 利用pdfmake生成pdf文件 1.下载安装pdfmake第三方包 npm i pdfma