SpringMVC与Tomcat JNDI配置数据源详解
2星 需积分: 50 152 浏览量
更新于2024-09-11
收藏 41KB DOCX 举报
"SpringMVC与JNDI在Tomcat服务器上的数据源配置方法,包括两种方式:单个应用独享数据源和全局JNDI数据源,并涉及常见配置及问题解决"
SpringMVC是一个广泛使用的Java Web框架,而JNDI(Java Naming and Directory Interface)是Java应用程序访问命名和目录服务的接口。在Tomcat服务器上配置数据源,可以通过JNDI来实现,这样可以提高代码的可重用性和灵活性。
一、简介
JNDI允许开发者通过名称来查找和访问资源,如数据库连接池。这种方式在多应用共享同一数据源的环境中非常有用,因为它减少了重复配置的负担。
二、Tomcat配置JNDI数据源的两种方式
1. 单个应用独享数据源
这种方式是将数据源配置在特定Web应用的`Context`节点下。例如,在`server.xml`中找到对应工程的`Context`节点,并添加`Resource`标签,定义数据源的属性,如数据库URL、用户名、密码等。这种方式简单但不便于多个应用共享数据源。
```xml
<Context docBase="Web" path="/Web" reloadable="true" source="org.eclipse.jst.jee.server:WebApp">
...
<Resource name="jndi/testdb" auth="Container"
type="javax.sql.DataSource"
driverClassName="com.mysql.jdbc.Driver"
url="jdbc:mysql://localhost:3306/appdb"
username="root"
password="123456"
maxActive="20"
maxIdle="10"
maxWait="10000"
removeAbandoned="true"
removeAbandonedTimeout="180"
logAbandoned="true"
factory="org.apache.tomcat.dbcp.dbcp.BasicDataSourceFactory"/>
...
</Context>
```
2. 配置全局JNDI数据源,应用于单个应用
全局数据源可以在`server.xml`的`GlobalNamingResources`节点下配置,然后所有应用都可以通过JNDI引用这个数据源。这种方法提高了重用性,但每个应用仍需明确引用该全局数据源。
```xml
<GlobalNamingResources>
...
<Resource name="jndi/testdb" auth="Container"
type="javax.sql.DataSource"
driverClassName="com.mysql.jdbc.Driver"
url="jdbc:mysql://localhost:3306/appdb"
username="root"
password="123456"
maxActive="20"
maxIdle="10"
maxWait="10000"
removeAbandoned="true"
removeAbandonedTimeout="180"
logAbandoned="true"
factory="org.apache.tomcat.dbcp.dbcp.BasicDataSourceFactory"/>
...
</GlobalNamingResources>
```
三、数据源配置在`context.xml`或`server.xml`的区别
配置在`context.xml`文件中的数据源只对当前Web应用生效,而配置在`server.xml`的`GlobalNamingResources`则对整个Tomcat实例有效。`context.xml`通常用于应用特定的配置,而`server.xml`用于全局配置。
四、常见报错及解决方案
配置数据源时可能会遇到的问题包括但不限于:
1. JNDI查找失败:检查数据源名称是否正确,以及应用是否正确引用了JNDI名称。
2. 驱动类找不到:确保已将JDBC驱动添加到Tomcat的`lib`目录或应用的类路径中。
3. 连接问题:确认数据库URL、用户名和密码是否正确,以及数据库服务是否运行正常。
4. 性能问题:根据应用需求调整数据源的最大连接数、空闲连接数等参数。
解决这些问题通常需要检查配置文件、日志输出和网络通信,以及可能需要查阅相关技术文档和社区资源。通过正确的配置和调试,可以确保数据源在SpringMVC应用中稳定高效地工作。
108 浏览量
122 浏览量
189 浏览量
115 浏览量
2021-10-05 上传
点击了解资源详情
hzh_猴哥
- 粉丝: 67
- 资源: 6
最新资源
- CM3技术参考手册-中文版
- wp-hookdoc:一个用于您的WordPress操作和过滤器的API文档生成器
- lwc-rest-explorer:使用LWC轻松实现Rest Explorer
- CS428_Project1
- Social Distancing Yahtzee-crx插件
- one-on-one:1个
- LitJson.rar
- nodejs-test:使用 Node.js 的 Hello World
- GitHubUpdates:Cocoa框架,用于从GitHub版本安装应用程序更新
- Model1.rar
- 彩色清新医疗图表PPT模板
- Jordy3D.github.io:CSS对我来说,就是所有人。 通常是对原始版本的改进
- ARM语言(汇编中文手册)
- cpp_metaprog_HandsOn_C++_c++template_metaprogramming_
- udacity-api:Udacity.com API 课程
- Tareas-Individuales:个人信息存储库