亚洲av成人无遮挡网站在线观看,少妇性bbb搡bbb爽爽爽,亚洲av日韩精品久久久久久,兔费看少妇性l交大片免费,无码少妇一区二区三区

  免費注冊 查看新帖 |

Chinaunix

  平臺 論壇 博客 文庫
最近訪問板塊 發(fā)新帖
查看: 5343 | 回復(fù): 3
打印 上一主題 下一主題

PostgreSQL鎖機制 [復(fù)制鏈接]

論壇徽章:
0
跳轉(zhuǎn)到指定樓層
1 [收藏(0)] [報告]
發(fā)表于 2010-12-13 09:46 |只看該作者 |倒序瀏覽
PostgreSQL鎖機制

閆華 postgres_fan@yahoo.com.cn

4鎖機制
PostgreSQL內(nèi)部有三種類型的鎖,分別是自旋鎖(spin lock)、輕量級鎖(Lightweight lock)和常規(guī)鎖(regular lock)。自旋鎖和輕量級鎖用來保護(hù)數(shù)據(jù)庫內(nèi)部的數(shù)據(jù)結(jié)構(gòu),常規(guī)鎖用來保護(hù)數(shù)據(jù)庫對象,相當(dāng)于其他的數(shù)據(jù)庫中的表級鎖和行級鎖。自旋鎖和輕量級鎖沒有死鎖檢測機制,常規(guī)鎖有死鎖檢測機制。
4.1自旋鎖
自旋鎖只有一種模式(互斥模式)。一個數(shù)據(jù)庫進(jìn)程持有自旋鎖的時間應(yīng)該非常短。
在使用自旋鎖以前,應(yīng)當(dāng)使用宏S_INIT_LOCK(lock)初始化自旋鎖,使用宏S_LOCK(lock)得到自旋鎖,使用宏S_UNLOCK(lock)釋放自旋鎖。這三個宏在include/storage/spin.h中定義:

#define SpinLockInit(lock)        S_INIT_LOCK(lock)

#define SpinLockAcquire(lock) S_LOCK(lock)

#define SpinLockRelease(lock) S_UNLOCK(lock)

#define SpinLockFree(lock)        S_LOCK_FREE(lock)


為提高執(zhí)行的效率,得到自旋鎖的核心步驟test and set操作采用匯編語言實現(xiàn),所以在不同平臺上的實現(xiàn)代碼是不一樣的,X86平臺上的test and set操作的實現(xiàn)代碼如下,位于include/storage/s_lock.h文件中:

tas(volatile slock_t *lock)
{
        register slock_t _res = 1;

        /*
         * Use a non-locking test before asserting the bus lock.  Note that the
         * extra test appears to be a small loss on some x86 platforms and a small
         * win on others; it's by no means clear that we should keep it.
         */
        __asm__ __volatile__(
                "        cmpb        $0,%1        \n"
                "        jne                1f                \n"
                "        lock                        \n"
                "        xchgb        %0,%1        \n"
                "1: \n"
:                "+q"(_res), "+m"(*lock)
:
:                "memory", "cc");
        return (int) _res;
}

論壇徽章:
59
2015七夕節(jié)徽章
日期:2015-08-24 11:17:25ChinaUnix專家徽章
日期:2015-07-20 09:19:30每周論壇發(fā)貼之星
日期:2015-07-20 09:19:42ChinaUnix元老
日期:2015-07-20 11:04:38榮譽版主
日期:2015-07-20 11:05:19巳蛇
日期:2015-07-20 11:05:26CU十二周年紀(jì)念徽章
日期:2015-07-20 11:05:27IT運維版塊每日發(fā)帖之星
日期:2015-07-20 11:05:34操作系統(tǒng)版塊每日發(fā)帖之星
日期:2015-07-20 11:05:36程序設(shè)計版塊每日發(fā)帖之星
日期:2015-07-20 11:05:40數(shù)據(jù)庫技術(shù)版塊每日發(fā)帖之星
日期:2015-07-20 11:05:432015年辭舊歲徽章
日期:2015-07-20 11:05:44
2 [報告]
發(fā)表于 2010-12-13 10:25 |只看該作者
源碼解讀啊。我不會C。C太高深了。

論壇徽章:
4
丑牛
日期:2014-09-15 09:28:12雙子座
日期:2014-12-19 17:01:192015年辭舊歲徽章
日期:2015-03-03 16:54:15數(shù)據(jù)庫技術(shù)版塊每日發(fā)帖之星
日期:2016-06-28 06:20:00
3 [報告]
發(fā)表于 2010-12-13 10:39 |只看該作者
我只了解文檔里的鎖幾種情況,源碼不會。

論壇徽章:
0
4 [報告]
發(fā)表于 2011-01-14 09:16 |只看該作者
您需要登錄后才可以回帖 登錄 | 注冊

本版積分規(guī)則 發(fā)表回復(fù)

  

北京盛拓優(yōu)訊信息技術(shù)有限公司. 版權(quán)所有 京ICP備16024965號-6 北京市公安局海淀分局網(wǎng)監(jiān)中心備案編號:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年舉報專區(qū)
中國互聯(lián)網(wǎng)協(xié)會會員  聯(lián)系我們:huangweiwei@itpub.net
感謝所有關(guān)心和支持過ChinaUnix的朋友們 轉(zhuǎn)載本站內(nèi)容請注明原作者名及出處

清除 Cookies - ChinaUnix - Archiver - WAP - TOP