为什么不在jelastic hosting中连接数据库mysql,如果在eclipse正常?

时间:2017-01-04 07:08:25

标签: hosting jelastic

消息

  

请求处理失败;嵌套异常是org.springframework.transaction.CannotCreateTransactionException:无法打开Hibernate Session进行事务处理;嵌套异常是org.hibernate.exception.GenericJDBCException:无法打开连接

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"

    xmlns:mvc="http://www.springframework.org/schema/mvc" 

    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xmlns:context="http://www.springframework.org/schema/context" 
    xmlns:tx="http://www.springframework.org/schema/tx"
    xsi:schemaLocation="http://www.springframework.org/schema/mvc 
    http://www.springframework.org/schema/mvc/spring-mvc.xsd
        http://www.springframework.org/schema/beans 
        http://www.springframework.org/schema/beans/spring-beans.xsd

        http://www.springframework.org/schema/context 
        http://www.springframework.org/schema/context/spring-context.xsd
        http://www.springframework.org/schema/tx 
        http://www.springframework.org/schema/tx/spring-tx.xsd">

    <context:component-scan base-package="com.hendri" />

    <!-- Enables the Spring MVC @Controller programming model -->
    <mvc:annotation-driven />

    <!-- Handles HTTP GET requests for /resources/** by efficiently serving 
        up static resources in the ${webappRoot}/resources directory -->

    <!--  <mvc:resources mapping="/resources/**" location="/resources/"/> -->
        <mvc:resources mapping="/images/**" location="/images/"/>
        <mvc:resources mapping="/bukanadmin/**" location="/bukanadmin/"/>
        <mvc:resources mapping="/resources/**" location="/resources/"/>





    <bean id="viewResolver"
        class="org.springframework.web.servlet.view.tiles3.TilesViewResolver">

        <property name="viewClass"
            value="org.springframework.web.servlet.view.tiles3.TilesView" />
    </bean>

    <bean id="tilesConfigurer"
        class="org.springframework.web.servlet.view.tiles3.TilesConfigurer">
        <property name="definitions">
            <list>
                <value>/WEB-INF/layouts/layouts.xml</value>
            </list>
        </property>
    </bean>

    <bean id="messageSource"
        class="org.springframework.context.support.ResourceBundleMessageSource">
        <property name="basename" value="messages" />
    </bean>
    <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
        <property name="prefix" value="/jsp/" />
        <property name="suffix" value=".jsp" />
    </bean>
    <!-- Root Context: defines shared resources visible to all other web components -->

    <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource"
        destroy-method="close">

        <property name="url" value="jdbc:mysql://mysql3309-testaja.kilatiron.com:3306/sms" />       
        <property name="username" value="root" />
        <property name="password" value="somepassword" />
        <property name="driverClassName" value="com.mysql.jdbc.Driver"/>



    </bean>





    <bean id="sessionFactory"
        class="org.springframework.orm.hibernate4.LocalSessionFactoryBean">
        <property name="dataSource" ref="dataSource" />



        <property name="hibernateProperties">
            <props>
                <prop key="hibernate.dialect">org.hibernate.dialect.MySQLDialect</prop>
                <prop key="hibernate.show_sql">true</prop>
                <prop key="hibernate.hbm2ddl.auto">update</prop>
            </props>
        </property>
        <property name="packagesToScan" value="com.hendri.domain" />
    </bean>

    <tx:annotation-driven />

    <bean id="transactionManager"
        class="org.springframework.orm.hibernate4.HibernateTransactionManager">
        <property name="sessionFactory" ref="sessionFactory"></property>
    </bean>



</beans>

1 个答案:

答案 0 :(得分:0)

当webapp的/ WEB-INF / lib中存在JDBC 4.0兼容驱动程序时,Tomcat提供了内存泄漏检测功能,该驱动程序在webapp启动期间使用ServiceLoader API自动注册,但在自动注销时不会自动注销webapp的关闭。 您可以将JDBC driver移动到Tomcat的/ lib文件夹(/ opt / tomcat / lib),并使用连接池数据源来管理驱动程序。

注意 Tomcat的内置DBCP在关闭时不会正确注销驱动程序。

另见bug DBCP-322