zoukankan      html  css  js  c++  java
  • 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
    版权声明:本文为博主原创文章,转载请附上博文链接!

  • 相关阅读:
    忍者必须死3 模拟器按键设置
    C# 工厂模式 个人基本流程
    WPF Boolean类型转化器收集 反转转化器
    Json实体类驼峰名称转化器
    TDengine + EMQ X + Grafana 轻松搭建高效低成本的边缘侧工业互联网平台
    呼声最高的数据更新功能来了,用户需要什么,我们就开源什么
    年轻人不讲武德,TDengine边缘侧数据存储方案挑战SQLite
    保姆级演示一分钟搞定TDengine的下载安装
    双汇大数据方案选型:从棘手的InfluxDB+Redis到毫秒级查询的TDengine
    HiveMQ TDengine extension 使用指南
  • 原文地址:https://www.cnblogs.com/zengpeng/p/11177457.html
Copyright © 2011-2022 走看看