数据库连接池JNDI

数据库JNDI连接池

数据源(DataSource)javax.sql.DataSource接口负责建立与数据库的连接由Tomcat提供,将连接保存在连接池中

因为这个数据库连接池是配置在Tomcat中的,一旦换了Tomcat,就不能用,所以很少用这个JNDI

配置 Tomcat 中的数据源并使用 JNDI 获取数据库连接的过程可以分为几个步骤 :

1.apache-tomcat-9.0.30\conf\content.xml中的<Context>设置

注意:

  1. username修改成自己的数据库用户名
  2. password修改成自己的数据库密码
  3. url 把这个url的端口和数据库名称修改成自己的

name 指定Resource的JNDI名称

Container 指定管理Resource的Manager

type 指定Resource所属的Java类

maxActive 指定连接池中处于活动状态的数据库连接的最大数目

maxIdle 指定连接池中处于空闲状态的数据库连接的最大数目

maxWait 指定连接池中的连接处于空闲的最长时间

复制代码
	<Resource name="jdbc/smbms" 
              auth="Container"  type="javax.sql.DataSource"  maxActive="100" 
              maxIdle="30" maxWait="10000" username="root"  password="root" 
              driverClassName="com.mysql.jdbc.Driver" 
              url="jdbc:mysql://127.0.0.1:3306/javaweb_test"/>
2. 配置数据库驱动

确保 JDBC 驱动已添加到 Tomcat 的 lib 目录中,例如 MySQL 驱动 mysql-connector-java-X.X.X.jar,

3.获取连接对象

=把这个放到BaseDao中,这是获取conn连接的

复制代码
Context ctx = new InitialContext();
DataSource ds = (DataSource) ctx.lookup("java:comp/env/jdbc/javaweb_test");
Connection conn = ds.getConnection();
out.println(conn);
相关推荐
m0_4954964128 分钟前
mysql处理复杂SQL性能_InnoDB优化器与MyISAM差异
jvm·数据库·python
forEverPlume1 小时前
PHP怎么使用Eloquent Attribute Composition属性组合_Laravel通过组合构建复杂属性【方法】
jvm·数据库·python
2301_809204702 小时前
mysql在docker容器中如何部署_利用docker-compose快速启动
jvm·数据库·python
虹科网络安全2 小时前
艾体宝产品|深度解读 Redis 8.4 新增功能:原子化 Slot 迁移(上)
数据库·redis·bootstrap
阿坤带你走近大数据2 小时前
怎么查看当前oracle库下的表空间temp大小或者默认大小
数据库·oracle
yoyo_zzm2 小时前
Laravel8.x新特性全解析
数据库·nginx
码界奇点3 小时前
基于Python的新浪微博数据爬虫系统设计与实现
数据库·爬虫·python·毕业设计·新浪微博·源代码管理
我科绝伦(Huanhuan Zhou)3 小时前
探索技术世界:我的GitHub数据库工具宝库
数据库·github
猫的玖月4 小时前
(一)MY SQL概述
数据库·sql
脑子进水养啥鱼?4 小时前
PostgreSQL .history 文件
数据库·postgresql