日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

java weblogic连接池,Weblogic JNDI 方式连接连接池 (工作中遇到的问题)

發布時間:2023/12/19 编程问答 23 豆豆
生活随笔 收集整理的這篇文章主要介紹了 java weblogic连接池,Weblogic JNDI 方式连接连接池 (工作中遇到的问题) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

背景描述

工作中客戶的代碼中沒有alter session set nls_date_format = 'YYYY-MM-DD HH24:MI:SS',這個sql,可是agent每條請求平均抓了60次,用戶“要一個說法”

weblogic使用JNDI

自行配置

往下拉這里有一個測試的表名需要注意下,可能跟下面的錯誤有關系,不能使oracl關鍵字ORA

點擊剛剛新建的

往下拉下面有一個高級點開

填入sql,并點擊下方的保存

目標,點擊服務器,并保存。這里如果不點會報錯,下面有記錄,如果保存的時候有報錯,下面也有記錄,不要著急,往下看。

測試代碼

demo1(我用這個成功了)

package com.leesin;

import javax.naming.Context;

import javax.naming.InitialContext;

import javax.naming.NamingException;

import javax.sql.DataSource;

import java.sql.Connection;

import java.sql.ResultSet;

import java.sql.SQLException;

import java.sql.Statement;

public class Jndi_test {

public static void main(String[] args) {

Connection conn = null;

try {

Context ctx = new InitialContext();

//tomcat連接池

//DataSource ds=(DataSource)ctx.lookup("java:comp/env/mysql55");

//weblogic連接池

//lookup后面的是jndi的名字,在weblogic中進行配置

//必須和上面配置的一致。

DataSource ds = (DataSource) ctx.lookup("leesin");

conn = ds.getConnection();

Statement stmt6 = conn.createStatement();//創建一個Statement對象

String sql7 = "SELECT * FROM student";//生成一條sql語句

ResultSet rs17 = stmt6.executeQuery(sql7);//執行查詢,把查詢結果賦值給結果集對象

System.out.println("編號 \t 姓名 \t 工資 -------statment");

while (rs17.next()) {

System.out.println(rs17.getString(1) + "\t" + rs17.getString(2) + "\t" + rs17.getString(3));

}

} catch (NamingException e) {

e.printStackTrace();

} catch (

SQLException e) {

e.printStackTrace();

}

}

}

下面的demo2,private final static String PROVIDER_URL = “t3://10.0.2.90:7001”;有這句話,這里dmeo1沒有問題,可能默認是localhost的,因為要部署到weblogic上運行。

demo2

package com.leesin;

import java.sql.Connection;

import java.sql.SQLException;

import java.util.Properties;

import javax.naming.Context;

import javax.naming.InitialContext;

import javax.sql.DataSource;

public class WebLogicJndiUtil {

//初始化上下文需要用到的工廠類

private final static String INITIAL_CONTEXT_FACTORY = "weblogic.jndi.WLInitialContextFactory";

//WebLogic服務器的訪問地址

private final static String PROVIDER_URL = "t3://10.0.2.90:7001";

//WebLogic服務器中的JNDI數據源名稱

//private final static String ORACLE_JNDI_NAME = "JNDI/OracleDataSource";

private final static String ORACLE_JNDI_NAME = "leesin";

private final static String MYSQL_JNDI_NAME = "JNDI/MysqlDataSource";

//存儲從JNDI容器中取出來的數據源

private static DataSource dsOracle = null;

private static DataSource dsMySQL = null;

static {

try {

//初始化WebLogic Server的JNDI上下文信息

Context context = getInitialContext();

//獲取數據源對象

dsOracle = (DataSource) context.lookup(ORACLE_JNDI_NAME);

dsMySQL = (DataSource) context.lookup(MYSQL_JNDI_NAME);

} catch (Exception e) {

e.printStackTrace();

}

}

/**

* MethodName: getInitialContext

* Description: 獲得WebLogic ServerJNDI初始上下文信息

*

* @return

* @throws Exception

* @author xudp

*/

private static Context getInitialContext() throws Exception {

Properties properties = new Properties();

properties.put(Context.INITIAL_CONTEXT_FACTORY, INITIAL_CONTEXT_FACTORY);

properties.put(Context.PROVIDER_URL, PROVIDER_URL);

return new InitialContext(properties);

}

/**

* MethodName: getOracleConnection

* Description: 獲取Oracle數據庫連接

*

* @return

* @throws SQLException

* @author xudp

*/

public static Connection getOracleConnection() throws SQLException {

return dsOracle.getConnection();

}

/**

* MethodName: getMySQLConnection

* Description: 獲取MySQL數據庫連接

*

* @return

* @throws SQLException

* @author xudp

*/

public static Connection getMySQLConnection() throws SQLException {

return dsMySQL.getConnection();

}

}

