校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > 分析Cache 在 Ruby China 里面的應用情況

分析Cache 在 Ruby China 里面的應用情況

熱門標簽:征服者企業地圖標注 中牟外呼系統違法嗎 漯河電銷 AI電銷機器人 線路 天津外呼系統怎么收費 柯城手機地圖如何做地圖標注 外呼線路從哪里出來的 淮安自動外呼系統供應商 巫師3地圖標注魔力之所

首先給大家看一下 NewRelic 的報表

最近 24h 的平均響應時間

流量高的那些頁面 (Action)

訪問量搞的幾個 Action 的情況:

TopicsController#show

UsersController#show (比較慘,主要是 GitHub API 請求拖慢)

PS: 在發布這篇文章之前我有稍加修改了一下,GitHub 請求放到后臺隊列處理,新的結果是這樣:

TopicsController#index

HomeController#index

從上面的報表來看,目前 Ruby China 后端的請求,排除用戶主頁之外,響應時間都在 100ms 以內,甚至更低。

我們是如何做到的?

Markdown 緩存
Fragment Cache
數據緩存
ETag
靜態資源緩存 (JS,CSS,圖片)
Markdown 緩存

在內容修改的時候就算好 Markdown 的結果,存到數據庫,避免瀏覽的時候反復計算。

此外這個東西也特意不放到 Cache,而是放到數據庫里面:

為了持久化,避免 Memcached 停掉的時候,大量丟失;
避免過多占用緩存內存;

class Topic
 field :body # 存放原始內容,用于修改
 field :body_html # 存放計算好的結果,用于顯示

 before_save :markdown_body
 def markdown_body
  self.body_html = MarkdownTopicConverter.format(self.body) if self.body_changed?
 end
end
Fragment Cache

這個是 Ruby China 里面用得最多的緩存方案,也是速度提升的原因所在。

app/views/topics/_topic.html.erb

% cache([topic, suggest]) do %>
div class="topic topic_line topic_%= topic.id %>">
  %= link_to(topic.replies_count,"#{topic_path(topic)}#reply#{topic.replies_count}",
     :class => "count state_false") %>
 ... 省略內容部分

/div>
% end %>

用 topic 的 cache_key 作為緩存 cache views/topics/{編號}-#{更新時間}/{suggest 參數}/{文件內容 MD5} -> views/topics/19105-20140508153844/false/bc178d556ecaee49971b0e80b3566f12
某些涉及到根據用戶帳號,有不同狀態顯示的地方,直接把完整 HTML 準備好,通過 JS 控制狀態,比如目前的“喜歡“功能。

script type="text/javascript">
 var readed_topic_ids = %= current_user.filter_readed_topics(@topics) %>;
 for (var i = 0; i  readed_topic_ids.length; i++) {
  topic_id = readed_topic_ids[i];
  $(".topic_"+ topic_id + " .right_info .count").addClass("state_true");
 }
/script>

再比如

app/views/topics/_reply.html.erb

 % cache([reply,"raw:#{@show_raw}"]) do %>
div class="reply">
 div class="pull-left face">%= user_avatar_tag(reply.user, :normal) %>/div>
 div class="infos">
  div class="info">
   span class="name">
    %= user_name_tag(reply.user) %>
   /span>
   span class="opts">
    %= likeable_tag(reply, :cache => true) %>
    %= link_to("", edit_topic_reply_path(@topic,reply), :class => "edit icon small_edit", 'data-uid' => reply.user_id, :title => "修改回帖")%>
    %= link_to("", "#", 'data-floor' => floor, 'data-login' => reply.user_login,
      :title => t("topics.reply_this_floor"), :class => "icon small_reply" )
    %>
   /span>
  /div>
  div class="body">
   %= sanitize_reply reply.body_html %>
  /div>
 /div>
/div>
% end %>

同樣也是通過 reply 的 cache_key 來緩存 views/replies/202695-20140508081517/raw:false/d91dddbcb269f3e0172bf5d0d27e9088

同時這里還有復雜的用戶權限控制,用 JS 實現;

script type="text/javascript">
 $(document).ready(function(){
  % if admin? %>
   $("#replies .reply a.edit").css('display','inline-block');
  % elsif current_user %>
   $("#replies .reply a.edit[data-uid='%= current_user.id %>']").css('display','inline-block');
  % end %>
  % if current_user  !@user_liked_reply_ids.blank? %>
   Topics.checkRepliesLikeStatus([%= @user_liked_reply_ids.join(",") %>]);
  % end %>
 })
/script>

數據緩存

其實 Ruby China 的大多數 Model 查詢都沒有上 Cache 的,因為據實際狀況來看, MongoDB 的查詢響應時間都是很快的,大部分場景都是在 5ms 以內,甚至更低。

