JNDI配置 | 学习笔记

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS MySQL,高可用系列 2核4GB
简介: 快速学习JNDI配置

开发者学堂课程【JDBC 数据库开发进阶JNDI配置】学习笔记,与课程紧密联系,让用户快速学习知识。

课程地址:https://developer.aliyun.com/learning/course/32/detail/688


JNDI配置


内容简介:

一、Tomcat 配置 JNDI 资源

二、获取资源

一、Tomcat 配置 JNDI 资源

JNDl (Java Naming and Directory Interface ),Java 命名和目录接口。

JNDl 的作用

在服务器上配置资源,然后通过统一的方式来获取配置的资源。

我们这里要配置的资源是连接池,这样项目中就可以通过统一的方式来获取连接池对象了。


1. Tomcat 中配置资源的格式如下:

type="com.mycompany.MyBean"

factory="org.apache.naming.factory.BeanFactory"

bar="23"/>


配置JNDI资源需要到  元素中配置  子元素:

① name :指定资源的名称,这个名称可以随便给,在获取资源时需要这个名称;

② factory :用来创建资源的工厂,这个值基本上是固定的,不用修改﹔

③ type :资源的类型,我们要给出的类型当然是我们连接池的类型了﹔  

④ bar :表示资源的属性,如果资源存在名为 bar 的属性,那么就配置 bar 的值。对于DBCP 连接池而言,你需要配置的不是 bar ,因为它没有 bar 这个属性,而是应该去配置 url、username 等属性。


2.按照给出文件配置资源

factory="org.apache.naming.factory.BeanFactory"

type="com.mchange.v2.c3p0.ComboPooledDataSource"

jdbcUrl="jdbc.mysql:// localhost : 3306 / mydb3 "

driverClass=" com. mysgl.jdbc.Driver"

user="root"

password="123"

acquireIncrement="5"

initialPoolSize="10"

/>


Dbcp 的配置

type="org.apache.tomcat.dbcp.dbcp.BasicDataSource"

factory="org.apache.naming.factory.BeanFactory"

username="root"

password="123"

driverClassName="com.mysal.jdbc.Driver"

url="jdbc:mysql://127.0.0.1/mydb1"

maxldle="3"

maxWait="5000"

maxActive="5"

initialSize="3" />


c3p0 的配置

type="com.mchange.v2.c3p0.ComboPooledDataSource"

factory="org.apache.naming.factory.BeanFactory"

user="root"

password="123"

classDriver="com.mysql.jdbc.Driver"

jdbcUrl="jdbc:mysql://127.0.0.1/mydb1"

maxPoolSize.="20"

minPoolSize ="5"

initialPoolSize="10"

acquirelncrement="2"/>



二、获取资源

配置资源的目的是为了获取资源,只要启动 Tomcat ,就可以在项目中通过 JNDI 获取资源的方式来获取资源。

1.获取资源的格式如下

下面一段代码与上面的配置资源是对应的。

Context initCtx =new InitialContext();

Context envCtx = (Context) initCtx.lookup("java:comp/env");

MyBean bean =(MyBean) envCtx.lookup ( "bean/MyBeanFactory");

writer.println ( "foo= " + bean.getFoo () + ", bar = " +

bean.getBar ());


获取资源:

①Context : jaxax.naming.Context ;  

②InitialContext: jaxax.naming.InitialContext;

③lookup(String):获取资源的方法,其中 "java.:comp/enx” 是资源的入口(这是固定的名称),获取过来的还是一个 Context ,这说明需要在获取到的 Context 上进一步进行获取。 "bean/MyBeanFactory" 对应  中配置的 name 值,这回获取的就是资源对象了。


2.按照配置获取资源

获取 JNDI 的资源

public class Aservlet extends HttpServlet {

public void doGet (HttpServletRequest request,HttpServletResponse response)  

throws ServletException,IOException {

①创建JND工的上下文对象

try {

Context cxt = new InitialContext( );

②查询出入口

Context envContext =(Context) cxt.lookup ( "java:comp/env");

③再进行二次查询,找到我们的资源,使用的是名称与元素的name对应

Datasource dataSource =(DataSource)envContext.lookup ("jdbc/dataSource");

connection con = dataSource.getConnection ( ) ;

System.out.println (con) ;

con.close() ;

}catch(Exception e) {

throw new RuntimeException (e) ;

}

}

}

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
Java 关系型数据库 程序员
|
Java 数据库连接 容器
|
网络协议 Java 程序员
|
Java 数据库连接 应用服务中间件
|
Java Spring
springboot jndi禁用
摘要:在实际项目开发中使用springboot的时候,可以使用jar包的方式运行项目,也可以将springboot项目打成war包使用。springboot war包运行可能会出现 [localhost-startStop-1] DEBUG org.
2357 0