tomcat 宕机问题分析及解决「建议收藏」

tomcat 宕机问题分析及解决「建议收藏」服务器环境:centos6.7+tomcat7.0.69+jdk1.7.0_55+mysql5.6.28场景:服务刚开始用户体验变差,请求时间长,之后出现404,500等与服务器交互失败问题。重启后用户体验回升,半小时内问题没有再现。日志中出现的问题有两个:                 1、Cause:org.springframework.jdbc.Can

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

服务器环境:centos6.7 + tomcat7.0.69 + jdk1.7.0_55 + mysql5.6.28

场景:服务刚开始用户体验变差,请求时间长,之后出现404,500等与服务器交互失败问题。重启后用户体验回升,半小时内问题没有再现。

日志中出现的问题有两个

                  1、Cause: org.springframework.jdbc.CannotGetJdbcConnectionException: Could not get JDBC Connection; nested exception is org.apache.tomcat.dbcp.dbcp.SQLNestedException: Cannot get a connection, pool error Timeout waiting for idle object

                   2、Mar 06, 2017 10:59:53 AM org.apache.tomcat.util.net.JIoEndpoint$Acceptor run
                                   SEVERE: Socket accept failed
                               java.net.SocketException: Too many open files

解决方案

                   1、更改centos的单个文件最大句柄数为最大的65535,tomcat宕机的直接原因是 第二个问题 Too many open files

                   2、更改线程池的配置增加如下参数:

  1. maxWait=“3000” 从池中取连接的最大等待时间,单位ms.  
  2. initialSize=“10”  初始化连接  
  3. minIdle=“10”   最小空闲连接 
  4. maxIdle=“150”   最大空闲连接 
  5. maxActive=“200” 最大活动连接  
  6.    
  7. validationQuery = “SELECT 1”  验证使用的SQL语句  
  8. testWhileIdle = “true”      指明连接是否被空闲连接回收器(如果有)进行检验.如果检测失败,则连接将被从池中去除.  
  9. testOnBorrow = “false”   借出连接时不要测试,否则很影响性能  
  10. timeBetweenEvictionRunsMillis = “30000”  每30秒运行一次空闲连接回收器  
  11. minEvictableIdleTimeMillis = “1800000”  池中的连接空闲30分钟后被回收  
  12. numTestsPerEvictionRun=“10” 在每次空闲连接回收器线程(如果有)运行时检查的连接数量  
  13.       
  14. removeAbandoned=“true”  连接泄漏回收参数,当可用连接数少于3个时才执行  
  15. removeAbandonedTimeout=“180”  连接泄漏回收参数,180秒,泄露的连接可以被删除的超时值  

问题原因

                    1、网络延迟增加;

                    2、tomcat的dbcp线程池设置偏小,当请求突发的时候出现线程池报错;

                    3、同时,由于对服务的请求及服务向数据库发起的服务的增加,在突发情况中击穿数据库限制超出最大句柄数

                    4、导致进程挂死。

tomcat 宕机问题分析及解决「建议收藏」

原因分析过程

            一、分析服务的系统日志,获取报错种类及第一次发生的时间节点

            二、分析服务的系统日志,查获所有数据库访问请求的执行时间点,服务的请求时间;

            三、统计每一秒内的数据库请求总数量,各个请求的总数量,各个请求失败总数量

            四、分析数据库日志,获取处理时间长及失败的SQL语句的执行时间及处理时长

            五、对比三和四步骤的结果初略的判断是否存在网络问题

其中频繁使用的小技巧:

             1、notepad++的正则查找:

                          a、搜索的设置如下图:

                                             tomcat 宕机问题分析及解决「建议收藏」

                          b、使用正则查找行中有10.6.6.5或Query_time或order by c.isTop DESC 三个字段的行

                                          ^.*10\.6\.6\.5.*$|^.*Query\_time.*$|^.*order by  c\.isTop DESC\, c\.id asc.*$

               2、excel中的vlookup公式,筛选、分列、多列排序、分类汇总、Ctrl+G>定点条件>可见单元格、插入图表

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/159400.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Linux下修改Mysql密码的多种方式「建议收藏」

    Linux下修改Mysql密码的多种方式「建议收藏」有时我们会忘记Mysql的密码,或者想改一个密码,以下将对这两种情况修改密码的三种解决方法做个总结本文都以用户为root为例;一、拥有原来的myql的root的密码;方法一:在mysql系统外,使用mysqladminmysqladmin-uroot-ppassword”test123″Enterpassword:【输入原来的密码】方法二:通过登录mysql系统,mysq

    2022年5月27日
    35
  • java: 找不到符号「建议收藏」

    java: 找不到符号「建议收藏」java:找不到符号符号:类TypeInformationTestBase位置:程序包org.apache.flink.api.common.typeutils程序报这种错误,不是代码造成的。解决办法:0、首先要统一编码格式:file–>settings–>fileencodings1、右键–>maven–>reloadproject2、build或rebuild3、flile–>inv..

    2022年7月8日
    65
  • jsonObject转map_json字符串转jsonobject对象

    jsonObject转map_json字符串转jsonobject对象Map转JSONObject<!–https://mvnrepository.com/artifact/com.alibaba/fastjson–><dependency><groupId>com.alibaba</groupId><artifactId>fastjson</artifactId><version>1.2.59</version></depende

    2022年9月28日
    2
  • 首批共享单车死于2019

    首批共享单车死于2019作者|周晶晶本文经授权转自燃财经(ID:rancaijing)共享单车换车潮正在上演。最近,微博上陆续有网友晒出车身为黄色、印有“美团单车”字样的共享单车,地点多集中在北京、太原等地。日前,燃财经来到人流量较大的五环外立水桥生活圈,以及四环内的望京CBD办公圈,发现确实有不少黄色美团单车。在立水桥地铁站出口,长约800米的单车停放区域,数量明显较多的美团单车、摩拜单…

    2022年5月26日
    44
  • mybatis的逆向工程怎么实现_mybatisinsert

    mybatis的逆向工程怎么实现_mybatisinsert1.什么是逆向工程mybatis官方提供逆向工程,可以针对单表自动生成mybatis执行所需要的代码(mapper.java、mapper.xml、pojo…)企业实际开发中,常用的逆向工程方式:由数据库的表生成java代码。注意:只能对单表进行操作2.逆向工程的作用myBatis逆向工程可以方便的从数据库中将表自动映射到JAVAPOJO类,并同时生成Mapper.xml和Mapper接…

    2022年8月21日
    5
  • 如何重新初始化磁盘[通俗易懂]

    如何重新初始化磁盘[通俗易懂]

    2025年12月9日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号