数据库连接池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);
相关推荐
李广坤2 小时前
MySQL 大表字段变更实践(改名 + 改类型 + 改长度)
数据库
Turnip12021 天前
深度解析:为什么简单的数据库"写操作"会在 MySQL 中卡住?
后端·mysql
爱可生开源社区1 天前
2026 年,优秀的 DBA 需要具备哪些素质?
数据库·人工智能·dba
随逸1771 天前
《从零搭建NestJS项目》
数据库·typescript
加号32 天前
windows系统下mysql多源数据库同步部署
数据库·windows·mysql
シ風箏2 天前
MySQL【部署 04】Docker部署 MySQL8.0.32 版本(网盘镜像及启动命令分享)
数据库·mysql·docker
大大水瓶2 天前
Tomcat
java·tomcat
李慕婉学姐2 天前
Springboot智慧社区系统设计与开发6n99s526(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端
百锦再2 天前
Django实现接口token检测的实现方案
数据库·python·django·sqlite·flask·fastapi·pip
WeiXin_DZbishe2 天前
基于django在线音乐数据采集的设计与实现-计算机毕设 附源码 22647
javascript·spring boot·mysql·django·node.js·php·html5