我們會做一些比價負責的數據查詢緩存,比如:GitHub Repos 獲取

def github_repos(user_id)
 cache_key = "user:#{user_id}:github_repos"
 items = Rails.cache.read(cache_key)
 if items.blank?
  items = real_fetch_from_github()
  Rails.cache.write(cache_key, items, expires_in: 15.days)
 end
 return items
end
ETag

ETag 是在 HTTP Request, Response 可以帶上的一個參數,用于檢測內容是否有更新過,以減少網絡開銷。

過程大概是這樣

Rails 的 fresh_when 方法可以幫助將你的查詢內容生成 ETag 信息

def show
 @topic = Topic.find(params[:id])

 fresh_when(etag: [@topic])
end

靜態資源緩存

請不要小看這個東西,后端寫得再快,也有可能被這些拖慢(瀏覽器上面的表現)!

1、合理利用 Rails Assets Pipeline,一定要開啟!

# config/environments/production.rb
config.assets.digest = true

2、在 Nginx 里面將 CSS, JS, Image 的緩存有效期設成 max;

location ~ (/assets|/favicon.ico|/*.txt) {
 access_log    off;
 expires      max;
 gzip_static on;
}

3、盡可能的減少一個頁面 JS, CSS, Image 的數量,簡單的方法是合并它們,減少 HTTP 請求開銷;

head>
 ... 
 只有兩個
 link  rel="stylesheet" />
 script src="http://ruby-china-files.b0.upaiyun.com/assets/app-24d4280cc6fda926e73419c126c71206.js">/script>
 ...
/head>

一些 Tips

看統計日志,優先處理流量高的頁面;
updated_at 是一個非常有利于幫助你清理緩存的東西,善用它!修改數據的時候別忽略它!
多關注你的 Rails Log 里面的查詢時間,100ms 一下的頁面響應時間是一個比較好的狀態,超過 200ms 用戶就會感覺到遲鈍了。

您可能感興趣的文章:
  • Ruby On Rails中如何避免N+1問題
  • ruby開發vim插件小結
  • 優化Ruby腳本效率實例分享
  • Java版的Ruby解釋器 JRuby簡介
  • ruby執行周期性任務的三種gem介紹

標簽:內江 甘孜 棗莊 西雙版納 河池 南昌 克拉瑪依 大慶

巨人網絡通訊聲明:本文標題《分析Cache 在 Ruby China 里面的應用情況》,本文關鍵詞  分析,Cache,在,Ruby,China,里,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《分析Cache 在 Ruby China 里面的應用情況》相關的同類信息!
  • 本頁收集關于分析Cache 在 Ruby China 里面的應用情況的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    夜夜揉揉日日人人青青一国产精品| 国产精品久久久久久久浪潮网站| 欧美色欧美亚洲另类二区| aaa亚洲精品| av在线综合网| 欧洲色大大久久| 欧美乱妇一区二区三区不卡视频| 欧美狂野另类xxxxoooo| 精品伦理精品一区| 久久久久久亚洲综合影院红桃| 欧美成人欧美edvon| 国产清纯美女被跳蛋高潮一区二区久久w| 日韩女优av电影在线观看| 久久精品亚洲精品国产欧美| 欧美精品一区二区三区蜜桃| 亚洲欧美视频在线观看| 亚洲大片免费看| 国产精品99久久久久久似苏梦涵 | 欧美视频一区在线| 91精品国产综合久久久久久| 自拍偷拍国产精品| 免费在线观看一区二区三区| 国产福利一区在线观看| 精品视频一区二区三区免费| 国产亚洲一区字幕| 美女视频一区二区| 91福利资源站| 久久品道一品道久久精品| 日本成人在线电影网| 欧美在线观看视频一区二区三区| 91精品在线一区二区| 天天综合色天天综合色h| 在线免费精品视频| 中文字幕不卡在线观看| 成人av电影在线网| 国产亚洲人成网站| 蜜臂av日日欢夜夜爽一区| 欧美日韩你懂的| 亚洲欧美一区二区三区国产精品 | 国产精品麻豆久久久| 精品亚洲国产成人av制服丝袜| 欧美日韩国产精选| 一区二区三区视频在线观看| 色婷婷精品大视频在线蜜桃视频| 中文字幕第一区综合| 高清beeg欧美| 亚洲精品国产成人久久av盗摄 | 亚洲主播在线播放| 欧美午夜精品久久久| 亚洲韩国精品一区| 欧美大胆人体bbbb| 成人综合在线网站| 亚洲女性喷水在线观看一区| 777精品伊人久久久久大香线蕉| 蜜臂av日日欢夜夜爽一区| 久久人人超碰精品| 精品视频在线视频| 国产乱淫av一区二区三区| 中文字幕日韩一区| 91麻豆精品国产综合久久久久久| 日韩成人免费在线| 一区二区成人在线| 久久精品一二三| 欧美视频一区二区| 成人晚上爱看视频| 奇米四色…亚洲| 国产精品嫩草影院com| 欧美精品黑人性xxxx| 色综合久久综合网| www.av精品| 国产一区二区三区免费播放| 午夜私人影院久久久久| 欧美激情在线免费观看| 精品理论电影在线| 欧美日韩精品欧美日韩精品| 色狠狠一区二区| 色94色欧美sute亚洲13| 懂色av中文字幕一区二区三区| 强制捆绑调教一区二区| 亚洲一卡二卡三卡四卡无卡久久| 中文字幕一区二区三区四区不卡| 久久精品一二三| 国产精品视频一二三| 久久久五月婷婷| 久久久久久久久99精品| 3atv在线一区二区三区| 欧美成人bangbros| 国产亚洲精久久久久久| 久久精品亚洲一区二区三区浴池| 国产三级精品在线| 亚洲欧美日韩在线不卡| 亚洲欧美偷拍三级| 日韩在线a电影| 久久精品国产亚洲高清剧情介绍| 日本女人一区二区三区| 国产在线不卡一区| 成人av电影在线观看| 色视频一区二区| 26uuu亚洲综合色欧美| 自拍偷拍亚洲欧美日韩| 一区二区三区成人| 久久66热re国产| 91蜜桃视频在线| 日韩一级免费观看| 一区二区三区电影在线播| 日韩高清在线一区| 99久久免费精品| 欧美v亚洲v综合ⅴ国产v| 伊人性伊人情综合网| 国产综合一区二区| 欧美日韩精品电影| 最新中文字幕一区二区三区| 香蕉成人啪国产精品视频综合网 | 久久久久久麻豆| 午夜电影网一区| 欧美影片第一页| 一区二区成人在线视频 | 日韩午夜在线影院| 婷婷国产v国产偷v亚洲高清| 欧美日韩综合在线| 国产精品久久久久久久久免费樱桃 | 国产盗摄女厕一区二区三区| 日韩精品在线一区| 毛片不卡一区二区| 日韩一卡二卡三卡| 男女男精品视频| 欧美高清视频在线高清观看mv色露露十八| 久久久久久9999| eeuss鲁一区二区三区| 久久久激情视频| thepron国产精品| 日韩一区欧美一区| 色88888久久久久久影院野外 | 韩国一区二区视频| 欧美大胆人体bbbb| 成人h动漫精品一区二区 | 91国产视频在线观看| 日本最新不卡在线| 26uuu精品一区二区三区四区在线| 理论电影国产精品| 中文字幕在线不卡国产视频| 色视频欧美一区二区三区| 午夜成人在线视频| 久久伊人蜜桃av一区二区| 91在线一区二区| 天堂精品中文字幕在线| 欧美成人a视频| 在线精品视频一区二区三四| 亚洲福利视频一区| 26uuu精品一区二区| 色偷偷久久一区二区三区| 污片在线观看一区二区| 2020国产精品| 国产午夜亚洲精品午夜鲁丝片 | 亚洲视频免费在线观看| 精品国产123| 欧美夫妻性生活| 91热门视频在线观看| 国产乱码字幕精品高清av | 色婷婷精品久久二区二区蜜臀av| 蜜桃视频在线一区| 亚洲成av人片在线观看| 国产精品不卡在线观看| 26uuu欧美| 亚洲精品在线一区二区| 精品国产一区二区精华| 欧美片网站yy| 欧美夫妻性生活| 欧美乱妇15p| 欧美日韩国产片| 91啪亚洲精品| 91精品福利在线| 欧美在线你懂的| 欧美久久久久久蜜桃| 欧美一区二区三区在线观看| 欧美日韩一级视频| 91精品国产欧美一区二区18| 日韩免费观看高清完整版| 色八戒一区二区三区| 91久久久免费一区二区| 欧美日韩五月天| 久久在线免费观看| 亚洲欧洲日产国产综合网| 1000部国产精品成人观看| 亚洲一级二级在线| 美女视频免费一区| 国产精品白丝jk白祙喷水网站| 不卡大黄网站免费看| 欧美久久一二区| 久久久久久久久久久99999| 最新久久zyz资源站| 亚洲国产综合91精品麻豆| 激情文学综合丁香| 91浏览器入口在线观看| 欧美日韩一区精品| 中文字幕免费不卡| 三级久久三级久久| 9久草视频在线视频精品| 欧美精品精品一区| 亚洲sss视频在线视频|