zoukankan      html  css  js  c++  java
  • 记一次优化的的意外收获

    一.在获取MySQL连接的时候发现如下问题

    第一次访问

    第二次访问

    下面是我做测试的代码

    二.原因

      1.第一次访问慢,第二次快,很容易想到缓存,这里我们是对获取连接的代码进行测试,所以应该是连接缓存,我们使用navicat的服务器监视功能监视MySQL的连接情况,但连接数一直稳定在四个,没有增加,也就没有缓存。

      2.不是连接缓存那就有可能是在第一次查询会做一些解析工作,后面了解到,mysql会有一个叫做反向解析的过程,也就是通过IP查找域名,这个过程会很耗时,但与这个关联的是一个叫Host Cache的东西,在反向解析查找到后,会把这个主机的IP与域名以及错误信息暂时缓存起来,如果第二次访问有这个缓存说明进行了反向解析,但很遗憾并没有,说明并不是这个影响的。

      3.在后来询问老师,在一番检查后认为是因为第一次会把许多类加载进内存,而第二次不用加载,就是这个过程耗费了几百毫秒的时间,因为Connect方法的调用会涉及许多底层类的加载与各种初始化,所以很有可能,最后在主方法调用此方法,每次耗费时间相同,因为主方法每次都会重新加载类,至此原因水落石出,完美。

  • 相关阅读:
    BZOJ4401 块的计数
    poj2914 Minimum Cut 全局最小割模板题
    无向图求最小割集
    HDU3232 Crossing Rivers 数学期望问题
    poj1386 字符串类型的一笔画问题 欧拉回路
    HDU3018 几笔画(非1笔)
    欧拉路&&欧拉回路 概念及其练习
    欧拉回路基础 HDU1878 欧拉回路||并差集
    我的明天在何处
    哈夫曼树讲解
  • 原文地址:https://www.cnblogs.com/lollong/p/11539954.html
Copyright © 2011-2022 走看看