1. 程式人生 > >springmvc+druid+dataSource配置的兩種方式

springmvc+druid+dataSource配置的兩種方式

連接 between ida 等待 ext 基本屬性 scac framework 文件

一、一般的配置方式

數據庫連接配置在jdbc.properties文件中,這種方式有一個最大的缺點,數據庫的配置信息對開發人員是完全可見的,十分方便程序員刪庫跑路。spring配置具體如下:

1、jdbc.properties文件:

driver=com.mysql.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.beans.factory.config.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)相關配置文件(context.xml),這種配置的優點是spring配置中只包含jndi的名稱,開發者看不到到具體數據庫的賬號和密碼,為程序員刪庫跑路增加了難度。

1、Tomcat中context.xml配置如下:

    <Resource
            name="jdbc/erp"
            factory="com.alibaba.druid.pool.DruidDataSourceFactory"
            auth="Container"
            type="javax.sql.DataSource"
            driverClassName="com.mysql.jdbc.Driver"
            url="jdbc:mysql://192.168.1.7:3306/test_table?useUnicode=true&amp;characterEncoding=UTF-8&amp;zeroDateTimeBehavior=convertToNull&amp;allowMultiQueries=true&amp;"
            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配置生產數據鏈接信息,生產數據對開發者不可見。

springmvc+druid+dataSource配置的兩種方式