Performance spring mvc+;野蝇&x2B;postgresql性能调优
我花了很多时间试图找出是什么原因导致我的应用程序运行非常缓慢,也许有人会帮助我检查问题所在 版本:Performance spring mvc+;野蝇&x2B;postgresql性能调优,performance,hibernate,spring-mvc,optimization,wildfly,Performance,Hibernate,Spring Mvc,Optimization,Wildfly,我花了很多时间试图找出是什么原因导致我的应用程序运行非常缓慢,也许有人会帮助我检查问题所在 版本: springmvc:4.2.5.发布 hibernate:4.3.11.最终版 spring数据jpa:1.8.2.发布 wildfly:10 PostgreSQL Server:9.4 OS:Debian GNU/Linux 7.9(喘息) 服务器配置:VPS、1进程、4GB RAM 关于我的应用程序: 带有静态JSP登录页、信息页和重定向到私有区域的登录的简单web应用程序。公共页面是静态的,
springmvc:4.2.5.发布
hibernate:4.3.11.最终版
spring数据jpa:1.8.2.发布
wildfly:10
PostgreSQL Server:9.4
OS:Debian GNU/Linux 7.9(喘息)
服务器配置:VPS、1进程、4GB RAM
关于我的应用程序:
带有静态JSP
登录页、信息页和重定向到私有区域的登录的简单web应用程序。公共页面是静态的,首先在登录期间对数据库进行查询,然后尝试获取登录用户的内容
问题是什么:
当我浏览如下配置的页面时:
<http auto-config="true">
<intercept-url pattern="/" access="permitAll"/>
<intercept-url pattern="favicon.ico" access="permitAll"/>
<intercept-url pattern="/login/**" access="permitAll"/>
<intercept-url pattern="/info" access="permitAll"/>
...
</http>
<intercept-url pattern="/main/**" access="hasRole('ROLE_USER')"/>
<intercept-url pattern="/statistic/**" access="hasRole('ROLE_USER')"/>
<intercept-url pattern="/admin/**" access="hasRole('ROLE_ADMIN')" />
...
没有问题,所有的东西都在加载,没有停顿。它运行平稳。
当我在/login上发布时(将我重定向到/main),然后当我在如下配置的每个站点上导航时:
<http auto-config="true">
<intercept-url pattern="/" access="permitAll"/>
<intercept-url pattern="favicon.ico" access="permitAll"/>
<intercept-url pattern="/login/**" access="permitAll"/>
<intercept-url pattern="/info" access="permitAll"/>
...
</http>
<intercept-url pattern="/main/**" access="hasRole('ROLE_USER')"/>
<intercept-url pattern="/statistic/**" access="hasRole('ROLE_USER')"/>
<intercept-url pattern="/admin/**" access="hasRole('ROLE_ADMIN')" />
有些极端的延迟有时甚至长达1分钟
休眠配置
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
<property name="driverClassName" value="${jdbc.driverClassName}"/>
<property name="url" value="${jdbc.url}"/>
<property name="username" value="${jdbc.username}"/>
<property name="password" value="${jdbc.password}"/>
</bean>
<!-- Configure the entity manager factory bean -->
<bean id="entityManagerFactory" class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean">
<property name="dataSource" ref="dataSource"/>
<property name="packagesToScan" value="pl.portal.model"/>
<property name="jpaVendorAdapter">
<bean class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter"/>
</property>
<property name="jpaProperties">
<props>
<!-- <prop key="hibernate.dialect">pl.portal.sql.ProjectPsqlDialect</prop> -->
<prop key="hibernate.show_sql">false</prop>
<prop key="hibernate.enable_lazy_load_no_trans">true</prop>
<prop key="hibernate.jdbc.use_streams_for_binary">false</prop>
<prop key="hibernate.connection.useUnicode">true</prop>
<prop key="hibernate.connection.characterEncoding">UTF-8</prop>
<prop key="hibernate.connection.characterSet">UTF-8</prop>
</props>
</property>
</bean>
假的
真的
假的
真的
UTF-8
UTF-8
有谁能给我一个提示,如何确定是什么导致了延迟?在我的浏览器中检查webinspect->/admin,大小7,89KB,大小:54秒(其中每个js或css不超过100毫秒)
编辑2:
删除了无效的线程转储片段,粘贴了在调用应用程序上的操作/admin
后启动的完整线程转储。线程为61s
visualvm控制台上的线程:
关于如何分析性能,您可以关注以下几个方面:
也许是你的情况。epoll有一个bug。但如今也出现了类似的情况。造成此类延误的原因可能有很多,下面列出了一些最常见的原因