在Linux上Mycat学习遇到的坑。不容易
2021/5/8 7:25:29
本文主要是介绍在Linux上Mycat学习遇到的坑。不容易,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
这两天在学习Mycat,遇到不少坑,可谓是步步有坑,而且网上类似的问题解决办法也不是很多,在此总结一下一路走下来遇到的坑。方便后来者鉴之。
1、安装Mycat,版本选择的问题。1.6版本出现这个错误:Unable to locate the class io.mycat.MycatStartup
我使用的是最新版,1.6.7.4的,建议大家也使用这个版本,1.6的可能会有各种不知道的坑。下面给出下载地址:
http://www.mycat.org.cn/
这个安装非常简单,下载后上传到Linux中,解压即可用。
2、jdk版本必须是1.7以上,最好是1.8的,jdk1.8安装,自己网上查找,类似文档很多,在此不作赘述。
3、mySql建议安装8.0版本的,这样避免因为低版本出现和别的软件不匹配的原因。
Linux上面安装Mysql8.0教程,参看下面的链接,非常好,强烈推荐,别的教程可能会出现各种不期的问题:
https://blog.csdn.net/qq_40550973/article/details/80721014
-----------------------------------上面是安装准备工作------------------------------------------------
4、mysql安装好后,远程访问问题:
由于在上一步安装mysql中的密码设置这一步,没能成功设置为简单的密码。所以我的root登录密码还是初始密码。
远程登录mysql方式:
mysql -uroot -p 登录密码 -h 192.168.254.21 -P 3306
发现不能远程登录,所以需要修改密码验证策略。然后修改登录密码,然后就能远程登录了。具体操作见下面链接:
https://blog.csdn.net/weixin_44649811/article/details/116463922
5、Mycat解压后复制解压的文件到 /usr/local下面即可。
配置server.xml文件:
只需要将那么修改为mycat(别的名字也行)
:wq 保存退出。
6、下载mysql的8.x版本的驱动
首先需要下载8.x版本的驱动,Mycat 默认的MySQL驱动版本为5.x。
8.x下载地址为:
https://pan.baidu.com/s/13mb6qGUBqUBQX0PqyjUG3Q
提取码:i7sp
下载好后上传到mycat的lib目录下,并删除原本的5.x驱动包:
接着使用chmod命令设置该驱动包的权限:
[root@txy-server /usr/local/mycat]# chmod 777 lib/mysql-connector-java-8.0.23
7、修改 schema.xml
修改位于conf目录下的schema.xml配置文件,目的是更改Mycat连接MySQL的方式:
[root@txy-server /usr/local/mycat]# vim conf/schema.xml
修改dataHost标签中的dbDriver属性为jdbc,以及修改 writeHost 标签中的url属性:
url这里有一个坑,就是 & 必须使用转义字符,不然会报错。转义字符为: &
不然会有这个错误:The reference to entity “serverTimezone” must end with the ‘;’ delimiter.
ip为mysql所在的ip地址,user和password为mysql的登录用户名与密码。
<dataHost name="host1" maxCon="1000" minCon="10" balance="0" writeType="0" dbType="mysql" dbDriver="jdbc" switchType="1" slaveThreshold="100"> <heartbeat>select user()</heartbeat> <writeHost host="hostM1" url="jdbc:mysql://192.168.130.28:3306?useSSL=false&serverTimezone=GMT%2B8" user="root" password="123456"> </writeHost> </dataHost>
修改 server.xml
修改位于conf目录下的server.xml配置文件:
[root@txy-server /usr/local/mycat]# vim conf/server.xml
将useHandshakeV10设置为1,如果没该标签则添加即可:
<system> <property name="useHandshakeV10">1</property> ... </system>
8、此时启动Mycat,[root@localhost bin]# ./mycat console
会出现下面得问题:The specified size exceeds the maximum representable size.
jvm 2 | Invalid maximum heap size: -Xmx4G jvm 2 | The specified size exceeds the maximum representable size. jvm 2 | Error: Could not create the Java Virtual Machine. jvm 2 | Error: A fatal exception has occurred. Program will exit.
解决办法:
修改wrapper.xml。改为512M和64M,保存重启。
前台启动方式:`[root@localhost bin]# ./mycat console
我们发现启动成功。Mycat的安装配置完毕。
ctrl+c结束进程使用后台启动方式:
[root@localhost bin]# ./mycat start Starting Mycat-server... [root@localhost bin]#
查看是否启动成功:
[root@localhost bin]# ps -ef|grep mycat root 1305 1 0 11:31 ? 00:00:00 /usr/local/mycat/bin/./wrapper-linux-x86-64 /usr/local/mycat/conf/wrapper.conf wrapper.syslog.ident=mycat wrapper.pidfile=/usr/local/mycat/logs/mycat.pid wrapper.daemonize=TRUE wrapper.lockfile=/var/lock/subsys/mycat root 1307 1305 96 11:31 ? 00:00:09 java -DMYCAT_HOME=. -server -XX:+AggressiveOpts -XX:MaxDirectMemorySize=2G -Dcom.sun.management.jmxremote -Dcom.sun.management.jmxremote.port=1984 -Dcom.sun.management.jmxremote.authenticate=false -Dcom.sun.management.jmxremote.ssl=false -Xmx512M -Xms64M -Djava.library.path=lib -classpath lib/wrapper.jar:conf:lib/annotations-13.0.jar:lib/asm-4.0.jar:lib/commons-collections-3.2.1.jar:lib/commons-lang-2.6.jar:lib/curator-client-2.11.0.jar:lib/curator-framework-2.11.0.jar:lib/curator-recipes-2.11.0.jar:lib/disruptor-3.3.4.jar:lib/dom4j-1.6.1.jar:lib/druid-1.0.26.jar:lib/ehcache-core-2.6.11.jar:lib/fastjson-1.2.58.jar:lib/guava-19.0.jar:lib/hamcrest-core-1.3.jar:lib/hamcrest-library-1.3.jar:lib/jline-0.9.94.jar:lib/joda-time-2.9.3.jar:lib/jsr305-2.0.3.jar:lib/kotlin-stdlib-1.3.50.jar:lib/kotlin-stdlib-common-1.3.50.jar:lib/kryo-2.10.jar:lib/leveldb-0.7.jar:lib/leveldb-api-0.7.jar:lib/libwrapper-linux-ppc-64.so:lib/libwrapper-linux-x86-32.so:lib/libwrapper-linux-x86-64.so:lib/log4j-1.2-api-2.5.jar:lib/log4j-1.2.17.jar:lib/log4j-api-2.5.jar:lib/log4j-core-2.5.jar:lib/log4j-slf4j-impl-2.5.jar:lib/mapdb-1.0.7.jar:lib/minlog-1.2.jar:lib/mongo-java-driver-3.11.0.jar:lib/Mycat-server-1.6.7.4-release.jar:lib/mysql-binlog-connector-java-0.16.1.jar:lib/mysql-connector-java-5.1.35.jar:lib/netty-3.7.0.Final.jar:lib/netty-buffer-4.1.9.Final.jar:lib/netty-common-4.1.9.Final.jar:lib/objenesis-1.2.jar:lib/okhttp-4.2.2.jar:lib/okio-2.2.2.jar:lib/reflectasm-1.03.jar:lib/sequoiadb-driver-1.12.jar:lib/slf4j-api-1.6.1.jar:lib/univocity-parsers-2.2.1.jar:lib/velocity-1.7.jar:lib/wrapper.jar:lib/zookeeper-3.4.6.jar -Dwrapper.key=t7pVtFRuTurdUh0m -Dwrapper.port=32000 -Dwrapper.jvm.port.min=31000 -Dwrapper.jvm.port.max=31999 -Dwrapper.pid=1305 -Dwrapper.version=3.2.3 -Dwrapper.native_library=wrapper -Dwrapper.service=TRUE -Dwrapper.cpu.timeout=10 -Dwrapper.jvmid=1 org.tanukisoftware.wrapper.WrapperSimpleApp io.mycat.MycatStartup start root 1327 1229 0 11:31 pts/0 00:00:00 grep --color=auto mycat [root@localhost bin]#
启动成功!!
9、最后一步:远程连接Mycat
mysql -umycat -p123456 -P8066 -h 192.168.254.85
发现出现这个错误:Access denied for user ‘mycat’, because password is error
这也是因为MySQL 8以上的版本与之前版本的密码加密方式不一样。而 Mycat 目前还是只支持5.x版本的加密方式,所以使用8以上版本的MySQL客户端工具连接Mycat时就会报密码错误。
解决办法:指定mysql客户端连接时的加密方式:在后面加上:--default-auth=mysql_native_password
即可
[root@localhost bin]# mysql -umycat -p123456 -P8066 -h192.168.254.12 --default-auth=mysql_native_password
然后就成功了,此处大功告成!!
mysql: [Warning] Using a password on the command line interface can be insecure. Welcome to the MySQL monitor. Commands end with ; or \g. Your MySQL connection id is 3 Server version: 5.6.29-mycat-1.6.7.4-release-20200105164103 MyCat Server (OpenCloudDB) Copyright (c) 2000, 2021, Oracle and/or its affiliates. Oracle is a registered trademark of Oracle Corporation and/or its affiliates. Other names may be trademarks of their respective owners. Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
这篇关于在Linux上Mycat学习遇到的坑。不容易的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-10-22原生鸿蒙操作系统HarmonyOS NEXT(HarmonyOS 5)正式发布
- 2024-10-18操作系统入门教程:新手必看的基本操作指南
- 2024-10-18初学者必看:操作系统入门全攻略
- 2024-10-17操作系统入门教程:轻松掌握操作系统基础知识
- 2024-09-11Linux部署Scrapy学习:入门级指南
- 2024-09-11Linux部署Scrapy:入门级指南
- 2024-08-21【Linux】分区向左扩容的方法
- 2024-08-21【Linux】gnome桌面环境切换KDE Plasma
- 2024-08-19如何安装 VMware Tools (macOS, Linux, Windows)
- 2024-08-15Linux部署Scrapy教程:入门级指南