weblogic服務建立數據源連接測試更新mysql驅動包的問題及解決方法
WebLogic是美國Oracle公司出品的一個application server,確切的說是一個基於JAVAEE架構的中間件,WebLogic是用於開發、集成、部署和管理大型分佈式Web應用、網絡應用和數據庫應用的Java應用服務器。將Java的動態功能和Java Enterprise標準的安全性引入大型網絡應用的開發、集成、部署和管理之中。下面介紹下weblogic服務建立數據源連接測試更新mysql驅動包的問題及解決方法。
1、mysql服務搭建
如果有需要的請移步連接:Docker簡單部署mysql
2、weblogic控制臺建立數據源並測試
數據庫類型:MySQL;其他保持默認即可
其他步驟保持默認即可,一直下一步到配置連接
進行配置測試環節
問題處理1
測試不通過,錯誤如下
錯誤 連接測試失敗。
錯誤 Unable to load authentication plugin 'caching_sha2_password'.
com.mysql.jdbc.SQLError.createSQLException(SQLError.java:910)
com.mysql.jdbc.SQLError.createSQLException(SQLError.java:907)
com.mysql.jdbc.MysqlIO.proceedHandshakeWithPluggableAuthentication(MysqlIO.java:1715)
com.mysql.jdbc.MysqlIO.doHandshake(MysqlIO.java:1244)
com.mysql.jdbc.ConnectionImpl.coreConnect(ConnectionImpl.java:2396)
com.mysql.jdbc.ConnectionImpl.connectOneTryOnly(ConnectionImpl.java:2429)
com.mysql.jdbc.ConnectionImpl.createNewIO(ConnectionImpl.java:2214)
com.mysql.jdbc.ConnectionImpl.<init>(ConnectionImpl.java:797)
com.mysql.jdbc.JDBC4Connection.<init>(JDBC4Connection.java:31)
sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:62)
sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45)
java.lang.reflect.Constructor.newInstance(Constructor.java:423)
com.mysql.jdbc.Util.handleNewInstance(Util.java:395)
com.mysql.jdbc.ConnectionImpl.getInstance(ConnectionImpl.java:383)
com.mysql.jdbc.NonRegisteringDriver.connect(NonRegisteringDriver.java:334)
weblogic.jdbc.common.internal.DataSourceUtil.testConnection0(DataSourceUtil.java:340)
weblogic.jdbc.common.internal.DataSourceUtil.access$000(DataSourceUtil.java:22)
weblogic.jdbc.common.internal.DataSourceUtil$1.run(DataSourceUtil.java:254)
註意第一行(一般也是最重要的)Unable to load authentication plugin 'caching_sha2_password'.
原因:
不同版本的身份驗證機制不同
5.X版本:default_authentication_plugin=mysql_native_password
8.x版本:default_authentication_plugin=caching_sha2_password
解決:
登陸mysql控制臺執行一下命令
查看權限以及身份驗證機制命令:
select host,user,plugin,authentication_string from mysql.user; ALTER USER 'root'@'%' IDENTIFIED BY '12345' PASSWORD EXPIRE NEVER; ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY '12345'; FLUSH PRIVILEGES; alter user 'root'@'%' identified by '12345';
mysql> ALTER USER 'root'@'%' IDENTIFIED BY '12345' PASSWORD EXPIRE NEVER; # 修改加密規則 Query OK, 0 rows affected (0.01 sec) mysql> ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY '12345'; # 更新一下用戶的密碼 Query OK, 0 rows affected (0.00 sec) mysql> FLUSH PRIVILEGES; Query OK, 0 rows affected (0.00 sec) mysql> alter user 'root'@'%' identified by '12345'; # 重置密碼 Query OK, 0 rows affected (0.00 sec)
問題處理2
上面執行操作之後,重新測試連接
java.lang.ClassCastException: java.math.BigInteger cannot be cast to java.lang.Long
com.mysql.jdbc.SQLError.createSQLException(SQLError.java:1058)
類轉換異常,查看mysql日志信息docker logs mysql
mbind: Operation not permitted
原因:
在 ODI 12.2.1.4 中添加瞭 MySQL Database Server 8 作為 Source/Target 的認證。較舊的 ODI 12c 版本未經認證。
解決:
升級到通過 MySQL 8 認證的 Oracle Data Integrator 版本 12.2.1.4 或更高版本。
步驟1:(猜測這一步可有可無,下來自己測試,我是操作瞭的)
1.拷貝mysql8的驅動包到weblogic目錄下
/home/weblogic/Oracle/Middleware/wlserver/server/lib/mysql-connector-java-8.0.22.jar
2.修改wlserver/common/bin/commEnv.sh
文件的weblogic_classpath=<驅動包路徑>
export weblogic_classpath="/home/weblogic/Oracle/Middleware/wlserver/server/lib/mysql-connector-java-8.0.22.jar"
步驟2:(感覺是最關鍵的)
- 拷貝驅動包到域的lib目錄下,如:
/home/weblogic/Oracle/Middleware/user_projects/domains/basicWLSDomain/lib
- 修改驅動程序類型為
com.mysql.cj.jdbc.Driver
- 連接測試,ok
到此完美收官!
到此這篇關於weblogic服務建立數據源連接測試更新mysql驅動包的文章就介紹到這瞭,更多相關weblogic數據源連接測試內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- Windows Server 2019 MySQL數據庫的安裝與配置理論+遠程連接篇
- mysql8.0.27配置步驟以及註意事項
- MySQL8.0.23版本的root密碼重置最優解法
- 詳細介紹windows下MySQL安裝教程
- Oracle更換為MySQL遇到的問題及解決