国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務器之家:專注于服務器技術及軟件下載分享
分類導航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|數(shù)據(jù)庫技術|

服務器之家 - 數(shù)據(jù)庫 - Mysql - MySQL中實現(xiàn)高性能高并發(fā)計數(shù)器方案(例如文章點擊數(shù))

MySQL中實現(xiàn)高性能高并發(fā)計數(shù)器方案(例如文章點擊數(shù))

2020-04-22 15:23MYSQL教程網(wǎng) Mysql

這篇文章主要介紹了MySQL中實現(xiàn)高性能高并發(fā)計數(shù)器方案,本文中的計數(shù)器是指如文章的點擊數(shù)、喜歡數(shù)、瀏覽次數(shù)等,需要的朋友可以參考下

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

言歸正傳,對文章資訊類為主的項目,在瀏覽一個頁面的時候不但要進行大量的查(查詢上文的記錄,已經(jīng)所屬分類的名字、熱門文章資訊評論、TAG等),還要進行寫操作(更新瀏覽數(shù)點擊數(shù))。把文章的詳細內(nèi)容和計數(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;

 

這種方式,雖然分擔了文章表的壓力,但是每當有一個進程請求更新的時候,都會產(chǎn)生全局的互斥鎖,只能串行,不能并行。在高并發(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ā)變的更復雜,維護成本等。所以并不是讀的速度越快越好,需要找一個平衡點。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 日韩电影网站 | 日韩在线播放一区二区 | 亚洲一区免费在线观看 | 成人av观看 | 亚洲精品欧美 | 99久久精品一区二区成人 | 福利在线播放 | 九九re热 | 手机看片亚洲 | 久久精品小视频 | 国产精品久久久久久久久久久久冷 | 81精品国产乱码久久久久久 | 欧美午夜在线观看 | 午夜成人免费电影 | 国产精品一区二区三区在线播放 | 日本视频在线播放 | 亚洲欧洲精品视频 | 中文字幕电影在线 | 亚洲视频综合 | 黄色在线免费看 | 美女视频一区二区三区 | 日韩免费在线观看 | 国产 日韩 欧美 在线 | 自拍视频在线观看 | 欧美视频中文字幕 | 国产精品视频一 | 中文字幕日韩一区 | 一级特黄录像免费播放全99 | 久久精品免费观看 | 国产精品香蕉 | 国产精品久久久久国产a级 最新国产视频 | 99精品一区二区三区 | 国产精品美女www爽爽爽软件 | 精品国产乱码久久久久久图片 | 在线视频 91 | 欧美a网站| 少妇精品久久久久久久久久 | 黄色一级视频 | 在线欧美视频 | 午夜av一区二区 | 久久久久久久免费 |