欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時(shí)間:2014年10月24日 10:40:34   投稿:junjie  
這篇文章主要介紹了MySQL中實(shí)現(xiàn)高性能高并發(fā)計(jì)數(shù)器方案,本文中的計(jì)數(shù)器是指如文章的點(diǎn)擊數(shù)、喜歡數(shù)、瀏覽次數(shù)等,需要的朋友可以參考下

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

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

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

復(fù)制代碼 代碼如下:

CREATE TABLE `article_view`(
`article_id` int(11) NOT NULL,
`view` int(11) NOT NULL,
PRIMARY KEY (`article_id`)
)ENGINE=InnoDB;

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

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

復(fù)制代碼 代碼如下:

CREATE TABLE `article_view`(
`article_id` int(11) NOT NULL,
`pond` tinyint(4) NOT NULL COMMENT '池子,就是用來隨機(jī)用的',
`view` int(11) NOT NULL,
PRIMARY KEY (`article_id`,`pond`)
)ENGINE=InnoDB;

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

復(fù)制代碼 代碼如下:

INSERT INTO `article_view` (`article_id`, `pond`, `view`) VALUES (`123`, RAND()*100, 1) ON DUPLICATE KEY UPDATE `view`=`view`+1

獲取指定文章的總訪問量的時(shí)候:

復(fù)制代碼 代碼如下:

SELECT SUM(`view`) FROM `article_view` WHERE `article_id`='123'

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

相關(guān)文章

  • MySQL綠色版設(shè)置編碼以及1067錯(cuò)誤詳解

    MySQL綠色版設(shè)置編碼以及1067錯(cuò)誤詳解

    這篇文章主要介紹了MySQL綠色版設(shè)置編碼,以及1067錯(cuò)誤的相關(guān)資料,需要的朋友可以參考下
    2017-05-05
  • MySQL binlog日志清理的方案分享

    MySQL binlog日志清理的方案分享

    Binlog日志非常重要,但是占用的磁盤空間也很大,我們也需要定期的去清理二進(jìn)制日志,在MySQL數(shù)據(jù)庫(kù)中,提供了自動(dòng)清理Binlog日志的參數(shù),本文給大家詳細(xì)介紹了MySQL binlog日志清理方案,需要的朋友可以參考下
    2024-01-01
  • SQL Server數(shù)據(jù)庫(kù)錯(cuò)誤5123解決方案

    SQL Server數(shù)據(jù)庫(kù)錯(cuò)誤5123解決方案

    這篇文章主要介紹了SQL Server數(shù)據(jù)庫(kù)錯(cuò)誤5123解決方案,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-06-06
  • 一文帶你了解MySQL中觸發(fā)器的操作

    一文帶你了解MySQL中觸發(fā)器的操作

    觸發(fā)器,就是一種特殊的存儲(chǔ)過程。觸發(fā)器和存儲(chǔ)過程一樣是一個(gè)能夠完成特定功能、存儲(chǔ)在數(shù)據(jù)庫(kù)服務(wù)器上的SQL片段。本文將通過簡(jiǎn)單的實(shí)力介紹一下觸發(fā)器的操作,需要的可以參考一下
    2023-02-02
  • Mysql錯(cuò)誤:Too many connections的解決方法

    Mysql錯(cuò)誤:Too many connections的解決方法

    這篇文章主要給大家介紹了關(guān)于Mysql錯(cuò)誤Too many connections的解決方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用Mysql具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-06-06
  • 關(guān)于pt-archiver和自增主鍵的那些事

    關(guān)于pt-archiver和自增主鍵的那些事

    mysql是我們經(jīng)常會(huì)用到的一個(gè)數(shù)據(jù)庫(kù),mysql數(shù)據(jù)庫(kù)中有一個(gè)主鍵生成規(guī)則,就是自增,這篇文章主要給大家介紹了關(guān)于pt-archiver和自增主鍵的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-04-04
  • MySQL中REPLACE INTO和INSERT INTO的區(qū)別分析

    MySQL中REPLACE INTO和INSERT INTO的區(qū)別分析

    REPLACE的運(yùn)行與INSERT很相似。只有一點(diǎn)例外,假如表中的一個(gè)舊記錄與一個(gè)用于PRIMARY KEY或一個(gè)UNIQUE索引的新記錄具有相同的值,則在新記錄被插入之前,舊記錄被刪除。
    2011-07-07
  • MYSQL 完全備份、主從復(fù)制、級(jí)聯(lián)復(fù)制、半同步小結(jié)

    MYSQL 完全備份、主從復(fù)制、級(jí)聯(lián)復(fù)制、半同步小結(jié)

    這篇文章主要介紹了MYSQL 完全備份、主從復(fù)制、級(jí)聯(lián)復(fù)制、半同步小結(jié),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2019-05-05
  • percona-toolkit對(duì)MySQL的復(fù)制和監(jiān)控類操作教程

    percona-toolkit對(duì)MySQL的復(fù)制和監(jiān)控類操作教程

    這篇文章主要介紹了使用percona-toolkit對(duì)MySQL進(jìn)行復(fù)制和監(jiān)控類操作的教程,percona-toolkit是一款強(qiáng)大的MySQL輔助軟件,需要的朋友可以參考下
    2015-11-11
  • 如何添加一個(gè)mysql用戶并給予權(quán)限詳解

    如何添加一個(gè)mysql用戶并給予權(quán)限詳解

    在很多時(shí)候我們并不會(huì)直接利用mysql的root用戶進(jìn)行項(xiàng)目的開發(fā),一般我們都會(huì)創(chuàng)建一個(gè)具有部分權(quán)限的用戶,下面這篇文章主要給大家介紹了關(guān)于如何添加一個(gè)mysql用戶并給予權(quán)限的相關(guān)資料,需要的朋友可以參考下
    2023-03-03

最新評(píng)論