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

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

    第一次访问

    第二次访问

    下面是我做测试的代码

    二.原因

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

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

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

  • 相关阅读:
    smarty中ifelse、foreach以及获取数组中键值名的一个实例
    smarty逻辑运算符
    python strip()函数 介绍
    (转)论python工厂函数与内建函数
    数据结构哈希表(转)
    哈希表算法的编写
    哈希表(转)
    平衡二叉树的旋转操作
    并查集详解(转)
    Java数组技巧攻略
  • 原文地址:https://www.cnblogs.com/lollong/p/11539954.html
Copyright © 2011-2022 走看看