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數據源的全部內容。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章