1、下载mycat
为了方便,我已经下载下来。我选择的版本是1.6版本

2、解压,安装在/home/xm6f/dev目录下

cd /home/xm6f/devtar -zxvf Mycat-server-1.6-RELEASE-20161028204710-linux.tar.gz

为了以后更好看目录结构,下tree(可选)

yum -y install tree
tree /home/xm6f/dev/mycat #查看mycat目录结构

3、创建用户并修改配置文件
a、为了更好的进入mycat,设置MYCAT_HOME的变量:vim /etc/profile
修改增加下列内容:

export JAVA_HOME=/home/xm6f/dev/jdk1.7.0_80
export JRE_HOME=/home/xm6f/dev/jdk1.7.0_80/jre
export MYCAT_HOME=/home/xm6f/dev/mycat
export PATH=$PATH:$JAVA_HOME/bin:$JRE_HOME/bin:$MYCAT_HOME/bin
 
使得变量生效:source /etc/profile

###服务器名和IP绑定

vim /etc/hosts 192.168.1.105 mycat-server127.0.0.1 mycat-server

###设置 wrapper.java.command 的java 路径
( 同时可设置 -Xmx 和 -Xms ,参考: mycat 启动失败 The specified size exceeds the maximum
representable size)

vim /home/xm6f/dev/mycat/conf/wrapper.conf 
wrapper.java.command=%JAVA_HOME%/bin/java 

b、修改server.xml
cd /home/xm6f/dev/mycat
vim conf/server.xml

 
开启实时统计,便于后期安装mycat-eye的监测<!-- 1为开启实时统计、0为关闭 --><property name="useSqlStat">1</property>
 
这四项都去掉注释,使得生效<!--默认是65535 64K 用于sql解析时最大文本长度 --><property name="maxStringLiteralLength">65535</property><property name="sequnceHandlerType">0</property><property name="backSocketNoDelay">1</property><property name="frontSocketNoDelay">1</property>
 

最主要的看下面的配置,这是连接mycat的时候的用户名和密码

 
    <user name="root">
        <property name="password">123456</property>
        <property name="schemas">TESTDB</property>
        
        <!-- 表级 DML 权限设置 -->
        <!--         
        <privileges check="false">
            <schema name="TESTDB" dml="0110" >
                <table name="tb01" dml="0000"></table>
                <table name="tb02" dml="1111"></table>
            </schema>
        </privileges>        
         -->
    </user>
 
    <user name="user">
        <property name="password">user</property>
        <property name="schemas">TESTDB</property>
        <property name="readOnly">true</property>
    </user>
 

mycat的用户名和密码:root/123456、user/user

c、修改schema.xml
cd /home/xm6f/dev/mycat
vim conf/schema.xml

 
<?xml version="1.0" encoding="UTF-8"?><!DOCTYPE mycat:schema SYSTEM "schema.dtd"><mycat:schema xmlns:mycat="http://io.mycat/">
 
    <schema name="TESTDB" checkSQLschema="false" sqlMaxLimit="100" dataNode="dn1" />
    <dataNode name="dn1" dataHost="localhost1" database="mldn" />
    <dataHost name="localhost1" maxCon="1000" minCon="10" balance="0" writeType="0" dbType="mysql" 
        dbDriver="native" switchType="1"  slaveThreshold="100">
        <heartbeat>select user()</heartbeat>
        <!-- can have multi write hosts -->
        <writeHost host="hostM1" url="192.168.1.33:3306" user="root" password="attack">
        </writeHost>
    </dataHost></mycat:schema>
 

d、修改log4j的配置
为了让信息启动时更好定位,需要将conf/log4j2.xml的文件修改为debug级别。

四、启动mycat服务

# mycat { console | start | stop | restart | status | dump }

总结
关于MyCAT的配置其实是蛮简单的,最主要的是熟悉各配置文件的规则。以上用户名,密码,如何分库,都是在配置文件中定义的。

关于配置文件,conf目录下主要以下三个需要熟悉。
server.xml是Mycat服务器参数调整和用户授权的配置文件
schema.xml是逻辑库定义和表以及分片定义的配置文件
rule.xml是分片规则的配置文件

WrapperSimpleApp:
Encountered an error running main: java.lang.OutOfMemoryError: Direct buffer
memory

修改wrapper.conf的配置文件:

wrapper.java.additional.3=-XX:MaxPermSize=1024M
wrapper.java.additional.5=-XX:MaxDirectMemorySize=4G
# Initial Java Heap Size (in MB)
wrapper.java.initmemory=512
# Maximum Java Heap Size (in MB)
wrapper.java.maxmemory=512

最新文章

  1. 【转】如何提高意志力&amp;如何坚持每天学习
  2. php取整函数ceil,floor,round,intval函数的区别
  3. 读取中文目录(python)
  4. NET中的Memcached.ClientLibrary使用详解
  5. 用Eclipse新建一个web项目没有自动生成web.xml
  6. 函数fseek() 用法(转)
  7. Django ajax MYSQL Highcharts&lt;1&gt;
  8. Android进阶篇-内存管理
  9. jquery validation插件
  10. scss 学习笔记
  11. CF798 C. Mike and gcd problem
  12. [CQOI 2015]选数
  13. python爬虫Scrapy(一)-我爬了boss数据
  14. Git使用五:回到过去
  15. 找bug hhh
  16. 130、 Android OkHttp完全解析(转载)
  17. 在centos7上使用最简单的方法把php脚本做成服务,随开机启动运行
  18. 【转】理解js中的原型链,prototype与__proto__的关系
  19. luogu P4161 [SCOI2009]游戏
  20. SQL server 清除缓存

热门文章

  1. python学习之模块导入,操作邮件,redis
  2. UML再论关系extend和include
  3. js onclick事件传参
  4. python----PySnooper获取打印日志
  5. nginx location中root指令和alias指令的区别
  6. HTML 007 链接
  7. NodeJS事件环
  8. MongoDB 查看集合是否分片
  9. Python多线程笔记(二)
  10. List&lt;Map&lt;String, Obejct&gt;&gt;遍历