热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

springboot每隔一段时间后第一次请求耗时特别长(内含详情)

2017-08-25更新发现,在访问任何一个接口后,接着的接口在短时间内访问速度都很正常。且该情况,无论是否通过nginx代理都是这样。始终是隔一段时


2017-08-25 更新
发现,在访问任何一个接口后,接着的接口在短时间内访问速度都很正常。
且该情况,无论是否通过nginx 代理都是这样。
始终是隔一段时间后的第一个接口访问速度很慢。


背景
1、 应用基于 Spring Boot
2、 调试部分已独立出来为单一的 Get 请求接口。
3、 该接口仅仅返回一个普通json,包含服务器时间、应用名称、请求状态等信息,无任何I/O、数据库等复杂操作。
4、 项目启动方式为 打包后通过 java -jar xxx.war 启动,上层由 nginx 托管。
5、 Spring Boot 启动端口为8000, nginx 端口为9999

问题
无论用浏览器、Postman、curl、Python(requests) 去访问接口,均得到第一次响应非常耗时,短时间内第二次访问会快很多。

分析
1、暂时通过日志判断出控制台输出请求头部分的前后耗时非常长,但是不明白下一步该去怎么分析找问题。
2、单独接口部分的请求响应很快。

请各位帮忙分析下,以下为代码。

接口代码

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
    @RequestMapping(value = "/status")

    @ResponseBody

    public

    Map status(HttpServletRequest request){

        Map m = new HashMap<>;



        m.put("name", "*****");

        m.put("remote_addr", request.getHeader("X-Real-Addr"));



        SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");

        Calendar calendar = Calendar.getInstance();

        m.put("time", sdf.format(calendar.getTime()));





        return m;

    }

日志设置代码

1
2
3
4
5
#logging(TRACE DEBUG INFO WARN)

logging.level.org.apache=debug

logging.level.org.springframework=INFO

logging.level.org.springframework.jdbc.core.StatementCreatorUtils=TRACE

logging.level.org.springframework.jdbc.core=DEBUG

日志代码

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
2017-08-22 16:28:54,430 [http-nio-8000-Acceptor-0] DEBUG o.a.tomcat.util.threads.LimitLatch - Counting up[http-nio-8000-Acceptor-0] latch=1

2017-08-22 16:28:54,430 [http-nio-8000-exec-2] DEBUG o.a.coyote.http11.Http11NioProtocol - Processing socket [org.apache.tomcat.util.net.NioChannel@16655a47:java.nio.channels.SocketChannel[connected local=/192.168.0.30:8000 remote=/192.168.0.30:55507]] with status [OPEN_READ]

