版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
1、redis頁面緩存html,使用redis實現(xiàn)頁面緩存 本文是 <>一書第二章的讀書筆記設(shè)計方案第一個域,是zset類型的…key是viewed:userSessionid存放的是商品id與用戶查看此商品時的timestamp第二個域,是zset類型的——可以是viewed:member是商品id(全局范圍內(nèi)),score是商品被用戶(全局范圍內(nèi))瀏覽的次數(shù)(是負數(shù))第三個域,是hash類型的-- key是item:item
2、ld存放的是商品的信息用戶查看了某件商品public void viewitem (Jed is conn, String token, String user, String item){long timestamp = System.currentTimeMillis() / 1000;if (item != null) {〃用戶user在某時瀏覽了某件商品conn.zadd(“viewed:“ + token, timestamp
3、, item);〃只記錄用戶最近查看的25件商品conn.zremrangeByRank(“viewed:“ + token, 0, -26);〃有序set里score的越小排名越靠前conn.zincrbyC'viewed:“, -1, item);//-15i®l?))試著緩存這個頁面首先我們要判斷某個url是否能緩存/*** 如果request不符合規(guī)范就不緩存返回false如果商品還沒有被訪問過自然不能緩存返回
4、false* 如果商品被訪問過但是訪問的排名在10000之后也就不緩存了返回false如果商品被訪問過且訪問的排名在10000之內(nèi)就說明可以緩存返回true★@param conn* @param request“@returnVpublic boolean canCache(Jedis conn, String request) {〃這樣的字符串中獲得paramter代碼就不贅述了Map params = getParams(requ
5、est);if (params = = null)return false;〃獲得itemX這個信息String itemld = extractltemld(params);//params.containsKey(“_“)這個條件只是示例//ffl戶可以加上自己的判別條件if (itemld == null || params.containsKey(“_“)){return false;)“viewed:這個有序集里存放的是商品的
6、訪問次數(shù)Long rank = conn.zrankC'viewed:“, itemld);//查看這個商品的訪問量是否在前10000內(nèi)〃如果rank二二null說明商品還沒有被訪問過return rank != null )實現(xiàn)緩存requestpublic String cacheRequest(Jedis conn, String request, Callback callback){if (!canCache(conn
7、z request)) {return callback != null ? callback.call(request): null;)String pageKey = “cache:“ + hashRequest(request);〃這個只是示例真實的情況應(yīng)該是復(fù)雜的業(yè)務(wù)邏輯產(chǎn)生items.add(itemData);)return items;)在viewitem里,我們已經(jīng)記錄了所有商品的瀏覽次數(shù)(負數(shù))conn.zincrby
8、(“viewed:“; “l(fā)z item);那么經(jīng)過n天后,這個viewed里的數(shù)據(jù)項就很多了,而且其實也沒有必要一直保存著所有商品的瀏覽次數(shù)所以publicclass RescaleViewedThread implementsRunnable{ private Jedis conn;private boolean quit;public RescaleViewedThread(int limit){conn = newJedis(-
9、10.150.0.80“);conn.auth(“dlfl23123“);)public void shutDown(){ quit=true;)@Override public void run(){while (!quit) {try {〃移除排名20000之后的商品瀏覽信息conn.zremrangeByRankC'viewed:“, 0, -20001);〃將所有商品的瀏覽數(shù)量降低一半conn.zinterstore(“
10、viewed“/“viewed:0.5“);Thread.sleep(300);} catch (InterruptedException e) {//TODO Auto-generated catch block e.printStackT race();)))}系統(tǒng)后動后就一直運行這個線程。那么怎么做呢?怎么集成到我的項目里呢?我的項目是使用struts2開發(fā)的。 哥哥,您不知道有個東西叫攔截器么?interceptor?這個是sp
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- redis頁面緩存html,使用redis實現(xiàn)頁面緩存
- Redis緩存技術(shù)研究及應(yīng)用.pdf
- 基于Redis的結(jié)構(gòu)化數(shù)據(jù)緩存系統(tǒng)的設(shè)計與實現(xiàn).pdf
- 基于MongoDB和Redis的數(shù)據(jù)緩存方法的研究與應(yīng)用.pdf
- 操作系統(tǒng)頁面緩存優(yōu)化技術(shù)研究.pdf
- 應(yīng)用—nginx 反向代理、負載均衡、頁面緩存、url重寫及讀寫分離詳解
- 基于頁面分類與放置策略的混合緩存管理機制研究.pdf
- redis與網(wǎng)站架構(gòu)
- redis筆記整理后
- 【客戶】使用【香港自提頁面教程】
- 頁面
- 基于redis的券商活動平臺的設(shè)計與實現(xiàn).pdf
- 項目5使用css控制頁面元素
- 頁面.doc
- 頁面.doc
- 頁面.doc
- 基于html5移動web頁面開發(fā)技術(shù)研究
- 基于內(nèi)容個性化的HTML頁面轉(zhuǎn)換研究.pdf
- 基于自制模板動態(tài)生成HTML頁面的財務(wù)報賬系統(tǒng)設(shè)計與實現(xiàn).pdf
- nosql數(shù)據(jù)庫-mongodb和redis
評論
0/150
提交評論