然后調用這個類的getOracleConnection方法得到connection即可。

報錯 javax.naming.NameNotFoundException: Unable to resolve ‘leesin’. Resolved ‘’; remaining name ‘leesin’

<2019-8-20 下午06時09分55秒 CST>

javax.naming.NameNotFoundException: Unable to resolve 'leesin'. Resolved ''; remaining name 'leesin'

at weblogic.jndi.internal.BasicNamingNode.newNameNotFoundException(BasicNamingNode.java:1139)

at weblogic.jndi.internal.BasicNamingNode.lookupHere(BasicNamingNode.java:252)

at weblogic.jndi.internal.ServerNamingNode.lookupHere(ServerNamingNode.java:182)

at weblogic.jndi.internal.BasicNamingNode.lookup(BasicNamingNode.java:206)

at weblogic.jndi.internal.WLEventContextImpl.lookup(WLEventContextImpl.java:254)

at weblogic.jndi.internal.WLContextImpl.lookup(WLContextImpl.java:412)

at javax.naming.InitialContext.lookup(InitialContext.java:417)

at com.leesin.WebLogicJndiUtil.(WebLogicJndiUtil.java:29)

at com.leesin.Jndi_test.main(Jndi_test.java:23)

at com.leesin.Servlet.doGet(Servlet.java:39)

at javax.servlet.http.HttpServlet.service(HttpServlet.java:707)

at javax.servlet.http.HttpServlet.service(HttpServlet.java:820)

at weblogic.servlet.internal.StubSecurityHelper$ServletServiceAction.run(StubSecurityHelper.java:227)

at weblogic.servlet.internal.StubSecurityHelper.invokeServlet(StubSecurityHelper.java:125)

at weblogic.servlet.internal.ServletStubImpl.execute(ServletStubImpl.java:301)

at weblogic.servlet.internal.ServletStubImpl.execute(ServletStubImpl.java:184)

at weblogic.servlet.internal.WebAppServletContext$ServletInvocationAction.wrapRun(WebAppServletContext.java:3732)

at weblogic.servlet.internal.WebAppServletContext$ServletInvocationAction.run(WebAppServletContext.java:3696)

at weblogic.security.acl.internal.AuthenticatedSubject.doAs(AuthenticatedSubject.java:321)

at weblogic.security.service.SecurityManager.runAs(SecurityManager.java:120)

at weblogic.servlet.internal.WebAppServletContext.securedExecute(WebAppServletContext.java:2273)

at weblogic.servlet.internal.WebAppServletContext.execute(WebAppServletContext.java:2179)

at weblogic.servlet.internal.ServletRequestImpl.run(ServletRequestImpl.java:1490)

at weblogic.work.ExecuteThread.execute(ExecuteThread.java:256)

at weblogic.work.ExecuteThread.run(ExecuteThread.java:221)

解決方法:

在Weblogic數據源管理中的

JDBC Data Source-0的設置

中設置目標選項

將服務勾選上,如默認的:AdminServer

保存后即可;

會報如下的錯誤

java.sql.SQLSyntaxErrorException: ORA-00903: 表名無效

這句話的意思是ORA-00903是oracle的關鍵字,不能使用,我的demo中沒有使用啊,回想一下,我在建立連接池的時候,添加了一個初始化的sql,會不會是這個原因呢?

當然我上面有記錄,也可能跟那個有關系。

后來換了一個weblogic就可以了,可能是版本的問題。

之后就能成功連接了。

文章:

https://blog.csdn.net/wx5040257/article/details/77926540

https://blog.csdn.net/weixin_37264997/article/details/84820316

https://blog.csdn.net/acmman/article/details/70146603

創作挑戰賽新人創作獎勵來咯,堅持創作打卡瓜分現金大獎

總結

以上是生活随笔為你收集整理的java weblogic连接池,Weblogic JNDI 方式连接连接池 (工作中遇到的问题)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。