• windows下配置mycat与常见问题解决


    mycat官网:http://www.mycat.org.cn/

    wiki:https://github.com/MyCATApache/Mycat-Server/wiki



    MyCat使用Mysql的通讯协议模拟成一个MySQl服务器,并建立了完整的Schema(数据库)、Table(数据表)、User(用户)的逻辑模型,并将这套逻辑模型映射到后端的存储节点DataNode上的真实的物理库中,这样一来所有能使用MySQL的客户端及编程语言都能将Mycat当成MYSQLServer使用,不必开发新的客户端。



    Mycat的原理:当Mycat收到一个客户端发送的SQL请求,会先对SQL进行语法分析和检查,分析的结果用SQL路由,SQL路由策略支持传统的基于表格的分片字段进行分片,也支持独有的基于数据库E-R关系的分别片策略,对于路由到多个数据节点(DataNode)的SQL,则会对收到的数据集进行”归并“,然后输出到客户端。



    DataNode是MyCat的逻辑数据节点,映射到后端的某一个物理数据库的一个Datebase,为了做到系统高可用,每个DataNode可以配置多个引用地址(DataSource),当主DataSource被检测为不可用时,系统会自动切换到下一个可用的DataSource上,这里的DataSoure即可认为是Mysql的主流服务器的地址。



    安装:

    1、下载安装包 https://github.com/MyCATApache/Mycat-download/tree/master/1.5-RELEASE

    选择windows版本。



    2、解压下载的mycat安装包的知道目录



    3、搭建java环境,下载jdk8(mycat 1.5.1-RELEASE对应的版本呢)并安装,配置相应的环境变量。



    4、修改mycat配置文件:
    【1】wrapper.conf 修改wrapper.java.command对应的java jdk对应的目录,例如:wrapper.java.command=G:java_jdkjdkinjava.exe
    【2】修改server.xml,mycat的基本配置文件,可以配置端口、绑定ip等相关配置,默认配置文件中,是注释掉,走默认值。这块主要配置mycat登录的用户名和密码

    1. <user name="root">  
    2.     <property name="password">root</property>  
    3.     <property name="schemas">TESTDB</property>  
    4. </user>  


    配置用户名为root,密码是root,用户有权限的逻辑库TESTDB
    【3】修改schema.xml (定义逻辑库,表、分片节点等内容)
    schema对应逻辑库:TESTDB
    table对应逻辑表:t_user
    dataNode对应分片
    dataHost对应物理库真实映射
    1. <?xml version="1.0" encoding="UTF-8"?>  
    2. <!DOCTYPE mycat:schema SYSTEM "schema.dtd">  
    3.   
    4.   
    5. <mycat:schema  xmlns:mycat="http://org.opencloudb/">  
    6.   <schema name="TESTDB" checkSQLschema="true" sqlMaxLimit="100" dataNode="dn1">  
    7.       <table name="t_user" dataNode="dn1,dn2" rule="sharding-by-mod2"/>  
    8.       <table name="ht_jy_login_log" primaryKey="ID" dataNode="dn1,dn2" rule="sharding-by-date_jylog"/>  
    9.   </schema>  
    10.   <dataNode name="dn1" dataHost="localhost1" database="mycat_node1"/>  
    11.   <dataNode name="dn2" dataHost="localhost1" database="mycat_node2"/>  
    12.   
    13.   
    14.   <dataHost name="localhost1" writeType="0" switchType="1" slaveThreshold="100" balance="1" dbType="mysql" maxCon="10" minCon="1" dbDriver="native">  
    15.     <heartbeat>show status like 'wsrep%'</heartbeat>  
    16.     <writeHost host="hostM1" url="127.0.0.1:3306" user="root" password="root" >  
    17.     </writeHost>    
    18.   </dataHost>  
    19. </mycat:schema >  







    5、mycat的分片规则下一篇讲解



    6、启动mycat。

    mycat.bat start 启动



    mycat.bat stop 停止



    mycat.bat console 前台运行



    mycat.bat install 添加到系统自动启动(暂未实现)



    mycat.bat remove 取消随系统自动启动(暂未实现)



    mycat.bat restart 重启服务



    mycat.bat pause 暂停



    mycat.bat status 查看启动状态



    7、通过navcat进行链接测试:
    地址:localhost
    端口:8066
    账号:root
    密码:root



    8、常见问题:
    【1】wrapper  | OpenSCManage failed - 拒绝访问
    解决办法:cmd以管理员身份运行。
    【2】Unsupported major.minor version 51.0
    解决办法:调整本地jdk的版本,试试jdk8.0
    【3】Error: Could not create the Java Virtual Machine.
    解决办法:
    wrapper.java.additional.10=-Xmx1G
    wrapper.java.additional.11=-Xms512M

    修改最后一个值的大小,例如:wrapper.java.additional.11=-Xms1G


  • 相关阅读:
    window.open
    网站图片的放大镜效果
    Python3基础 getatime getctime getmtime 文件的最近访问 + 属性修改 + 内容修改时间
    Python3基础 file open+write 对不存在的txt进行创建与写入
    Python3基础 file seek 将文件的指针恢复到初始位置
    Python3基础 file with 配合文件操作
    Python3基础 file read 读取txt文件的前几个字符
    Python3基础 file open 打开txt文件并打印出全文
    Python3基础 file for+list 读取txt文本 并 一行一行的输出(低效率)
    Python3基础 file for+文件指针 读取txt文本并 一行一行的输出(高效率)
  • 原文地址:https://www.cnblogs.com/jpfss/p/8205176.html
Copyright © 2020-2023  润新知