摘要:銷售助手緩存優(yōu)化實(shí)驗(yàn)報(bào)告問題背景移動銷售助手又名外勤通,個別頁面訪問非常慢,急需優(yōu)化。結(jié)論二對于簡單的,無須從優(yōu)化為緩存。
銷售助手-緩存優(yōu)化實(shí)驗(yàn)報(bào)告
2015.4.7 by ouyida3
移動APP-銷售助手(又名外勤通),個別頁面訪問非常慢,急需優(yōu)化。
實(shí)驗(yàn)環(huán)境Oracle數(shù)據(jù)庫:測試環(huán)境32.121.2.132(性能還行,但發(fā)現(xiàn)偶爾會有問題)
后臺WEB應(yīng)用:本機(jī)環(huán)境MyEclipse+Weblogic(本機(jī)暫時發(fā)現(xiàn)很好,完全沒有性能瓶頸)
前臺MAPP應(yīng)用:測試環(huán)境30.51.23.250(該機(jī)器是svn服務(wù)器,性能不怎么樣)
手機(jī)APP應(yīng)用:iphone5,ios8.2安裝(沒有性能瓶頸)
優(yōu)化手段某些表使用Ehcache把數(shù)據(jù)通過Key-Value緩存,不用每次均從數(shù)據(jù)庫取數(shù)。
優(yōu)化代碼:
詳見:/mapp/src/com/age/mapp/bean/MappTaskBean.java
修改前,每次均讀取oracle的方法:
javacomdao.getStaticValue 修改后,只第一次從oracle讀取,第二次以后從緩存讀?。篊acheUtils.getStaticValue 代碼如下: // 優(yōu)化效率,改為讀取緩存 author Ouyida3 2015.4.4 //taskmap.put("URGENT", comdao.getStaticValue(task.getString("URGENT"), "MAPP_EMERGENT_TYPE")); taskmap.put("URGENT", CacheUtils.getStaticValue(task.getString("URGENT"), "MAPP_EMERGENT_TYPE", pd));
為了測試使用時間,在前后均加上時間的打印代碼:
java// 增加時間差顯示,優(yōu)化效率時使用 2015.4.4 Date beginDate = null; if (log.isDebugEnabled()) { beginDate = new java.util.Date(); } taskmap.put("URGENT", CacheUtils.getStaticValue(task.getString("URGENT"), "MAPP_EMERGENT_TYPE", pd)); // 增加時間差顯示,優(yōu)化效率時使用 author OuyangDa 2015.4.4 if (log.isDebugEnabled()) { SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss SSS"); Date endDate = new Date(); String beginTime = sdf.format(beginDate); String endTime = sdf.format(endDate); log.debug("請求和返回時間分別是:" + endTime + " , " + beginTime); }
修改前的時間占用
連續(xù)進(jìn)行了5次測試。第一次和第三次分別占用了15和16毫秒,其余均占用0毫秒。證明即使連接oracle,也不是每次都占用毫秒級的時間,應(yīng)該是oracle內(nèi)部作了優(yōu)化,把同樣的sql放到緩存池了,提高了命中率。
DEBUG(MappTaskBean) 請求和返回時間分別是:2015-04-07 14:46:12 039 , 2015-04-07 14:46:12 024
DEBUG(MappTaskBean) 請求和返回時間分別是:2015-04-07 14:46:35 539 , 2015-04-07 14:46:35 539
DEBUG(MappTaskBean) 請求和返回時間分別是:2015-04-07 14:46:59 149 , 2015-04-07 14:46:59 133
DEBUG(MappTaskBean) 請求和返回時間分別是:2015-04-07 14:47:47 117 , 2015-04-07 14:47:47 117
DEBUG(MappTaskBean) 請求和返回時間分別是:2015-04-07 14:48:11 117 , 2015-04-07 14:48:11 117
修改后的時間占用
第一次訪問,使用時間均為16毫秒。重啟了weblogic,再次試驗(yàn),第一次訪問還是為16毫秒。
DEBUG(MappTaskBean) 請求和返回時間分別是:2015-04-07 14:34:45 961 , 2015-04-07 14:34:45 945
第二次以后的訪問,使用時間均為0毫秒。說明此時的占用時間已經(jīng)是微妙級以下。
DEBUG(MappTaskBean) 請求和返回時間分別是:2015-04-07 14:28:36 524 , 2015-04-07 14:28:36 524
DEBUG(MappTaskBean) 請求和返回時間分別是:2015-04-07 14:36:26 695 , 2015-04-07 14:36:26 695
實(shí)驗(yàn)結(jié)論
結(jié)論一
第一次連接Oracle數(shù)據(jù)庫的時間:大約16毫秒
一模一樣的SQL,第二次以后連接Oracle數(shù)據(jù)庫的時間:大多數(shù)為0毫秒,偶然會占用大約16毫秒
從Ehcache取數(shù)時間:大約0毫秒
也就是說從Oracle取數(shù)與從Ehcache緩存里取數(shù),相差的時間大約為16毫秒。
結(jié)論二
對于簡單的SQL,無須從Oracle優(yōu)化為緩存。
因?yàn)楹唵蔚腟QL,只要每次都能在Oracle里命中,從Oracle里取數(shù)也能達(dá)到0毫秒的性能。
ouyida3的segmentfault的blog
2015.4.7
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/61770.html
摘要:更好的安全性隨著的發(fā)布,從升級到了,更安全且更易配置。通過使用,程序可以減少握手所需時間來提升請求性能。提供診斷報(bào)告有一項(xiàng)實(shí)驗(yàn)功能,根據(jù)用戶需求提供診斷報(bào)告,包括崩潰性能下降內(nèi)存泄露使用高等等。前端精讀幫你篩選靠譜的內(nèi)容。 1. 引言 Node12 發(fā)布有幾個月了,讓我們跟隨 Nodejs 12 一起看看 Node12 帶來了哪些改變。 2. 概述 Node12 與以往的版本不同,帶來...
摘要:巔峰人生年老兵思路上的轉(zhuǎn)變,遠(yuǎn)比單純提升技術(shù)更有價值本文節(jié)選自趙成教授在極客時間開設(shè)的趙成的運(yùn)維體系管理課,是其對自己十年技術(shù)生涯的回顧與總結(jié)。趙成教授來自美麗聯(lián)合集團(tuán),集團(tuán)旗下兩大主力產(chǎn)品是蘑菇街和美麗說,目前負(fù)責(zé)管理集團(tuán)的技術(shù)服務(wù)團(tuán)隊(duì)。 showImg(https://segmentfault.com/img/remote/1460000012476504?w=1240&h=826...
摘要:啟動速度大幅提升。同時,通過重用主進(jìn)程緩存,的啟動速度提升了。在已經(jīng)引入的特性,在里面默認(rèn)啟用,無需使用開啟。相關(guān)介紹診斷報(bào)告提供了新的實(shí)驗(yàn)性功能診斷報(bào)告,一個非常有用的特性。升級為,增強(qiáng)安全功能。 前言 時隔一年,Node.js 12 如約而至,正式發(fā)布第一個 Current 版本。 該版本帶來了諸如: V8 更新帶來好多不錯的特性。 HTTP 解析速度提升。 啟動速度大幅提升。 更好的...
摘要:在實(shí)踐中,幾乎總是通過向梯度增加來實(shí)現(xiàn)算法,而不是真正改變損失函數(shù)。顯然這是兩種不同的方法。那么,權(quán)重衰減是不是總比的正則化更好呢我們還沒發(fā)現(xiàn)明顯更糟的情況,但無論是遷移學(xué)習(xí)問題例如斯坦福汽車數(shù)據(jù)集上的的微調(diào)還是 跌宕起伏的 Adam縱觀 Adam 優(yōu)化器的發(fā)展歷程,就像過山車一樣。它于 2014 年在論文 Adam: A Method for Stochastic Optimization...
閱讀 2586·2021-11-25 09:43
閱讀 1863·2021-09-22 15:26
閱讀 3742·2019-08-30 15:56
閱讀 1714·2019-08-30 15:55
閱讀 1899·2019-08-30 15:54
閱讀 816·2019-08-30 15:52
閱讀 3158·2019-08-29 16:23
閱讀 897·2019-08-29 12:43