jndi weblogic mysql_WebLogic配置JNDI数据源及在项目的使用方法

一、在WebLogic新建针对Oracle数据库的JNDI数据源

点击左侧【 域结构】→【base domain】 → 【服务】 → 【数据源】 然后点击右侧【 新建】 → 【般数据源】, 如下图所示:

041405330282100.png

填写JDBC数据源的【名称】、【jndi名称】,选择数据库类型,如选择【oracle】,下一步

f8d92430c53f708a13cbc3f859bcb308.png

选择Oracle数据库的驱动程序,如下图所示:

e8cd14aaf1edc0b9d0ce08e420d8b8a6.png

这里选择【Oracle' s Driver (Thin)for Instance connections;Version:Any】,点击【下一步】按钮,进入下一个配置步骤:

6d5a081a7a698cf0c263ef23a1071609.png

这里使用默认配置即可 ,点击【下一步】按钮,进入下一个配置步骤:如下图所示:

填写数据库的连接信息:要连接的数据库,数据库的IP地址,连接数据库时使用的端口号,登录数据库时使用的用户名和密码

597af64e552eeafd3d6deacc1d63a3f7.png

点击【下一步】按钮,进入下一个配置步骤:如下图所示:

fb1e5381f317d4edbf14576d2f941e0c.png

连接测试结果如下:

4a13e998692c9568aa1f6e04a07ef71a.png

点击【下一步】按钮,进入下一个配置步骤:如下图所示:

607d3d8548df0250db58285971592fc4.png

点击【完成】,这样WebLogic就会创建一个新的JDBC数据源,如下图所示:

45387220c624251e59d7540686efd4dc.png

到此,在WebLogic新建针对Oracle数据库的JNDI数据源就算是全部完成了。数据源创建之后,我们就可以在应用程序中使用数据源了。

二、在WebLogic新建针对MySQL数据库的JNDI数据源

上面我们已经配置好了一个针对Oracle数据库的JNDI数据源,这里我们在新建一个针对MySQL数据库的数据源,配置步骤和上述针对Oracle数据库创建的JDBC数据源大部分是一样的,针对不一样的地方给出如下的截图说明:

2f9daaf9d1b572267667bc31f4eade68.png

07306a694a5cfb40b92c09b1b7c9e8db.png

59e65f03199a3dd7a01d8b3cd2892590.png

beaff5777cb121985288ea2c8bf88862.png

9d6bbfd1f8099e72797cfbe89b4a89fc.png

60c5a66cc8a13b9340eff80ee2f5904f.png

到此,在WebLogic新建针对MySQL数据库的JNDI数据源就算是全部完成了。查看jndi树,可以看到JNDI树上面挂载了两个数据源,如下图所示:

de69eaab7a72b992df5d7b5ad7624063.png

三、在应用程序中使用WebLogic配置JNDI数据源

3.1、创建测试项目

新建一个测试项目,如下图所示:

0133ada409c750f545a9032a2f292ce2.png

3.2、编写测试代码

编写一个WebLogicJndiUtil工具类,用于从WebLogic的JNDI容器中取出数据源。

WebLogicJndiUtil工具类代码如下:

/**

*

*/

package me.gacl.util;

import java.sql.Connection;

import java.sql.SQLException;

import java.util.Properties;

import javax.naming.Context;

import javax.naming.InitialContext;

import javax.sql.DataSource;

/**

ClassName: WebLogicJndiUtil

Description: 获取WebLogic服务器中的JNDI数据源工具类

* @author xudp

* @version 1.0 V

* @createTime 2015-1-4 下午03:54:39

*/

public class WebLogicJndiUtil {

//初始化上下文需要用到的工厂类

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

//WebLogic服务器的访问地址

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

//WebLogic服务器中的JNDI数据源名称

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

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初始上下文信息

* @author xudp

* @return

* @throws Exception

*/

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数据库连接

* @author xudp

* @return

* @throws SQLException

*/

public static Connection getOracleConnection() throws SQLException {

return dsOracle.getConnection();

}

/**

* MethodName: getMySQLConnection

* Description: 获取MySQL数据库连接

* @author xudp

* @return

* @throws SQLException

*/

public static Connection getMySQLConnection() throws SQLException {

return dsMySQL.getConnection();

}

}

编写一个测试Servlet,JndiTestServlet的代码如下:

package me.gacl.test;

import java.io.IOException;

import java.sql.Connection;

import java.sql.ResultSet;

import java.sql.SQLException;

import java.sql.Statement;

import javax.servlet.ServletException;

import javax.servlet.http.HttpServlet;

import javax.servlet.http.HttpServletRequest;

import javax.servlet.http.HttpServletResponse;

import me.gacl.util.WebLogicJndiUtil;

/**

ClassName: JndiTestServlet

Description: 

* @author xudp

* @version 1.0 V

* @createTime 2015-1-4 下午03:37:53

*/

public class JndiTestServlet extends HttpServlet {

public void doGet(HttpServletRequest request, HttpServletResponse response)

throws ServletException, IOException {

//Oracle数据库连接对象

Connection oracleConn = null;

//MySQL数据库连接对象

Connection mysqlConn = null;

Statement stmt = null;

ResultSet rs = null;

try {

String sqlOracle = "SELECT * FROM LEAD_OAMS_APPLICATIONS";

//获取数据库连接对象

oracleConn = WebLogicJndiUtil.getOracleConnection();

stmt = oracleConn.createStatement();

rs = stmt.executeQuery(sqlOracle);

while (rs.next()) {

System.out.println(rs.getString("RESOURCEID")+"---"+rs.getString("APP_NAME"));

}

System.out.println("-----------------------------分割线-------------------------------------");

String sqlMySQL = "SELECT * FROM LEAD_OAMS_DBSOURCES";

//获取数据库连接对象

mysqlConn = WebLogicJndiUtil.getMySQLConnection();

stmt = mysqlConn.createStatement();

rs = stmt.executeQuery(sqlMySQL);

while (rs.next()) {

System.out.println(rs.getString("RESOURCEID")+"---"+rs.getString("DBSOURCE_NAME"));

}

} catch (SQLException e) {

e.printStackTrace();

}finally{

try {

rs.close();

stmt.close();

oracleConn.close();

} catch (SQLException e) {

e.printStackTrace();

}

}

}

public void doPost(HttpServletRequest request, HttpServletResponse response)

throws ServletException, IOException {

doGet(request,response);

}

}

在Web.xml文件中注册JndiTestServlet,如下:

JndiTestServlet

me.gacl.test.JndiTestServlet

JndiTestServlet

/servlet/JndiTestServlet

将测试项目部署到WebLogic服务器中运行,如下图所示:

e1ff2ce7b750bffcb3a8a15fd9337c30.png

输入JndiTestServlet的访问地址:http://localhost:7001/WebLogic_Jndi_Test/servlet/JndiTestServlet进行测试,如下图所示:

bb805911cf86078e4517c5e553e1b854.png

访问JndiTestServlet的过程中没有出现任何错误,后台的控制台中输出了从数据库中取出来的数据,如下图所示:

b62ff9883eaec0e7715afc51be33c79f.png

这就证明了我们已经成功地从WebLogic服务器中的JNDI树中取出了JDBC数据源,再通过数据源获取到了数据库连接,执行SQL从数据库中查询出数据。

以上就是关于在WebLogic配置JNDI数据源以及如何在应用程序中使用配置好的JNDI数据源的全部内容。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值