WebLogic使用总结(三)——WebLogic配置JNDI数据源

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

  进入weblogic管理控制台,此处是远程访问:http://192.168.1.144:7001/console

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

  

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

  

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

  

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

  

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

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

  

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

  

  连接测试结果如下:

  

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

  

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

  

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

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

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

  

  

  

  

  

  

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

  

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

3.1、创建测试项目

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

  

3.2、编写测试代码

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

  WebLogicJndiUtil工具类代码如下:

 1 /**
 2  *
 3  */
 4 package me.gacl.util;
 5
 6 import java.sql.Connection;
 7 import java.sql.SQLException;
 8 import java.util.Properties;
 9
10 import javax.naming.Context;
11 import javax.naming.InitialContext;
12 import javax.sql.DataSource;
13
14 /**
15  * <p>ClassName: WebLogicJndiUtil<p>
16  * <p>Description: 获取WebLogic服务器中的JNDI数据源工具类<p>
17  * @author xudp
18  * @version 1.0 V
19  * @createTime 2015-1-4 下午03:54:39
20  */
21 public class WebLogicJndiUtil {
22
23     //初始化上下文需要用到的工厂类
24     private final static String INITIAL_CONTEXT_FACTORY="weblogic.jndi.WLInitialContextFactory";
25     //WebLogic服务器的访问地址
26     private final static String PROVIDER_URL="t3://192.168.1.144:7001";
27     //WebLogic服务器中的JNDI数据源名称
28     private final static String ORACLE_JNDI_NAME="JNDI/OracleDataSource";
29     private final static String MYSQL_JNDI_NAME="JNDI/MysqlDataSource";
30
31     //存储从JNDI容器中取出来的数据源
32     private static DataSource dsOracle = null;
33     private static DataSource dsMySQL = null;
34
35     static {
36         try {
37             //初始化WebLogic Server的JNDI上下文信息
38             Context context = getInitialContext();
39             //获取数据源对象
40             dsOracle = (DataSource) context.lookup(ORACLE_JNDI_NAME);
41             dsMySQL = (DataSource) context.lookup(MYSQL_JNDI_NAME);
42         } catch (Exception e) {
43             e.printStackTrace();
44         }
45     }
46
47     /**
48      * MethodName: getInitialContext
49      * Description: 获得WebLogic ServerJNDI初始上下文信息
50      * @author xudp
51      * @return
52      * @throws Exception
53      */
54     private static Context getInitialContext() throws Exception {
55         Properties properties = new Properties();
56         properties.put(Context.INITIAL_CONTEXT_FACTORY, INITIAL_CONTEXT_FACTORY);
57         properties.put(Context.PROVIDER_URL, PROVIDER_URL);
58         return new InitialContext(properties);
59     }
60
61     /**
62      * MethodName: getOracleConnection
63      * Description: 获取Oracle数据库连接
64      * @author xudp
65      * @return
66      * @throws SQLException
67      */
68     public static Connection getOracleConnection() throws SQLException {
69         return dsOracle.getConnection();
70     }
71
72     /**
73      * MethodName: getMySQLConnection
74      * Description: 获取MySQL数据库连接
75      * @author xudp
76      * @return
77      * @throws SQLException
78      */
79     public static Connection getMySQLConnection() throws SQLException {
80         return dsMySQL.getConnection();
81     }
82 }

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

 1 package me.gacl.test;
 2
 3 import java.io.IOException;
 4 import java.sql.Connection;
 5 import java.sql.ResultSet;
 6 import java.sql.SQLException;
 7 import java.sql.Statement;
 8
 9 import javax.servlet.ServletException;
10 import javax.servlet.http.HttpServlet;
11 import javax.servlet.http.HttpServletRequest;
12 import javax.servlet.http.HttpServletResponse;
13
14 import me.gacl.util.WebLogicJndiUtil;
15
16 /**
17  * <p>ClassName: JndiTestServlet<p>
18  * <p>Description: <p>
19  * @author xudp
20  * @version 1.0 V
21  * @createTime 2015-1-4 下午03:37:53
22  */
23 public class JndiTestServlet extends HttpServlet {
24
25     public void doGet(HttpServletRequest request, HttpServletResponse response)
26             throws ServletException, IOException {
27         //Oracle数据库连接对象
28         Connection oracleConn = null;
29         //MySQL数据库连接对象
30         Connection mysqlConn = null;
31         Statement stmt = null;
32         ResultSet rs = null;
33         try {
34             String sqlOracle = "SELECT * FROM LEAD_OAMS_APPLICATIONS";
35             //获取数据库连接对象
36             oracleConn = WebLogicJndiUtil.getOracleConnection();
37             stmt = oracleConn.createStatement();
38             rs = stmt.executeQuery(sqlOracle);
39             while (rs.next()) {
40                 System.out.println(rs.getString("RESOURCEID")+"---"+rs.getString("APP_NAME"));
41             }
42             System.out.println("-----------------------------分割线-------------------------------------");
43
44             String sqlMySQL = "SELECT * FROM LEAD_OAMS_DBSOURCES";
45             //获取数据库连接对象
46             mysqlConn = WebLogicJndiUtil.getMySQLConnection();
47             stmt = mysqlConn.createStatement();
48             rs = stmt.executeQuery(sqlMySQL);
49             while (rs.next()) {
50                 System.out.println(rs.getString("RESOURCEID")+"---"+rs.getString("DBSOURCE_NAME"));
51             }
52         } catch (SQLException e) {
53             e.printStackTrace();
54         }finally{
55             try {
56                 rs.close();
57                 stmt.close();
58                 oracleConn.close();
59             } catch (SQLException e) {
60                 e.printStackTrace();
61             }
62         }
63     }
64
65     public void doPost(HttpServletRequest request, HttpServletResponse response)
66             throws ServletException, IOException {
67         doGet(request,response);
68     }
69 }

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

