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控制台上的线程:

关于如何分析性能,您可以关注以下几个方面:

  • 分贝
  • 网络
  • 应用层
  • 记忆
  • 监视数据库非常简单,可以使用RDBMS监视工具,如查询监视器for DB2或其他依赖于供应商的工具

    分析B网络,有很多不同的工具,但你需要做的是弄清楚你的延迟是多少,网络速度是多少

    我相信我们可以假设,在您的情况下,网络是正常的,或者至少不太可能有问题

    要分析的第三件事是您的应用程序层,这是您需要适当的分析工具的地方。您可以使用jdk附带的免费visualVM,也可以使用付费的工具包。但是你可以得到一个试用版

    您还可以使用分析工具分析内存

    一旦执行CPU采样,您将能够找出应用程序的哪些区域导致延迟。Yourkit还能够从应用层端监控已执行的SQL。这样,您将在一次测量中获得SQL速度+执行它的延迟+传输结果集的时间

    常见的性能调整意见包括:

    冬眠。使用批处理加载集合,不要连接关系,而要选择策略。选择

    确保您不执行任何笛卡尔积之类的操作

    服务器配置:VPS、1进程、4GB RAM

    您有权访问服务器吗?还可以尝试运行top命令并查看CPU使用情况。你只有一个进程,也许有什么大的东西在运行

    开始查找性能问题的典型方法:

    条件1您可以连接探查器 去做吧。 jvisualvm、jconsole、NetBeans分析器、perf等

  • 使用profiler连接到您的流程
  • 运行您认为缓慢的任务并等待
  • 保存分析器结果以进行分析 您应该注意CPU总时间

    条件2您无法连接探查器

    是的,在这里您可以使用jstack获得线程转储。jps获取java进程ID

  • 准备cmd/bash
  • 运行jps并找到您的进程pid,记住
  • 运行您认为缓慢的任务
  • 多次运行jstack并保存输出(jstack pid>output.1、jstack pid>output.2等)
  • 分析所有结果,看看哪种方法最常用
  • 不要进行预优化,在之前测量性能。:)

    更新新信息后的答案

    在线程转储中,您可以看到很多“sun.nio.ch.EPollArrayWrapper.epollWait”,请尝试查看以下链接:


    也许是你的情况。epoll有一个bug。但如今也出现了类似的情况。

    造成此类延误的原因可能有很多,下面列出了一些最常见的原因

  • 线程正在等待锁定
  • 数据库性能问题
  • CPU密集型任务
  • 网络延迟
  • 在您的案例中,可以排除web服务器和客户端之间的网络延迟,因为您提到静态页面和页面资源(如CSS)的服务器响应时间以毫秒为单位

    对于其他方面来说,像VisualVM这样的远程管理系统是查明造成延迟的原因和占用大量CPU时间的进程的最佳工具。您也可以使用商业分析器,如JProfiler,但VisualVm也可以完美地完成这项工作

    要连接到ViusalVM,您需要访问服务器和附加JAVA_选项,或者您选择的任何地方,然后重新启动web应用程序

    等待锁定的线程-可能有一段代码,其中有一个已同步的