springmvc+druid+dataSource配置的两种⽅式
⼀、⼀般的配置⽅式
数据库连接配置在jdbc.properties⽂件中,这种⽅式有⼀个最⼤的缺点,数据库的配置信息对开发⼈员是完全可见的,⼗分⽅便程序员删库跑路。spring配置具体如下:
1、jdbc.properties⽂件:
sql.jdbc.Driver
url=jdbc:mysql://127.0.0.1:3306/test_table?useUnicode=true&characterEncoding=UTF-8&zeroDateTimeBehavior=convertToNull&allowMultiQueries=true& username=root
password=root
2、spring和druid配置:
<!-- 引⼊配置⽂件 -->
<bean id="propertyConfigurer"
class="org.springframework.fig.PropertyPlaceholderConfigurer">
<property name="location" value="classpath:jdbc.properties"/>
</bean>
<!-- JDBC Data Source. It is assumed you have MySQL running on localhost
port 3306 with username root and blank password. Change below if it's not
the case -->
<bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource" init-method="init" destroy-method="close">
<property name="driverClassName" value="${driver}"/>
<!-- 基本属性 url、user、password -->
<property name="url" value="${url}"/>
<property name="username" value="${username}"/>
<property name="password" value="${password}"/>
<!-- 配置初始化⼤⼩、最⼩、最⼤ -->
<property name="initialSize" value="1"/>
<property name="minIdle" value="1"/>
<property name="maxActive" value="20"/>
<!-- 配置获取连接等待超时的时间 -->
<property name="maxWait" value="60000"/>
<!-- 配置间隔多久才进⾏⼀次检测,检测需要关闭的空闲连接,单位是毫秒 -->
<property name="timeBetweenEvictionRunsMillis" value="60000"/>
<!-- 配置⼀个连接在池中最⼩⽣存的时间,单位是毫秒 -->
<property name="minEvictableIdleTimeMillis" value="300000"/>
<property name="validationQuery" value="SELECT 'x'"/>
<property name="testWhileIdle" value="true"/>
<property name="testOnBorrow" value="false"/>
<property name="testOnReturn" value="false"/>
<!-- 打开PSCache,并且指定每个连接上PSCache的⼤⼩ -->
<property name="poolPreparedStatements" value="false"/>
<property name="maxPoolPreparedStatementPerConnectionSize" value="20"/>
<!-- 配置监控统计拦截的filters -->
<property name="filters" value="stat"/>
</bean>
以上简单的配置就好了。
⼆、JNDI配置⽅式
JNDI需要配置spring和web容器(tomcat)相关配置⽂件(l),这种配置的优点是spring配置中只包含jndi的名称,开发者看不到到具体数据库的账号和密码,为程序员删库跑路增加了难度。
1、Tomcat中l配置如下:
<Resource
name="jdbc/erp"
factory="com.alibaba.druid.pool.DruidDataSourceFactory"
auth="Container"
spring framework jar包type="javax.sql.DataSource"
driverClassName="sql.jdbc.Driver"
url="jdbc:mysql://192.168.1.7:3306/test_table?useUnicode=true&characterEncoding=UTF-8&zeroDateTimeBehavior=convertToNull&allowMultiQueries=true&"            username="root"
password="root"
maxActive="50"
maxWait="10000"
removeabandoned="true"
removeabandonedtimeout="60"
logabandoned="false"
filters="stat"/>
2、除此之外在Tomcat中lib添加mysql和druid⾹⽠两个jar:
mysql-connector-java-5.1.38.jar
druid-1.0.18.jar
3、spring配置
<bean id="dataSource" class="org.springframework.jndi.JndiObjectFactoryBean">
<property name="jndiName" value="java:comp/env/jdbc/erp"/>
</bean>
⼩结:推荐第⼆种JNDI的配置⽅式,对于第⼆种配置⽅式,开发者在本地Tomcat配置开发的数据库信息,⽣产环境Tomcat配置⽣产数据链接信息,⽣产数据对开发者不可见。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。