中文字幕日韩精品一区二区免费_精品一区二区三区国产精品无卡在_国精品无码专区一区二区三区_国产αv三级中文在线

postgresql鎖住的簡單介紹

postgres怎么在線創(chuàng)建索引

我們知道數(shù)據(jù)庫創(chuàng)建索引可能會鎖住創(chuàng)建索引的表,并且用該表上的一次掃描來執(zhí)行整個索引的構(gòu)建,這樣在創(chuàng)建索引時會影響在線業(yè)務,非常大的表創(chuàng)建索引可能會需要幾個小時,這樣阻塞業(yè)務是不被允許的。商業(yè)數(shù)據(jù)庫一般都提供在線創(chuàng)建索引的能力,PostgreSQL作為開源數(shù)據(jù)庫,也提供了這樣的功能。我們在CREATE INDEX命令中新增CONCURRENTLY選項來實現(xiàn)索引的在線創(chuàng)建。? ? ?但是concurrently在線創(chuàng)建索引也并不是那么完美,當使用這個選項時,PostgreSQL必須執(zhí)行該表的兩次掃描,此外它必須等待所有現(xiàn)有可能會修改或者使用該索引的事務終止,甚至它可能會等待一個不相干的事務終止。因此這種方法比起普通的索引創(chuàng)建過程來說要做更多工作并且需要更多時間。同時,索引的創(chuàng)建會帶來較大的CPU和I/O消耗。甚至在極端情況下,如果數(shù)據(jù)庫存在長事務,我們發(fā)現(xiàn)create index命令根本無法結(jié)束。? ? ?從官方文檔中我們可以了解到如下信息,在并發(fā)(concurrently)索引構(gòu)建中,索引實際上是在事務中被構(gòu)建的,它在兩個事務中發(fā)生兩次表掃描。在每一次表掃描之前,索引構(gòu)建必須等待對該表做過修改的現(xiàn)有事務終止。在第二次掃描之后,索引構(gòu)建必須等待任何持有早于第二次掃描的快照的事務終止。然后該索引最終能被標記為可用,CREATE INDEX命令完成。

公司主營業(yè)務:成都網(wǎng)站建設、做網(wǎng)站、移動網(wǎng)站開發(fā)等業(yè)務。幫助企業(yè)客戶真正實現(xiàn)互聯(lián)網(wǎng)宣傳,提高企業(yè)的競爭能力。創(chuàng)新互聯(lián)建站是一支青春激揚、勤奮敬業(yè)、活力青春激揚、勤奮敬業(yè)、活力澎湃、和諧高效的團隊。公司秉承以“開放、自由、嚴謹、自律”為核心的企業(yè)文化,感謝他們對我們的高要求,感謝他們從不同領(lǐng)域給我們帶來的挑戰(zhàn),讓我們激情的團隊有機會用頭腦與智慧不斷的給客戶帶來驚喜。創(chuàng)新互聯(lián)建站推出奉新免費做網(wǎng)站回饋大家。

開啟第一個事務,拿到當前快照snapshot

2.等待所有修改過該表的事務結(jié)束

3.掃描該表,第一次創(chuàng)建索引

4.結(jié)束第一個事務

5.開啟第二個事務,拿到當前快照snapshot2

6.等待所有修改過該表的事務結(jié)束

7.第二次掃描該表,將兩次快照之間變更的記錄,合并到索引

8.上一步更新索引結(jié)束后,等待snapshot2之前開啟的所有事務結(jié)束

9.結(jié)束索引創(chuàng)建,索引變?yōu)榭捎? ? ?那么這里有個疑問,為什么需要兩次掃描、兩次創(chuàng)建索引?其實想想也很好解釋。因為在第一次創(chuàng)建索引的時候不阻塞讀寫,這段時間內(nèi)發(fā)生的變更需要在第二次掃描的時候合并更新進索引。

postgresql怎么解鎖表

--查詢是否鎖表了

1、select oid from pg_class where relname='可能被鎖掉的表的表名'

,會顯示一個oid

2、select pid from pg_locks where relation='剛剛查出來的oid'

--如果查詢到了結(jié)果(pid),表示該表被鎖 則需要釋放鎖定

select pg_cancel_backend(上面查到的pid)

