spring3.2+jdk1.7+hibernate+tomcat+idea
启动tomcat到一半自动关闭tomcat服务,tomcat日志中没有找到报错信息,已经查过端口号没有重复。
以下为报错信息:
17-Jan-2023 11:41:14.116 信息 [localhost-startStop-1] org.apache.catalina.startup.HostConfig.deployDirectory Web应用程序目录[D:\developSoft\apache-tomcat-8.5.58\webapps\manager]的部署已在[40]毫秒内完成
17-Jan-2023 11:41:58.582 信息 [Thread-5] org.apache.coyote.AbstractProtocol.pause 暂停ProtocolHandler["http-nio-8088"]
permission denied!-1 code:9766bdf303e5d5c39386be85f1f7190b2a72c83235076608e8d6776c5521f5d89aa23d87cb50aafa6996986acbff7340
17-Jan-2023 11:41:59.222 信息 [Thread-5] org.apache.catalina.core.StandardService.stopInternal 正在停止服务[Catalina]
17-Jan-2023 11:41:59.260 信息 [Thread-5] org.apache.coyote.AbstractProtocol.stop 正在停止ProtocolHandler ["http-nio-8088"]
17-Jan-2023 11:41:59.262 信息 [Thread-5] org.apache.coyote.AbstractProtocol.destroy 正在摧毁协议处理器 ["http-nio-8088"]
单独启动tomcat正常访问tomcat主页,idea中添加项目后就不行了。唯一的报错信息在项目的error日志文件中,内容如下:
或者提供解决问题的思路也可以,如果可以解决,可以提高额度
applicationContext.xml
<context:property-placeholder location="classpath*:/shopxx.properties" ignore-resource-not-found="true" ignore-unresolvable="true" />
<context:component-scan base-package="net.shopxx">
<context:exclude-filter type="annotation" expression="org.springframework.stereotype.Controller" />
</context:component-scan>
<!--<import resource="classpath:applicationContext-webservice.xml"/>-->
<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource" destroy-method="close">
<property name="driverClass" value="${jdbc.driver}" />
<property name="jdbcUrl" value="${jdbc.url}" />
<property name="user" value="${jdbc.username}" />
<property name="password" value="${jdbc.password}" />
<property name="initialPoolSize" value="${connection_pools.initial_pool_size}" />
<property name="minPoolSize" value="${connection_pools.min_pool_size}" />
<property name="maxPoolSize" value="${connection_pools.max_pool_size}" />
<property name="maxIdleTime" value="${connection_pools.max_idle_time}" />
<property name="acquireIncrement" value="${connection_pools.acquire_increment}" />
<property name="checkoutTimeout" value="${connection_pools.checkout_timeout}" />
</bean>
<bean id="entityManagerFactory" class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean">
<property name="dataSource" ref="dataSource" />
<!--<property name="persistenceXmlLocation" value="classpath*:/persistence.xml" />-->
<property name="persistenceUnitName" value="entityManagerFactoryExtend" />
<property name="packagesToScan" value="net.shopxx"/>
<property name="jpaVendorAdapter">
<bean class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter">
<property name="showSql" value="false" />
<property name="generateDdl" value="false" />
</bean>
</property>
<property name="jpaProperties">
<props>
<prop key="hibernate.dialect">${hibernate.dialect}</prop>
<prop key="hibernate.ejb.naming_strategy">org.hibernate.cfg.ImprovedNamingStrategy</prop>
<prop key="hibernate.cache.use_second_level_cache">${hibernate.cache.use_second_level_cache}</prop>
<prop key="hibernate.cache.region.factory_class">${hibernate.cache.region.factory_class}</prop>
<prop key="hibernate.cache.use_query_cache">${hibernate.cache.use_query_cache}</prop>
<prop key="hibernate.jdbc.fetch_size">${hibernate.jdbc.fetch_size}</prop>
<prop key="hibernate.jdbc.batch_size">${hibernate.jdbc.batch_size}</prop>
<prop key="hibernate.connection.isolation">2</prop>
<prop key="javax.persistence.validation.mode">none</prop>
<prop key="hibernate.search.default.directory_provider">org.hibernate.search.store.FSDirectoryProvider</prop>
<!--<prop key="hibernate.search.default.indexBase">${java.io.tmpdir}/${system.project_name}/index</prop>-->
</props>
</property>
</bean>
<bean id="transactionManager" class="org.springframework.orm.jpa.JpaTransactionManager">
<property name="entityManagerFactory" ref="entityManagerFactory" />
</bean>
<tx:annotation-driven transaction-manager="transactionManager" />
<cache:annotation-driven cache-manager="cacheManager" />
<!--bean class="org.springframework.beans.factory.config.MethodInvokingFactoryBean">
<property name="targetClass" value="java.lang.System" />
<property name="targetMethod" value="setProperty" />
<property name="arguments">
<list>
<value>system.project_name</value>
<value>${system.project_name}</value>
</list>
</property>
</bean-->
<bean id="ehCacheManager" class="org.springframework.cache.ehcache.EhCacheManagerFactoryBean">
<property name="configLocation" value="classpath:/ehcache.xml" />
<property name="shared" value="true" />
</bean>
<bean id="cacheManager" class="org.springframework.cache.ehcache.EhCacheCacheManager">
<property name="cacheManager" ref="ehCacheManager" />
</bean>
<bean id="freeMarkerConfigurer" class="org.springframework.web.servlet.view.freemarker.FreeMarkerConfigurer">
<property name="templateLoaderPaths" value="${template.loader_path}" />
<property name="freemarkerSettings">
<props>
<prop key="defaultEncoding">${template.encoding}</prop>
<prop key="url_escaping_charset">${url_escaping_charset}</prop>
<prop key="locale">${locale}</prop>
<prop key="template_update_delay">${template.update_delay}</prop>
<prop key="tag_syntax">auto_detect</prop>
<prop key="whitespace_stripping">true</prop>
<prop key="classic_compatible">true</prop>
<prop key="number_format">${template.number_format}</prop>
<prop key="boolean_format">${template.boolean_format}</prop>
<prop key="datetime_format">${template.datetime_format}</prop>
<prop key="date_format">${template.date_format}</prop>
<prop key="time_format">${template.time_format}</prop>
<prop key="object_wrapper">freemarker.ext.beans.BeansWrapper</prop>
</props>
</property>
<property name="freemarkerVariables">
<map>
<entry key="systemName" value="${system.name}" />
<entry key="systemVersion" value="${system.version}" />
<!--<entry key="systemDescription" value="${system.description}" />
<entry key="systemShowPowered" value="#{${system.show_powered}}" />-->
<entry key="base" value="#{servletContext.contextPath}" />
<entry key="locale" value="${locale}" />
<entry key="setting" value="#{T(net.shopxx.base.core.util.SettingUtils).get()}" />
<entry key="message" value-ref="messageMethod" />
<entry key="abbreviate" value-ref="abbreviateMethod" />
<entry key="currency" value-ref="currencyMethod" />
<entry key="pagination" value-ref="paginationDirective" />
<!--entry key="execute_time" value-ref="executeTimeDirective" />
<entry key="flash_message" value-ref="flashMessageDirective" />
<entry key="current_member" value-ref="currentMemberDirective" />
<entry key="seo" value-ref="seoDirective" />
<entry key="ad_position" value-ref="adPositionDirective" />
<entry key="ad" value-ref="adDirective" />
<entry key="store_list" value-ref="storeListDirective" />
<entry key="member_attribute_list" value-ref="memberAttributeListDirective" />
<entry key="navigation_list" value-ref="navigationListDirective" />
<entry key="tag_list" value-ref="tagListDirective" />
<entry key="friend_link_list" value-ref="friendLinkListDirective" />
<entry key="brand_list" value-ref="brandListDirective" />
<entry key="article_list" value-ref="articleListDirective" />
<entry key="article_category_root_list" value-ref="articleCategoryRootListDirective" />
<entry key="article_category_parent_list" value-ref="articleCategoryParentListDirective" />
<entry key="article_category_children_list" value-ref="articleCategoryChildrenListDirective" />
<entry key="product_list" value-ref="productListDirective" />
<entry key="product_category_root_list" value-ref="productCategoryRootListDirective" />
<entry key="product_category_parent_list" value-ref="productCategoryParentListDirective" />
<entry key="product_category_children_list" value-ref="productCategoryChildrenListDirective" />
<entry key="review_list" value-ref="reviewListDirective" />
<entry key="consultation_list" value-ref="consultationListDirective" />
<entry key="promotion_list" value-ref="promotionListDirective" />
<entry key="he_adPosition" value-ref="haierAdPositionDirective" />
<entry key="he_position" value-ref="haierPositionDirective" />
<entry key="order_product" value-ref="haierProductOrderSaleDirective" />
<entry key="product_push_manage" value-ref="productPushManageDirective" />
<entry key="sales_rank" value-ref="salesRankDirective" />
<entry key="qrcodePutTypeDetail" value-ref="qrcodePutTypeDirective" /-->
</map>
</property>
</bean>
<bean id="localeChangeInterceptor" class="org.springframework.web.servlet.i18n.LocaleChangeInterceptor" />
<bean id="defaultUrlMapping" class="org.springframework.web.servlet.handler.BeanNameUrlHandlerMapping">
<property name="interceptors" ref="localeChangeInterceptor" />
<property name="order">
<value>1</value>
</property>
</bean>
<bean id="messageSource" class="org.springframework.context.support.ReloadableResourceBundleMessageSource">
<property name="cacheSeconds" value="${message.cache_seconds}" />
<property name="useCodeAsDefaultMessage" value="true" />
<!--<property name="basenames">-->
<!--<list>-->
<!--<value>${message.path}</value>-->
<!--</list>-->
<!--</property>-->
</bean>
<bean id="localeResolver" class="org.springframework.web.servlet.i18n.FixedLocaleResolver">
<property name="defaultLocale" value="${locale}" />
</bean>
<!--
<bean id="imageCaptchaService" class="com.octo.captcha.service.image.DefaultManageableImageCaptchaService">
<property name="captchaEngine">
<bean class="net.shopxx.CaptchaEngine" />
</property>
<property name="minGuarantedStorageDelayInSeconds" value="3600" />
</bean>
<bean id="javaMailSender" class="org.springframework.mail.javamail.JavaMailSenderImpl">
<property name="javaMailProperties">
<props>
<prop key="mail.smtp.auth">${mail.smtp.auth}</prop>
<prop key="mail.smtp.timeout">${mail.smtp.timeout}</prop>
<prop key="mail.smtp.starttls.enable">${mail.smtp.starttls.enable}</prop>
<prop key="mail.smtp.socketFactory.class">javax.net.ssl.SSLSocketFactory</prop>
</props>
</property>
</bean>
<bean id="taskExecutor" class="org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor">
<property name="corePoolSize" value="${task.core_pool_size}" />
<property name="maxPoolSize" value="${task.max_pool_size}" />
<property name="queueCapacity" value="${task.queue_capacity}" />
<property name="keepAliveSeconds" value="${task.keep_alive_seconds}" />
</bean> -->
<task:annotation-driven />
applicationContext-mvc.xml
<context:property-placeholder location="classpath*:/shopxx.properties"
ignore-resource-not-found="true" ignore-unresolvable="true" />
<context:component-scan base-package="net.shopxx"
use-default-filters="false">
<context:include-filter type="annotation"
expression="org.springframework.stereotype.Controller" />
</context:component-scan>
<aop:aspectj-autoproxy proxy-target-class="true" />
<mvc:annotation-driven validator="validator" />
<mvc:interceptors>
<mvc:interceptor>
<mvc:mapping path="/**" />
<bean id="accessInterceptor" class="net.shopxx.common.AccessInterceptor" />
</mvc:interceptor>
<mvc:interceptor>
<mvc:mapping path="/**" />
<bean id="openSessionInViewInterceptor" class="org.springframework.orm.jpa.support.OpenEntityManagerInViewInterceptor">
<property name="entityManagerFactory" ref="entityManagerFactory" />
</bean>
</mvc:interceptor>
</mvc:interceptors>
<bean id="validator"
class="org.springframework.validation.beanvalidation.LocalValidatorFactoryBean">
<property name="validationMessageSource" ref="messageSource" />
</bean>
<bean id="viewResolver"
class="org.springframework.web.servlet.view.freemarker.FreeMarkerViewResolver">
<property name="contentType" value="text/html; charset=UTF-8" />
<property name="suffix" value="${template.suffix}" />
</bean>
<bean id="multipartResolver"
class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
<property name="defaultEncoding" value="UTF-8" />
</bean>
<!-- <bean id="exceptionResolver" class="org.springframework.web.servlet.handler.SimpleMappingExceptionResolver">
<property name="defaultErrorView" value="shop/common/error" /> <property
name="warnLogCategory" value="WARN" /> </bean> -->
<bean id="handlerExceptionResolver" class="net.shopxx.base.core.exception.ExceptionHandler"></bean>
这个错误信息表明Tomcat在启动时无法访问8088端口。这可能是由于其他程序占用了该端口,或者是您的操作系统的权限不允许Tomcat访问该端口。
解决这个问题的方法是:
1.确保8088端口没有被其他程序占用。您可以使用netstat命令查看已经打开的端口。
2.检查您的操作系统是否具有访问8088端口的权限。如果您在Windows上运行Tomcat,请确保Tomcat服务器进程具有访问端口8088的权限。
3.检查您的server.xml文件中是否正确配置了端口号。确保端口号为8088,并且没有被注释掉。
根据您提供的日志信息,可以看到报错信息中出现了"permission denied!",这可能是由于Tomcat运行所需的文件或目录没有足够的访问权限导致的。建议检查Tomcat安装目录和相关文件的访问权限,确保Tomcat进程有足够的权限来运行。您可以使用以下步骤检查Tomcat的文件和目录权限:
打开命令行窗口,并进入Tomcat的安装目录。
使用命令“ls -l”查看Tomcat安装目录中的所有文件和目录的权限。
检查Tomcat安装目录、bin目录、lib目录、logs目录、temp目录、webapps目录、work目录的权限是否正确。
检查Tomcat运行所需的所有文件(如catalina.sh,catalina.bat,tomcat8.exe等)的权限是否正确。
确保Tomcat进程具有读、写和执行权限。
修改所有文件和目录的权限,使其具有所需的权限。
重新启动Tomcat服务,检查是否正常启动。注意:上述步骤假设您使用的是Linux或Unix操作系统,如果您使用的是Windows系统,可以使用Windows资源管理器查看文件和目录的权限。
看您的错误是由于tomcat目录没有权限导致的,如果您是linux系统,则通过chmod命令修改目录权限:
chmod u+x *.sh
然后在重启tomcat 执行startup.sh
或者有可能是端口8080访问权限的问题,换一个端口再尝试下:
修改Tomcat的server.xml配置文件,将端口修改为8081(或者其他1024以上的端口号,不能与本机上的其它Tomcat端口冲突)
你的当前用户没有相关的端口的权限。
很有可能是你的项目里有类似于ApplicationRunner或是一启动就调用的Scheduled,它里面有进行一些权限校验的代码,注释掉它,重新启动
感谢邀请,工作中都知道,任何问题的出现,背景有所不同。例如本机环境,配置,个人操作,网络等各种原因的。题主提问题可以将一些具体背景介绍下,会能更快的找到问题原因。
看了题主回复其他答主的描述中,可以尝试从一下几个方便排查下:
1、若是本地启的,手动尝试关闭tomcat,然后看下进程是否真正关闭,再重启看下,有些关闭后但查看进程依然没真正关闭。
2、使用sh bin/startup.sh启动tomcat服务。
3、检查一下你的项目的问题,例如是否引用外部jar,并且jar已经正确加载上了。 可以看下具体的依赖来排查。
4、将项目编译的历史字节码和配置文件删除,然后清理idea的缓存后重试。
5、重新下载tomcat包,解压后比较现有的包,看下是否文件字节大小对得上。
以上是问题排查方法。可以重点看下数据库配置,是否有项目启动后便调数据库。 看下字段约束,外键问题
4、看下是否配置的内存不足引起的。
谢邀!!!
一、检查一下是不是在xml文件中加了中文字符?
二、尝试在tomcat配置页面,在Argument中末尾添加参数中的VM arguments中追加:
-Xms256M -Xmx512M -XX:PermSize=256m -XX:MaxPermSize=512m
三、有没有可能jvm崩溃了?
最后我看到你发的日志里面这段错误,请检查一下有关SQL语句
建议先检查一下catalina.bat这个文件的用户权限对吗,还有就是看一下这个文件里面的参数有没有问题,如果有配置了jvm启动参数就手动注释掉试一下
看报错,是这个项目用到了hibernate,估计是有多对一或者一对多映射,然后启动的时候发现这些关系没有外键尝试添加外键失败了,你应该检查下你的数据库,是否和生产一致。
很多人都是关注Tomcat问题 和 权限问题
我这里想的是会不会是代码报错,比如系统环境更改后程序无法运行、jar打包 或 配置做过代理等问题
但根据楼主贴的内容大概能猜出测试运行也没有报错,就是发布时有问题,需检查程序发布时运行有无异常,且异常要打包到日志(不是所有报错都会打印出来的)
处理方式:例:SpringBoot:在启动类 使用try捕获异常并存入日志,其它架构也是如此
目前看你的错误日志是集中在数据库层面的外键约束报错了,确保数据库连接的没有问题