1 <servlet>
2     <servlet-name>JndiTestServlet</servlet-name>
3     <servlet-class>me.gacl.test.JndiTestServlet</servlet-class>
4 </servlet>
5
6 <servlet-mapping>
7     <servlet-name>JndiTestServlet</servlet-name>
8     <url-pattern>/servlet/JndiTestServlet</url-pattern>
9 </servlet-mapping>

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

  

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

  

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

  

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

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

时间: 2024-08-11 23:33:56

WebLogic使用总结(三)——WebLogic配置JNDI数据源的相关文章

weblogic配置JNDI数据源

因项目需要使用多数据源,因此要使用JNDI方式去配置,在此留下操作步骤. # 启动Admin Server Console #登录到管理系统选择数据源节点 #新建数据源 #配置数据源信息 * 上面那个设置数据源名称 * JNDI名称和数据源名称可以相同也可以不相同,建议按照jdbc.XXX这种格式创建(测试时使用myname名字有点问题) * 数据库选择对应类型即可 #选择数据库驱动 这个可以随便选择一个,后面可以修改 #这一步直接下一步 #配置数据源信息 #测数据源链接 #部署数据源,点击完成

在Tomcat配置JNDI数据源的三种方式

在Tomcat配置JNDI数据源的三种方式 分类: java进阶2012-07-01 10:24 18328人阅读 评论(0) 收藏 举报 tomcatjdbcweblogicmysqlbean测试 目录(?)[+] 在我过去工作的过程中,开发用服务器一般都是Tomcat 数据源的配置往往都是在applicationContext.xml中配置一个dataSource的bean 然后在部署时再修改JNDI配置 我猜是因为Tomcat的配置需要改配置文件 不像JBoss,Weblogic等服务器在

JNDI学习总结(三)——Tomcat下使用Druid配置JNDI数据源

com.alibaba.druid.pool.DruidDataSourceFactory实现了javax.naming.spi.ObjectFactory,可以作为JNDI数据源来配置. 一.下载Druid的jar包 下载地址:http://mvnrepository.com/artifact/com.alibaba/druid/1.0.9,如下图所示: druid.jar依赖log4j的jar包,所以还需要下载log4j的jar包. log4j的下载地址如下:http://mvnreposi

JNDI学习总结(二)——Tomcat下使用C3P0配置JNDI数据源

一.C3P0下载 C3P0下载地址:http://sourceforge.net/projects/c3p0/files/?source=navbar 下载完成之后得到一个压缩包. 二.使用C3P0配置JNDI数据源 Tomcat6.x中配置JNDI数据源时默认使用的是Tomcat6.x自带的DBCP连接池,Tomcat6.x使用DBCP连接池配置JNDI数据源如下: 1 <Resource 2 name="oracleDataSource" 3 auth="Conta

Tomcat配置JNDI数据源

本文将介绍Tomcat配置JNDI数据源的方法,主要分为配置局部数据源(仅供单个应用使用)和全局数据源(所有用该Tomcat的应用都可以使用) 一.思考 从我们学习Web开发以来,我们都是通过程序代码来实现数据库的访问的.从一开始直接将数据库配置信息写在代码中,到后来将配置信息抽取出来写在了Properties文件中,我们访问数据库的代码更加精简. 而通过JNDI方式访问数据库则更为直接,JNDI连接数据库的方式直接将数据库信息放在Tomcat中,而项目代码里直接通过JNDI技术就可以得到数据源

Tomcat配置JNDI数据源的三种方式

第一种,单个应用独享数据源 就一步,找到Tomcat的server.xml找到工程的Context节点,添加一个私有数据源 Xml代码   <Context docBase="WebApp" path="/WebApp" reloadable="true" source="org.eclipse.jst.jee.server:WebApp"> <Resource name="jdbc/mysql&q

Tomcat下使用c3p0配置jndi数据源

下载c3p0包: 下载地址:https://sourceforge.net/projects/c3p0/files/?source=navbar 解压后得到包:c3p0-0.9.2.jar,mchange-commons-java-0.2.11.jar 下载mysql包: 下载地址:http://download.csdn.net/download/u010802461/9579306 解压后得到包:mysql-connector-java-5.1.39-bin.jar(笔者这里没有是因为我将包

Eclipse +Tomcat配置JNDI数据源

以下是具体配置的步骤: 1.首先配置Tomcat下的jndi数据源.具体存放目录apache-tomcat-7.0.59\conf\Catalina\localhost 下 osh.xml <?xml version='1.0' encoding='utf-8'?> <Context docBase="G:\sbwork\oshome\WebContent" reloadable="false" path="/osh">

图解WildFly8.x配置JNDI数据源

最近公司一直在推广使用JBoss,以前用的要么是Tomcat,要么是IBM的WAS,这里记录一下自己的转型过程,首先是安装Eclipse插件,具体步骤如下,如果是代理上网的,要在Eclipse里设置代理. 设置好后接下来配置数据源: 有两种配置方式,一是在jboss的xml配置文件里设置,另一种是在jboss的管理后台进行图形界面化的设置,而图形界面化的设置本质是还是对XML配置文件的设置,界面化的设置如下: 然后是设置JNDI名称: 选择数据库的驱动,这个要和具体的数据库相关了,总之要让Jbo