為什么使用postgresql skip locked加鎖失敗

是因為同時更新事物失誤。

通常在數(shù)據(jù)庫中最小粒度的鎖是行鎖,當一個事務正在更新某條記錄時,另一個事務如果要更新同一條記錄(或者申請這一條記錄的鎖),則必須等待鎖釋放。

通常持鎖的時間需要保持到事務結(jié)束,也就是說,如果一個長事務持有了某條記錄的鎖,其他會話要持有這條記錄的鎖,可能要等很久。

PostgresQL建立索引如何避免寫數(shù)據(jù)鎖定

問題源自一個帥哥在建索引發(fā)生表鎖的問題。先介紹一下Postgresql的建索引語法: Version:9.1 CREATE [ UNIQUE ] INDEX [ CONCURRENTLY ] [ name ] ON table [ USING method ] ( { column | ( expression ) } [ COLLATE collation ] [ opclass ] [ ASC | DESC ] [ NULLS { FIRST | LAST } ] [, ...] ) [ WITH ( storage_parameter = value [, ... ] ) ] [ TABLESPACE tablespace ] [ WHERE predicate ] 這里不解釋語法的諸多參數(shù)使用(排序,使用方法,填充因子等),主要說一下concurrently的使用場景。 正常情況下Postgresql建立普通btree索引時會阻塞DML(insert,update,delete)操作,直到索引完成,期間讀操作不受阻塞。當只有一個用戶操作這當然沒問題,但是在生產(chǎn)環(huán)境,并發(fā)比較高的情況下,特別是大表建索引就不能這么操作了,不然用戶要跳起來罵娘了,點個按鈕一天還沒反應過來。--使用 Postgresql提供了一個參數(shù),可以在線建立索引的時候避免因?qū)憯?shù)據(jù)而鎖表,這個參數(shù)叫concurrently。使用很簡單,就是用create index concurrently來代替create index即可。--副作用 當然了,使用這個參數(shù)是有副作用的,不使用這個參數(shù)建索引時DB只掃描一次表,使用這個參數(shù)時,會引發(fā)DB掃兩次表,同時等待所有潛在會讀到該索引的事務結(jié)束,這么一來,系統(tǒng)的CPU和IO,內(nèi)存等會受一點影響,所以綜合考慮,仍然讓用戶自行選擇,而不是默認。--失敗 在使用concurrently參數(shù)建索引時,有可能會遇到失敗的情況,比如建唯一索引索引發(fā)現(xiàn)數(shù)據(jù)有重復,又或者用戶發(fā)現(xiàn)建索引時建錯字段的,取消建索引操作了。此時該表上會存在一個索引,這是因為帶這個參數(shù)的建索引命令一經(jīng)發(fā)出,就首先會在系統(tǒng)的日志表里先插一個索引記錄進去,又因為這個索引最終建失敗了,所以會被標記一個INVALID的狀態(tài),如下: postgres=# \d t_kenyon Table public.t_kenyon Column | Type | Modifiers --------+---------+----------- col | integer |Indexes:idx btree (col) INVALID--重建 遇到上述失效的索引重建時兩個辦法,一個是drop index index_name,然后再執(zhí)行create index concurrently。還有一個是執(zhí)行reindex index_name命令,但是后者不支持concurrent參數(shù)。--總結(jié)

文章題目:postgresql鎖住的簡單介紹
標題網(wǎng)址:http://m.rwnh.cn/article10/dscdcgo.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供營銷型網(wǎng)站建設手機網(wǎng)站建設、微信小程序、ChatGPT、標簽優(yōu)化

廣告

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

成都定制網(wǎng)站網(wǎng)頁設計
溧阳市| 稻城县| 钦州市| 黎城县| 灌云县| 新建县| 南投市| 东乡族自治县| 津南区| 四平市| 永泰县| 汶上县| 静海县| 长春市| 怀安县| 江永县| 永兴县| 饶平县| 攀枝花市| 本溪| 盈江县| 永吉县| 富源县| 怀化市| 湘西| 麻栗坡县| 彝良县| 磐石市| 长顺县| 镇雄县| 柘城县| 北京市| 临夏市| 利津县| 象州县| 遵义市| 商洛市| 遂昌县| 巧家县| 满洲里市| 改则县|