mysql中實現(xiàn)高性能高并發(fā)計數(shù)器方案
來源:易賢網 閱讀:762 次 日期:2014-11-12 15:10:01
溫馨提示:易賢網小編為您整理了“mysql中實現(xiàn)高性能高并發(fā)計數(shù)器方案”,方便廣大網友查閱!

現(xiàn)在有很多的項目,對計數(shù)器的實現(xiàn)甚是隨意,比如在實現(xiàn)網站文章點擊數(shù)的時候,是這么設計數(shù)據(jù)表的,如:”article_id, article_name, article_content, article_author, article_view……在article_view中記錄該文章的瀏覽量。詐一看似乎沒有問題。對于小站,比如本博客,就是這么做的,因為小菜的博客難道會涉及并發(fā)問題嗎?答案顯而易見,一天沒多少ip,而且以后不會很大。

言歸正傳,對文章資訊類為主的項目,在瀏覽一個頁面的時候不但要進行大量的查(查詢上文的記錄,已經所屬分類的名字、熱門文章資訊評論、tag等),還要進行寫操作(更新瀏覽數(shù)點擊數(shù))。把文章的詳細內容和計數(shù)器放在一張表盡管對開發(fā)很方便,但是會造成數(shù)據(jù)庫的壓力過大(不然為什么大項目都要分庫分表呢)。

那么,分兩張表存放就好了么?一張表存文章詳細信息,另一張表單獨存計數(shù)器。

代碼如下:

create table `article_view`(

`article_id` int(11) not null,

`view` int(11) not null,

primary key (`article_id`)

)engine=innodb;

這種方式,雖然分擔了文章表的壓力,但是每當有一個進程請求更新的時候,都會產生全局的互斥鎖,只能串行,不能并行。在高并發(fā)下會有較長的等待時間。

另一種比較好的辦法是對每一個文章的計數(shù)器不是一行,而是多行,比如吧,一百行。每次隨機更新其中一行,該文章的瀏覽數(shù)就是所有行的和。

代碼如下:

create table `article_view`(

`article_id` int(11) not null,

`pond` tinyint(4) not null comment '池子,就是用來隨機用的',

`view` int(11) not null,

primary key (`article_id`,`pond`)

)engine=innodb;

小訪問量的隨機池子100個肯定多了,三五個足矣。每次訪問的時候,隨機一個數(shù)字(1-100)作為pond,如何該pond存在則更新view+1,否則插入,view=1。借助duplicate key,不然在程序里是實現(xiàn)得先select,判斷一下再insert或者update。

代碼如下:

insert into `article_view` (`article_id`, `pond`, `view`) values (`123`, rand()*100, 1) on duplicate key update `view`=`view`+1

獲取指定文章的總訪問量的時候:

代碼如下:

select sum(`view`) from `article_view` where `article_id`='123'

ps:凡事都是雙刃劍。為了更快的讀我們通常要犧牲一些東西。在讀比較多的表要加快讀的速度,在寫較多的表要加快寫的速度。各自權衡。在加快讀的速度的時候,我們犧牲的并不僅僅是寫的性能,還有開發(fā)成本,開發(fā)變的更復雜,維護成本等。所以并不是讀的速度越快越好,需要找一個平衡點。

更多信息請查看IT技術專欄

更多信息請查看數(shù)據(jù)庫

2025國考·省考課程試聽報名

  • 報班類型
  • 姓名
  • 手機號
  • 驗證碼
關于我們 | 聯(lián)系我們 | 人才招聘 | 網站聲明 | 網站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
工業(yè)和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網安備53010202001879號 人力資源服務許可證:(云)人服證字(2023)第0102001523號
聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關注公眾號:hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權所有:易賢網