Mycat整合MySQL过程报错怎么办?这个问题可能是我们日常学习或工作经常见到的。通过这个问题,希望你能收获更多。下面是解决这个问题的步骤内容。
我们提供的服务有:网站设计制作、成都网站设计、微信公众号开发、网站优化、网站认证、耀州ssl等。为上千企事业单位解决了网站和推广的问题。提供周到的售前咨询和贴心的售后服务,是有科学管理、有技术的耀州网站制作公司首先需要下载8.x
版本的驱动,Mycat 默认的MySQL驱动版本为5.x
。到maven中央仓库上复制8.x驱动jar包的下载地址,然后到Linux上使用wget
命令进行下载:
[root@txy-server ~]# cd /usr/local/src
[root@txy-server /usr/local/src]# wget https://repo1.maven.org/maven2/mysql/mysql-connector-java/8.0.18/mysql-connector-java-8.0.18.jar
将驱动包移动到mycat的lib
目录下,并删除原本的5.x
驱动包:
[root@txy-server /usr/local/src]# mv mysql-connector-java-8.0.18.jar /usr/local/mycat/lib/
[root@txy-server /usr/local/src]# rm -rf /usr/local/mycat/lib/mysql-connector-java-5.1.35.jar
接着使用chmod
命令设置该驱动包的权限:
[root@txy-server /usr/local/mycat]# chmod 777 lib/mysql-connector-java-8.0.18.jar
修改位于conf
目录下的schema.xml
配置文件,目的是更改Mycat连接MySQL的方式:
[root@txy-server /usr/local/mycat]# vim conf/schema.xml
修改dataHost
标签中的dbDriver
属性为jdbc
,以及修改 writeHost
标签中的url
属性:
<dataHost name="localhost1" 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>
修改位于conf
目录下的server.xml
配置文件:
[root@txy-server /usr/local/mycat]# vim conf/server.xml
将useHandshakeV10
设置为1
,如果没该标签则添加即可:
<system>
<property name="useHandshakeV10">1</property>
...
</system>
重启 Mycat:
[root@txy-server /usr/local/mycat]# mycat stop
Stopping Mycat-server...
Stopped Mycat-server.
[root@txy-server /usr/local/mycat]# mycat start
Starting Mycat-server...
[root@txy-server /usr/local/mycat]#
在测试能否正常连接 Mycat 时又遇到了另一个问题,使用MySQL 8.x的客户端工具连接 Mycat 报了个密码错误:
[root@txy-server ~]# mysql -uroot -p -P9066 -h227.0.0.1
Enter password:
ERROR 1045 (HY000): Access denied for user 'root', because password is error
[root@txy-server ~]#
同样,这也是因为MySQL 8以上的版本与之前版本的密码加密方式不一样。而 Mycat 目前还是只支持5.x版本的加密方式,所以使用8以上版本的MySQL客户端工具连接Mycat时就会报密码错误。
解决方式主要有两种,一是指定mysql客户端连接时的加密方式。如下示例:
[root@txy-server ~]# mysql -uroot -p -P9066 -h227.0.0.1 --default-auth=mysql_native_password
二是采用5.x版本的MySQL客户端工具来连接 Mycat。如下示例:
[root@txy-server /usr/local/mysql-5.7.28]# bin/mysql -uroot -p -P9066 -h227.0.0.1
看完这篇文章,你能够独立解决Mycat整合MySQL过程报错的问题了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注创新互联行业资讯频道,感谢各位的阅读。
另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。
网站名称:Mycat整合MySQL过程报错的解决方法-创新互联
标题路径:https://www.cdcxhl.com/article42/didgec.html
成都网站建设公司_创新互联,为您提供ChatGPT、品牌网站建设、网站改版、企业网站制作、网站维护、面包屑导航
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联