免费观看又色又爽又黄的小说免费_美女福利视频国产片_亚洲欧美精品_美国一级大黄大色毛片

如何在Redis數(shù)據(jù)庫(kù)實(shí)現(xiàn)API原子性-創(chuàng)新互聯(lián)

這期內(nèi)容當(dāng)中小編將會(huì)給大家?guī)?lái)有關(guān)如何在Redis數(shù)據(jù)庫(kù)實(shí)現(xiàn)API原子性,文章內(nèi)容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

創(chuàng)新互聯(lián)服務(wù)項(xiàng)目包括臺(tái)山網(wǎng)站建設(shè)、臺(tái)山網(wǎng)站制作、臺(tái)山網(wǎng)頁(yè)制作以及臺(tái)山網(wǎng)絡(luò)營(yíng)銷策劃等。多年來(lái),我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢(shì)、行業(yè)經(jīng)驗(yàn)、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機(jī)構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,臺(tái)山網(wǎng)站推廣取得了明顯的社會(huì)效益與經(jīng)濟(jì)效益。目前,我們服務(wù)的客戶以成都為中心已經(jīng)輻射到臺(tái)山省份的部分城市,未來(lái)相信會(huì)繼續(xù)擴(kuò)大服務(wù)區(qū)域并繼續(xù)獲得客戶的支持與信任!

原子性


原子性是數(shù)據(jù)庫(kù)的事務(wù)中的特性。在數(shù)據(jù)庫(kù)事務(wù)的情景下,原子性指的是:一個(gè)事務(wù)(transaction)中的所有操作,要么全部完成,要么全部不完成,不會(huì)結(jié)束在中間某個(gè)環(huán)節(jié)。【維基百科】

對(duì)于Redis而言,命令的原子性指的是:一個(gè)操作的不可以再分,操作要么執(zhí)行,要么不執(zhí)行。

Redis操作原子性的原因


Redis的操作之所以是原子性的,是因?yàn)镽edis是單線程的。

由于對(duì)操作系統(tǒng)相關(guān)的知識(shí)不是很熟悉,從上面這句話并不能真正理解Redis操作是原子性的原因,進(jìn)一步查閱進(jìn)程與線程的概念及其區(qū)別。

進(jìn)程與線程


進(jìn)程


計(jì)算機(jī)中已執(zhí)行程序的實(shí)體?!揪S基百科】。比如,一個(gè)啟動(dòng)了的php-fpm,就是一個(gè)進(jìn)程。

線程


操作系統(tǒng)能夠進(jìn)行運(yùn)算調(diào)度的最小單元。它被包含在進(jìn)程之中,是進(jìn)程的實(shí)際運(yùn)作單位。一條線程指的是進(jìn)程中一個(gè)單一順序的控制流,一個(gè)進(jìn)程中可以并發(fā)多個(gè)線程,每條線程并行執(zhí)行不同的任務(wù)?!揪S基百科】。比如,mysql運(yùn)行時(shí),mysql啟動(dòng)后,該mysql服務(wù)就是一個(gè)進(jìn)程,而mysql的連接、查詢的操作,就是線程。

進(jìn)程與線程的區(qū)別

  • 資源(如打開文件):進(jìn)程間的資源相互獨(dú)立,同一進(jìn)程的各線程間共享資源。某進(jìn)程的線程在其他進(jìn)程不可見(jiàn)。

  • 通信:進(jìn)程間通信:消息傳遞、同步、共享內(nèi)存、遠(yuǎn)程過(guò)程調(diào)用、管道。線程間通信:直接讀寫進(jìn)程數(shù)據(jù)段(需要進(jìn)程同步和互斥手段的輔助,以保證數(shù)據(jù)的一致性)。

  • 調(diào)度和切換:線程上下文切換比進(jìn)程上下文切換要快得多。

線程,是操作系統(tǒng)最小的執(zhí)行單元,在單線程程序中,任務(wù)一個(gè)一個(gè)地做,必須做完一個(gè)任務(wù)后,才會(huì)去做另一個(gè)任務(wù)。

Redis在并發(fā)中的表現(xiàn)


Redis的API是原子性的操作,那么多個(gè)命令在并發(fā)中也是原子性的嗎?

看看下面這段代碼:

  $redis = new Redis();
  $redis->connect('127.0.0.1', 6379);
  for($i = 0; $i < 1000; $i++) {
      $num = (int) $redis->get('val');
      $num++;
      $redis->set('val', $num);
      usleep(10000);
  }

用兩個(gè)終端執(zhí)行上面的程序,發(fā)現(xiàn)val的結(jié)果是小于2000的值,那么可以知道,在程序中執(zhí)行多個(gè)Redis命令并非是原子性的,這也和普通數(shù)據(jù)庫(kù)的表現(xiàn)是一樣的。

如果想在上面的程序中實(shí)現(xiàn)原子性,可以將get和set改成單命令操作,比如incr,或者使用Redis的事務(wù),或者使用Redis+Lua的方式實(shí)現(xiàn)。

總結(jié)


綜上所述,對(duì)Redis來(lái)說(shuō),執(zhí)行g(shù)et、set以及eval等API,都是一個(gè)一個(gè)的任務(wù),這些任務(wù)都會(huì)由Redis的線程去負(fù)責(zé)執(zhí)行,任務(wù)要么執(zhí)行成功,要么執(zhí)行失敗,這就是Redis的命令是原子性的原因。

Redis本身提供的所有API都是原子操作,Redis中的事務(wù)其實(shí)是要保證批量操作的原子性。

上述就是小編為大家分享的如何在Redis數(shù)據(jù)庫(kù)實(shí)現(xiàn)API原子性了,如果剛好有類似的疑惑,不妨參照上述分析進(jìn)行理解。如果想知道更多相關(guān)知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。

新聞標(biāo)題:如何在Redis數(shù)據(jù)庫(kù)實(shí)現(xiàn)API原子性-創(chuàng)新互聯(lián)
轉(zhuǎn)載來(lái)于:http://m.newbst.com/article28/dcshjp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供小程序開發(fā)、網(wǎng)站排名網(wǎng)站建設(shè)、域名注冊(cè)、手機(jī)網(wǎng)站建設(shè)、軟件開發(fā)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

手機(jī)網(wǎng)站建設(shè)