前言
工作越久發(fā)現(xiàn)自己越麻瓜。感覺只有每天積累一點(diǎn)擂红,才不會覺得空虛仪际。
redis-benchmark用法
redis-benchmark是用于給redis進(jìn)行壓測的。
1.100個并發(fā)連接昵骤,10000個請求
redis-benchmark -h 127.0.0.1 -p 6379 -c 100 -n 10000
2.存取大小為100字節(jié)的數(shù)據(jù)包
redis-benchmark -h 127.0.0.1 -p 6379 -q -d 100
3.只測試某些操作的性能
redis-benchmark -t set,get,lpush -q -n 10000
4.只測試某些數(shù)據(jù)存取的性能
redis-benchmark -n 10000 -q script load "redis.call('set','cmazxiaoma','123')"
jmeter命令行使用
1.在windows上錄好jmx
2.在linux上進(jìn)行命令行操作
sh jmeter.sh -n -t xxx.jmx -l result.jtl
3.把result.jtl導(dǎo)入到windows上的jmeter
合理更新緩存
一般我們正確使用Redis的策略是先更新數(shù)據(jù)庫树碱,再刪除緩存。在這種情況下变秦,我們可以考慮出臟數(shù)據(jù)的場景:有一個讀操作成榜,但是沒有命中緩存,然后就到數(shù)據(jù)庫取數(shù)據(jù)蹦玫。此時正好來了一個寫操作伦连,讓緩存失效,然后之前的那個讀操作再把老數(shù)據(jù)放到緩存中钳垮,所以產(chǎn)生了臟數(shù)據(jù)惑淳。
但是這種場景出現(xiàn)的概率很低,因?yàn)檫@個條件需要發(fā)現(xiàn)在讀操作時緩存需要失效饺窿,而且并發(fā)著有一個寫操作歧焦。而實(shí)際上數(shù)據(jù)庫的寫操作會比讀操作慢的多,而且要鎖表,而讀操作必須要在寫操作之前進(jìn)行數(shù)據(jù)庫操作绢馍,而且還要晚于寫操作更新緩存向瓷。
Linux命令
1.查看linux服務(wù)器CPU核數(shù)
cat /proc/cpuinfo|grep processor
2.給腳本賦權(quán)限,chmod是change the permissions mode of file。u代表所有者舰涌,x代表執(zhí)行權(quán)限猖任,+表示增加權(quán)限。
chmod n+x *.sh
3.查看系統(tǒng)當(dāng)前可用內(nèi)存
cat /proc/meminfo
Java編碼
1.Java一律采用Unicode編碼方式瓷耙,每個字符無論中文還是英文字符都占有2個字節(jié)朱躺。
2.Java虛擬機(jī)中通常使用UTF-16的方式來保存一個字符。
MySQL
1.我們查看會話等待時間搁痛,全局等待時間长搀。特別提醒:時間的大小不能隨便設(shè)置,時間過長導(dǎo)致過多的connection sleep鸡典,占用較多系統(tǒng)資源源请。從業(yè)務(wù)出發(fā),結(jié)合查詢的耗時和業(yè)務(wù)吞吐量彻况。
show global variables like 'wait_timeout'
show session variables like '%wait%'
2.建唯一索引
alter table order_info add unique key u_idx_user_goods(user_id,goods_id)
Http狀態(tài)碼
當(dāng)我們前后端分離 + 頁面靜態(tài)化(htm + ajax)去做商品詳情頁時谁尸,請求會返回304。304狀態(tài)碼:如果客戶端發(fā)送了一個帶條件的GET請求且該請求已被允許纽甘,而文檔的內(nèi)容并沒有改變症汹,則服務(wù)器應(yīng)返回這個304狀態(tài)。對于商品詳情頁而言贷腕,對數(shù)據(jù)的及時性沒有那么的高,應(yīng)該考慮將界面緩存到用戶的瀏覽器中咬展。在application-dev.properties中j進(jìn)行如下配置泽裳。
spring.resources.chain.cache=true
spring.resources.chain.enabled=true
Ajax
當(dāng)我們發(fā)送Ajax的請求時,要判斷readystate=4和status=200才能進(jìn)行下一步破婆。那么readystate又分為哪幾步呢涮总。
0 - 未初始化,還沒有創(chuàng)建對象祷舀。
1 - 已打開瀑梗,對象已經(jīng)創(chuàng)建并且已初始化,但還未調(diào)用send方法裳扯。
2 - 已發(fā)送抛丽,已經(jīng)調(diào)用send方法,但對象等待狀態(tài)碼和響應(yīng)頭返回饰豺。
3 - 正在接收亿鲜,已經(jīng)接收到部分?jǐn)?shù)據(jù),但還不能調(diào)用該對象的屬性和方法冤吨,因?yàn)闋顟B(tài)碼和響應(yīng)頭不完整蒿柳。
4 - 已加載完饶套,所有數(shù)據(jù)接收完畢。
Shiro
Shiro的Subject對象是由SecurityManager垒探、HttpRequest等信息創(chuàng)建妓蛮,然后把Subject綁定到當(dāng)前線程(servlet線程)。SecurityUtils的getSubject方法是從當(dāng)前線程中獲得到Subject對象的圾叼。
ThreadLocal
ThreadLocal本身不存儲值蛤克,每一個Thread維護(hù)著一個ThreadLocalMap,ThreadLocalMap中的key就是ThreadLocal實(shí)例本身褐奥,value是其需要存儲的Object對象咖耘。
ThreadLocalMap使用ThreadLocal的弱引用作為其key,如果一個ThreadLocal沒有外部強(qiáng)引用去引用它撬码,那么系統(tǒng)GC的時候儿倒,這個ThreadLocal會被回收。GC后呜笑,ThreadLocal會出key為null的Entry夫否,我們無法訪問這些key為null的Entry中的value。如果當(dāng)前線程遲遲不結(jié)束的話叫胁,這樣key為null的Entry的value就會形成一條引用鏈:Thread Ref -> Thread -> ThreadLocalMap -> Entry -> value凰慈,最終造成內(nèi)存泄漏。
尾言
腦子不好使驼鹅,就多背多積累吧微谓。