数据库JNDI连接池
数据源(DataSource)javax.sql.DataSource接口负责建立与数据库的连接由Tomcat提供,将连接保存在连接池中
因为这个数据库连接池是配置在Tomcat中的,一旦换了Tomcat,就不能用,所以很少用这个JNDI
配置 Tomcat 中的数据源并使用 JNDI 获取数据库连接的过程可以分为几个步骤 :
1.apache-tomcat-9.0.30\conf\content.xml中的<Context>设置
注意:
- username修改成自己的数据库用户名
- password修改成自己的数据库密码
- 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);