Java 简单的Spring/Hibernate应用程序在45到600秒内无法启动

Java 简单的Spring/Hibernate应用程序在45到600秒内无法启动,java,eclipse,spring,hibernate,tomcat,Java,Eclipse,Spring,Hibernate,Tomcat,我根据Websystique的“Spring4MVC+Hibernate4+MySQL+Maven集成示例使用注释”教程制作了一个简单的webapp 它为部署做了两件事: Eclipse的内置Tomcat部署 手动将war文件放入tomcat location/webapps,使用tomcat location/startup.sh并转到localhost:8080 对于第二,我只是从一个从未加载的空白网页开始 对于1号问题,由于这是一个已知的问题,我尝试了以下可能的解决方案,无解决了我的问题:

我根据Websystique的“Spring4MVC+Hibernate4+MySQL+Maven集成示例使用注释”教程制作了一个简单的webapp

它为部署做了两件事:

  • Eclipse的内置Tomcat部署
  • 手动将war文件放入
    tomcat location/webapps
    ,使用
    tomcat location/startup.sh
    并转到
    localhost:8080
  • 对于第二,我只是从一个从未加载的空白网页开始

    对于1号问题,由于这是一个已知的问题,我尝试了以下可能的解决方案,解决了我的问题:

  • 删除了所有断点
  • 增加了Tomcat超时(我使用了45100300和600)
  • 删除了当前的Tomcat服务器并创建了一个新服务器,删除了旧服务器的设置
  • 重新启动Eclipse和我的系统
  • 这个问题现在超出了我目前的知识范围。原木总是卡在里面

    INFO: HHH000021: Bytecode provider name : javassist
    
    在进展受阻的情况下:

    Preparing launch delegate...:
    
    请帮忙,这可能是什么原因造成的


    以下是可能有帮助的日志:

    mvn清洁安装
    : Eclipse作为服务器运行:
    pom.xml
    但在教程中,这是通过

    @PropertySource(value = { "classpath:application.properties" })
    
    其中,
    application.properties
    保存在
    /Java Resources/src/main/Resources


    我还尝试过让MySQL在Tomcat运行期间运行和不运行,但这也没有帮助。

    您是否可以更改日志属性,并将hibernate和spring记录器置于调试状态,以查看延迟时到底在处理什么。出于某种原因,我怀疑它试图连接未配置良好的数据库。
    Aug 14, 2016 8:00:19 PM org.apache.tomcat.util.digester.SetPropertiesRule begin
    WARNING: [SetPropertiesRule]{Server/Service/Engine/Host/Context} Setting property 'source' to 'org.eclipse.jst.j2ee.server:Spring4MVCHibernateDemo' did not find a matching property.
    Aug 14, 2016 8:00:19 PM org.apache.catalina.startup.VersionLoggerListener log
    INFO: Server version:        Apache Tomcat/8.0.8.5.4
    Aug 14, 2016 8:00:19 PM org.apache.catalina.startup.VersionLoggerListener log
    INFO: Server built:          Jul 6 2016 08:43:30 UTC
    Aug 14, 2016 8:00:19 PM org.apache.catalina.startup.VersionLoggerListener log
    INFO: Server number:         8.5.4.0
    Aug 14, 2016 8:00:19 PM org.apache.catalina.startup.VersionLoggerListener log
    INFO: OS Name:               Mac OS X
    Aug 14, 2016 8:00:19 PM org.apache.catalina.startup.VersionLoggerListener log
    INFO: OS Version:            10.11.6
    Aug 14, 2016 8:00:19 PM org.apache.catalina.startup.VersionLoggerListener log
    INFO: Architecture:          x86_64
    Aug 14, 2016 8:00:19 PM org.apache.catalina.startup.VersionLoggerListener log
    INFO: Java Home:             /Library/Java/JavaVirtualMachines/jdk1.8.0_101.jdk/Contents/Home/jre
    Aug 14, 2016 8:00:19 PM org.apache.catalina.startup.VersionLoggerListener log
    INFO: JVM Version:           1.8.0_101-b13
    Aug 14, 2016 8:00:19 PM org.apache.catalina.startup.VersionLoggerListener log
    INFO: JVM Vendor:            Oracle Corporation
    Aug 14, 2016 8:00:19 PM org.apache.catalina.startup.VersionLoggerListener log
    INFO: CATALINA_BASE:         /Users/username/Projects/.metadata/.plugins/org.eclipse.wst.server.core/tmp0
    Aug 14, 2016 8:00:19 PM org.apache.catalina.startup.VersionLoggerListener log
    INFO: CATALINA_HOME:         /usr/local/apache-tomcat-8.5.4
    Aug 14, 2016 8:00:19 PM org.apache.catalina.startup.VersionLoggerListener log
    INFO: Command line argument: -Dcatalina.base=/Users/username/Projects/.metadata/.plugins/org.eclipse.wst.server.core/tmp0
    Aug 14, 2016 8:00:19 PM org.apache.catalina.startup.VersionLoggerListener log
    INFO: Command line argument: -Dcatalina.home=/usr/local/apache-tomcat-8.5.4
    Aug 14, 2016 8:00:19 PM org.apache.catalina.startup.VersionLoggerListener log
    INFO: Command line argument: -Dwtp.deploy=/Users/username/Projects/.metadata/.plugins/org.eclipse.wst.server.core/tmp0/wtpwebapps
    Aug 14, 2016 8:00:19 PM org.apache.catalina.startup.VersionLoggerListener log
    INFO: Command line argument: -Djava.endorsed.dirs=/usr/local/apache-tomcat-8.5.4/endorsed
    Aug 14, 2016 8:00:19 PM org.apache.catalina.startup.VersionLoggerListener log
    INFO: Command line argument: -Dfile.encoding=UTF-8
    Aug 14, 2016 8:00:19 PM org.apache.catalina.core.AprLifecycleListener lifecycleEvent
    INFO: The APR based Apache Tomcat Native library which allows optimal performance in production environments was not found on the java.library.path: /Users/username/Library/Java/Extensions:/Library/Java/Extensions:/Network/Library/Java/Extensions:/System/Library/Java/Extensions:/usr/lib/java:.
    Aug 14, 2016 8:00:19 PM org.apache.coyote.AbstractProtocol init
    INFO: Initializing ProtocolHandler ["http-nio-8080"]
    Aug 14, 2016 8:00:19 PM org.apache.tomcat.util.net.NioSelectorPool getSharedSelector
    INFO: Using a shared selector for servlet write/read
    Aug 14, 2016 8:00:19 PM org.apache.coyote.AbstractProtocol init
    INFO: Initializing ProtocolHandler ["ajp-nio-8009"]
    Aug 14, 2016 8:00:19 PM org.apache.tomcat.util.net.NioSelectorPool getSharedSelector
    INFO: Using a shared selector for servlet write/read
    Aug 14, 2016 8:00:19 PM org.apache.catalina.startup.Catalina load
    INFO: Initialization processed in 1035 ms
    Aug 14, 2016 8:00:19 PM org.apache.catalina.core.StandardService startInternal
    INFO: Starting service Catalina
    Aug 14, 2016 8:00:19 PM org.apache.catalina.core.StandardEngine startInternal
    INFO: Starting Servlet Engine: Apache Tomcat/8.0.8.5.4
    Aug 14, 2016 8:00:21 PM org.apache.jasper.servlet.TldScanner scanJars
    INFO: At least one JAR was scanned for TLDs yet contained no TLDs. Enable debug logging for this logger for a complete list of JARs that were scanned but no TLDs were found in them. Skipping unneeded JARs during scanning can improve startup time and JSP compilation time.
    Aug 14, 2016 8:00:21 PM org.apache.catalina.core.ApplicationContext log
    INFO: Spring WebApplicationInitializers detected on classpath: [com.springmvc.configuration.AppInitializer@745a5afb]
    Aug 14, 2016 8:00:21 PM org.apache.catalina.core.ApplicationContext log
    INFO: Initializing Spring root WebApplicationContext
    Aug 14, 2016 8:00:21 PM org.springframework.web.context.ContextLoader initWebApplicationContext
    INFO: Root WebApplicationContext: initialization started
    Aug 14, 2016 8:00:21 PM org.springframework.web.context.support.AnnotationConfigWebApplicationContext prepareRefresh
    INFO: Refreshing Root WebApplicationContext: startup date [Sun Aug 14 20:00:21 PHT 2016]; root of context hierarchy
    Aug 14, 2016 8:00:21 PM org.springframework.web.context.support.AnnotationConfigWebApplicationContext loadBeanDefinitions
    INFO: Registering annotated classes: [class com.springmvc.configuration.AppConfiguration]
    Aug 14, 2016 8:00:22 PM org.springframework.jdbc.datasource.DriverManagerDataSource setDriverClassName
    INFO: Loaded JDBC driver: com.mysql.jdbc.Driver
    Aug 14, 2016 8:00:23 PM org.hibernate.annotations.common.reflection.java.JavaReflectionManager <clinit>
    INFO: HCANN000001: Hibernate Commons Annotations {4.0.5.Final}
    Aug 14, 2016 8:00:23 PM org.hibernate.Version logVersion
    INFO: HHH000412: Hibernate Core {4.3.6.Final}
    Aug 14, 2016 8:00:23 PM org.hibernate.cfg.Environment <clinit>
    INFO: HHH000206: hibernate.properties not found
    Aug 14, 2016 8:00:23 PM org.hibernate.cfg.Environment buildBytecodeProvider
    INFO: HHH000021: Bytecode provider name : javassist
    
    package com.springmvc.configuration;
    
    import java.util.Properties;
    
    import javax.sql.DataSource;
    
    import org.hibernate.SessionFactory;
    import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.context.annotation.Bean;
    import org.springframework.context.annotation.ComponentScan;
    import org.springframework.context.annotation.Configuration;
    import org.springframework.context.annotation.PropertySource;
    import org.springframework.core.env.Environment;
    import org.springframework.jdbc.datasource.DriverManagerDataSource;
    import org.springframework.orm.hibernate4.HibernateTransactionManager;
    import org.springframework.orm.hibernate4.LocalSessionFactoryBean;
    import org.springframework.transaction.annotation.EnableTransactionManagement;
    
    @Configuration
    @EnableTransactionManagement
    @ComponentScan({ "com.springmvc.configuration" })
    @PropertySource(value = { "classpath:application.properties" })
    public class HibernateConfiguration {
    
        @Autowired
        private Environment environment;
    
        @Bean
        public LocalSessionFactoryBean sessionFactory() {
            LocalSessionFactoryBean sessionFactory = new LocalSessionFactoryBean();
            sessionFactory.setDataSource(dataSource());
            sessionFactory.setPackagesToScan(new String[] { "com.springmvc.model" });
            sessionFactory.setHibernateProperties(hibernateProperties());
            return sessionFactory;
        }
    
        @Bean
        public DataSource dataSource() {
            DriverManagerDataSource dataSource = new DriverManagerDataSource();
            dataSource.setDriverClassName(environment.getRequiredProperty("jdbc.driverClassName"));
            dataSource.setUrl(environment.getRequiredProperty("jdbc.url"));
            dataSource.setUsername(environment.getRequiredProperty("jdbc.username"));
            dataSource.setPassword(environment.getRequiredProperty("jdbc.password"));
            return dataSource;
        }
    
        private Properties hibernateProperties() {
            Properties properties = new Properties();
            properties.put("hibernate.dialect", environment.getRequiredProperty("hibernate.dialect"));
            properties.put("hibernate.show_sql", environment.getRequiredProperty("hibernate.show_sql"));
            properties.put("hibernate.format_sql", environment.getRequiredProperty("hibernate.format_sql"));
            return properties;
        }
    
        @Bean
        @Autowired
        public HibernateTransactionManager transactionManager(SessionFactory s) {
            HibernateTransactionManager txManager = new HibernateTransactionManager();
            txManager.setSessionFactory(s);
            return txManager;
        }
    }
    
    <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
        xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
        <modelVersion>4.0.0</modelVersion>
        <groupId>com.websystique.springmvc</groupId>
        <artifactId>Spring4MVCHibernateDemo</artifactId>
        <packaging>war</packaging>
        <version>0.0.1-SNAPSHOT</version>
        <name>Spring4MVCHibernateDemo Maven Webapp</name>
        <url>http://maven.apache.org</url>
    
        <properties>
            <java.version>1.8</java.version>
            <springframework.version>4.0.6.RELEASE</springframework.version>
            <hibernate.version>4.3.6.Final</hibernate.version>
            <mysql.connector.version>5.1.31</mysql.connector.version>
            <joda-time.version>2.3</joda-time.version>
            <testng.version>6.9.4</testng.version>
            <mockito.version>1.10.19</mockito.version>
            <h2.version>1.4.187</h2.version>
            <dbunit.version>2.2</dbunit.version>
        </properties>
    
        <dependencies>
            <dependency>
                <groupId>junit</groupId>
                <artifactId>junit</artifactId>
                <version>3.8.1</version>
                <scope>test</scope>
            </dependency>
    
            <!-- Spring -->
            <dependency>
                <groupId>org.springframework</groupId>
                <artifactId>spring-core</artifactId>
                <version>${springframework.version}</version>
            </dependency>
            <dependency>
                <groupId>org.springframework</groupId>
                <artifactId>spring-web</artifactId>
                <version>${springframework.version}</version>
            </dependency>
            <dependency>
                <groupId>org.springframework</groupId>
                <artifactId>spring-webmvc</artifactId>
                <version>${springframework.version}</version>
            </dependency>
            <dependency>
                <groupId>org.springframework</groupId>
                <artifactId>spring-tx</artifactId>
                <version>${springframework.version}</version>
            </dependency>
            <dependency>
                <groupId>org.springframework</groupId>
                <artifactId>spring-orm</artifactId>
                <version>${springframework.version}</version>
            </dependency>
            <dependency>
                <groupId>org.springframework</groupId>
                <artifactId>spring-jdbc</artifactId>
                <version>${springframework.version}</version>
            </dependency>
    
            <!-- Hibernate -->
            <dependency>
                <groupId>org.hibernate</groupId>
                <artifactId>hibernate-core</artifactId>
                <version>${hibernate.version}</version>
            </dependency>
    
            <!-- jsr303 validation -->
            <dependency>
                <groupId>javax.validation</groupId>
                <artifactId>validation-api</artifactId>
                <version>1.1.0.Final</version>
            </dependency>
            <dependency>
                <groupId>org.hibernate</groupId>
                <artifactId>hibernate-validator</artifactId>
                <version>5.1.3.Final</version>
            </dependency>
    
            <!-- MySQL -->
            <dependency>
                <groupId>mysql</groupId>
                <artifactId>mysql-connector-java</artifactId>
                <version>${mysql.connector.version}</version>
            </dependency>
    
            <!-- Joda-Time -->
            <dependency>
                <groupId>joda-time</groupId>
                <artifactId>joda-time</artifactId>
                <version>${joda-time.version}</version>
            </dependency>
    
            <!-- To map JodaTime with database type -->
            <dependency>
                <groupId>org.jadira.usertype</groupId>
                <artifactId>usertype.core</artifactId>
                <version>3.0.0.CR1</version>
            </dependency>
    
            <!-- Servlet+JSP+JSTL -->
            <dependency>
                <groupId>javax.servlet</groupId>
                <artifactId>javax.servlet-api</artifactId>
                <version>3.1.0</version>
            </dependency>
            <dependency>
                <groupId>javax.servlet.jsp</groupId>
                <artifactId>javax.servlet.jsp-api</artifactId>
                <version>2.3.1</version>
            </dependency>
            <dependency>
                <groupId>javax.servlet</groupId>
                <artifactId>jstl</artifactId>
                <version>1.2</version>
            </dependency>
    
    
            <!-- Testing dependencies -->
            <dependency>
                <groupId>org.springframework</groupId>
                <artifactId>spring-test</artifactId>
                <version>${springframework.version}</version>
                <scope>test</scope>
            </dependency>
            <dependency>
                <groupId>org.testng</groupId>
                <artifactId>testng</artifactId>
                <version>${testng.version}</version>
                <scope>test</scope>
            </dependency>
            <dependency>
                <groupId>org.mockito</groupId>
                <artifactId>mockito-all</artifactId>
                <version>${mockito.version}</version>
                <scope>test</scope>
            </dependency>
            <dependency>
                <groupId>com.h2database</groupId>
                <artifactId>h2</artifactId>
                <version>${h2.version}</version>
                <scope>test</scope>
            </dependency>
            <dependency>
                <groupId>dbunit</groupId>
                <artifactId>dbunit</artifactId>
                <version>${dbunit.version}</version>
                <scope>test</scope>
            </dependency>
        </dependencies>
    
        <build>
            <pluginManagement>
                <plugins>
                    <plugin>
                        <groupId>org.apache.maven.plugins</groupId>
                        <artifactId>maven-compiler-plugin</artifactId>
                        <version>3.2</version>
                        <configuration>
                            <source>${java.version}</source>
                            <target>${java.version}</target>
                        </configuration>
                    </plugin>
                    <plugin>
                        <groupId>org.apache.maven.plugins</groupId>
                        <artifactId>maven-war-plugin</artifactId>
                        <version>2.4</version>
                        <configuration>
                            <warSourceDirectory>src/main/webapp</warSourceDirectory>
                            <warName>Spring4MVCHibernateDemo</warName>
                            <failOnMissingWebXml>false</failOnMissingWebXml>
                        </configuration>
                    </plugin>
                </plugins>
            </pluginManagement>
    
            <finalName>Spring4MVCHibernateDemo</finalName>
        </build>
    </project>
    
    INFO: HHH000206: hibernate.properties not found
    
    @PropertySource(value = { "classpath:application.properties" })