2017-08-22 16:28:54,431 [http-nio-8000-exec-2] DEBUG o.a.coyote.http11.Http11InputBuffer - Received [GET /rest/db/status HTTP/1.0

X-Real-Addr: 192.168.1.106

X-Real-Port: 54620

HostAddr: http://192.168.1.30

HostPort: 9999

project: /rest

ServerAddr: http://192.168.1.30:9999

Host: 192.168.0.30:8000

Connection: close

Pragma: no-cache

Cache-Control: no-cache

Upgrade-Insecure-Requests: 1

User-Agent: Mozilla/5.0 (Windows NT 6.1; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/60.0.3112.101 Safari/537.36

Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8

Accept-Encoding: gzip, deflate

Accept-Language: zh-CN,zh;q=0.8



]

2017-08-22 16:28:55,843 [http-nio-8000-exec-2] DEBUG o.a.c.a.AuthenticatorBase - Security checking request GET /rest/db/status

2017-08-22 16:28:55,843 [http-nio-8000-exec-2] DEBUG org.apache.catalina.realm.RealmBase -   No applicable constraints defined

2017-08-22 16:28:55,843 [http-nio-8000-exec-2] DEBUG o.a.c.a.AuthenticatorBase -  Not subject to any constraint

2017-08-22 16:28:55,843 [http-nio-8000-exec-2] DEBUG o.apache.tomcat.util.http.Parameters - Set encoding to UTF-8

2017-08-22 16:28:55,844 [http-nio-8000-exec-2] INFO  org.kys.log.spring.LogInterceptor - start [/rest/db/status]

2017-08-22 16:28:55,847 [http-nio-8000-exec-2] INFO  org.kys.log.spring.LogInterceptor - complete [/rest/db/status] :: Time Taken=3

2017-08-22 16:28:55,847 [http-nio-8000-exec-2] DEBUG o.a.coyote.http11.Http11Processor - Socket: [org.apache.tomcat.util.net.NioEndpoint$NioSocketWrapper@75160339:org.apache.tomcat.util.net.NioChannel@16655a47:java.nio.channels.SocketChannel[connected local=/192.168.0.30:8000 remote=/192.168.0.30:55507]], Status in: [OPEN_READ], State out: [CLOSED]

2017-08-22 16:28:55,848 [http-nio-8000-exec-2] DEBUG o.a.tomcat.util.threads.LimitLatch - Counting down[http-nio-8000-exec-2] latch=1

2017-08-22 16:29:03,493 [http-nio-8000-Acceptor-0] DEBUG o.a.tomcat.util.threads.LimitLatch - Counting up[http-nio-8000-Acceptor-0] latch=1

2017-08-22 16:29:03,503 [http-nio-8000-exec-3] DEBUG o.a.coyote.http11.Http11NioProtocol - Processing socket [org.apache.tomcat.util.net.NioChannel@16655a47:java.nio.channels.SocketChannel[connected local=/192.168.0.30:8000 remote=/192.168.0.30:55520]] with status [OPEN_READ]

2017-08-22 16:29:03,504 [http-nio-8000-exec-3] DEBUG o.a.coyote.http11.Http11InputBuffer - Received [GET /rest/db/status HTTP/1.0

X-Real-Addr: 192.168.1.106

X-Real-Port: 54620

HostAddr: http://192.168.1.30

HostPort: 9999

project: /rest

ServerAddr: http://192.168.1.30:9999

Host: 192.168.0.30:8000

Connection: close

Pragma: no-cache

Cache-Control: no-cache

Upgrade-Insecure-Requests: 1

User-Agent: Mozilla/5.0 (Windows NT 6.1; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/60.0.3112.101 Safari/537.36

Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8

Accept-Encoding: gzip, deflate

Accept-Language: zh-CN,zh;q=0.8



]

2017-08-22 16:29:03,507 [http-nio-8000-exec-3] DEBUG o.a.c.a.AuthenticatorBase - Security checking request GET /rest/db/status

2017-08-22 16:29:03,508 [http-nio-8000-exec-3] DEBUG org.apache.catalina.realm.RealmBase -   No applicable constraints defined

2017-08-22 16:29:03,508 [http-nio-8000-exec-3] DEBUG o.a.c.a.AuthenticatorBase -  Not subject to any constraint

2017-08-22 16:29:03,508 [http-nio-8000-exec-3] DEBUG o.apache.tomcat.util.http.Parameters - Set encoding to UTF-8



推荐阅读
  • 深入解析 Spring Security 用户认证机制
    本文将详细介绍 Spring Security 中用户登录认证的核心流程,重点分析 AbstractAuthenticationProcessingFilter 和 AuthenticationManager 的工作原理。通过理解这些组件的实现,读者可以更好地掌握 Spring Security 的认证机制。 ... [详细]
  • 深入理解Cookie与Session会话管理
    本文详细介绍了如何通过HTTP响应和请求处理浏览器的Cookie信息,以及如何创建、设置和管理Cookie。同时探讨了会话跟踪技术中的Session机制,解释其原理及应用场景。 ... [详细]
  • 本文详细分析了Hive在启动过程中遇到的权限拒绝错误,并提供了多种解决方案,包括调整文件权限、用户组设置以及环境变量配置等。 ... [详细]
  • 在现代网络环境中,两台计算机之间的文件传输需求日益增长。传统的FTP和SSH方式虽然有效,但其配置复杂、步骤繁琐,难以满足快速且安全的传输需求。本文将介绍一种基于Go语言开发的新一代文件传输工具——Croc,它不仅简化了操作流程,还提供了强大的加密和跨平台支持。 ... [详细]
  • 本文探讨了 Spring Boot 应用程序在不同配置下支持的最大并发连接数,重点分析了内置服务器(如 Tomcat、Jetty 和 Undertow)的默认设置及其对性能的影响。 ... [详细]
  • 深入解析 Apache Shiro 安全框架架构
    本文详细介绍了 Apache Shiro,一个强大且灵活的开源安全框架。Shiro 专注于简化身份验证、授权、会话管理和加密等复杂的安全操作,使开发者能够更轻松地保护应用程序。其核心目标是提供易于使用和理解的API,同时确保高度的安全性和灵活性。 ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • 网络攻防实战:从HTTP到HTTPS的演变
    本文通过一系列日记记录了从发现漏洞到逐步加强安全措施的过程,探讨了如何应对网络攻击并最终实现全面的安全防护。 ... [详细]
  • MQTT技术周报:硬件连接与协议解析
    本周开发笔记重点介绍了在新项目中使用MQTT协议进行硬件连接的技术细节,涵盖其特性、原理及实现步骤。 ... [详细]
  • UNP 第9章:主机名与地址转换
    本章探讨了用于在主机名和数值地址之间进行转换的函数,如gethostbyname和gethostbyaddr。此外,还介绍了getservbyname和getservbyport函数,用于在服务器名和端口号之间进行转换。 ... [详细]
  • 本文详细探讨了HTTP 500内部服务器错误的成因、解决方案及其在Web开发中的影响。通过对具体案例的分析,帮助读者理解并解决此类问题。 ... [详细]
  • 本文介绍了如何使用PHP代码实现微信平台的媒体素材上传功能,详细解释了API接口的使用方法和注意事项,确保文件路径正确以避免常见的错误。 ... [详细]
  • 图数据库中的知识表示与推理机制
    本文探讨了图数据库及其技术生态系统在知识表示和推理问题上的应用。通过理解图数据结构,尤其是属性图的特性,可以为复杂的数据关系提供高效且优雅的解决方案。我们将详细介绍属性图的基本概念、对象建模、概念建模以及自动推理的过程,并结合实际代码示例进行说明。 ... [详细]
  • 本文探讨了领域驱动设计(DDD)的核心概念、应用场景及其实现方式,详细介绍了其在企业级软件开发中的优势和挑战。通过对比事务脚本与领域模型,展示了DDD如何提升系统的可维护性和扩展性。 ... [详细]
  • 实体映射最强工具类:MapStruct真香 ... [详细]
author-avatar
mobiledu2502857923
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有