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

  免費注冊 查看新帖 |

Chinaunix

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

解決greenplum數(shù)據(jù)庫truncate table或drop table很慢的問題 [復(fù)制鏈接]

論壇徽章:
3
數(shù)據(jù)庫技術(shù)版塊每日發(fā)帖之星
日期:2015-06-18 22:20:00數(shù)據(jù)庫技術(shù)版塊每日發(fā)帖之星
日期:2015-06-21 22:20:00數(shù)據(jù)庫技術(shù)版塊每日發(fā)帖之星
日期:2015-08-27 06:20:00
跳轉(zhuǎn)到指定樓層
1 [收藏(0)] [報告]
發(fā)表于 2011-08-09 20:35 |只看該作者 |倒序瀏覽
問題描述:   

    在solaris10上使用greenplum3.3.6,當(dāng)數(shù)據(jù)文件很多的,truncate table和drop table很慢,常常這樣一個操作需要3分鐘到十幾分鐘。這個問題直到greenplum4.0都存在。

原因分析:

    對于PostgreSQL數(shù)據(jù)庫來說每個表都是由一個或幾個文件組成的,文件由一個數(shù)據(jù)組成,如名稱為:123468,文件大小不能超過一個設(shè)定值,目前是1G,如果表的內(nèi)容超過了1G,g內(nèi)容寫到下一個加了”.數(shù)字"的文件中,如123468.1,當(dāng)123468.1寫滿了,再放到123468.2文件中,依此類推。當(dāng)greenplum在truncate table或drop table時,會把表對應(yīng)的文件刪除,刪除的方式是,先刪除123468這個文件,然后遍歷這個目錄下的所有文件,看這個目錄下的每一個文件名前面是否是123468.n的格式(n為1,2,3...),如果是,再把這個文件刪除。隨著greenplum數(shù)據(jù)庫的變大,數(shù)據(jù)目錄下有幾十萬個文件甚至 到達(dá)百萬個文件,于是遍歷目錄就會很慢,這就是導(dǎo)致的greenplum3.3.X truncate table和drop table很慢的原因。

解決方法:

    與greenplum公司聯(lián)系過,他們說升級到greenplum4.1,這個問題就解決了,但由于一般的greenplum數(shù)據(jù)庫都比較大,而最新版本greenplum4.1還有一些bug,升級風(fēng)險很大。所以這個問題,于是只有自己想辦法解決這個問題。

    由于是遍歷目錄慢,能否讓系統(tǒng)跳過這個步驟。方法是,我寫一個動態(tài)庫fixgptrunc.so,這個動態(tài)庫重載列目錄的函數(shù)readdir_r,然后設(shè)置環(huán)境變量LD_PRELOAD_64:

export LD_PRELOAD_64=/home/gpadmin/fixgptrunc/fixgptrunc.so

    這樣當(dāng),postgres進(jìn)程起來時,當(dāng)調(diào)用遍歷目錄的函數(shù)readdir_r時,就會調(diào)用我寫的這個動態(tài)庫中的readdir_r函數(shù),而當(dāng)我的函數(shù) readdir_r,看到postgres是遍歷數(shù)據(jù)目錄時,就跳過。這樣這個性能問題就解決了。

這里大家可能有幾個疑問:


    1. 如果跳過了,那么那些帶后綴的123468.1、123468.2文件系統(tǒng)就不會刪除了,這怎么辦? 我的解決方法是,也重載unlink函數(shù),我的unlink在當(dāng)刪除123468文件時,就自動去把123468.1和123468.2這樣的文件都刪除 掉。

    2. 如果postgres進(jìn)程不是在做truncate table和drop table時,去調(diào)用readdir_r函數(shù)時,直接跳過,這樣是否會使用這些正常的需要調(diào)readdir_r的操作也會出現(xiàn)找不到文件的錯誤? 這個問題的解決方法是我的unlink函數(shù)會檢查調(diào)用unlink函數(shù)的父函數(shù)是否是mdunlink函數(shù),mdunlink函數(shù)是 PostgreSQL的一個刪除表文件的函數(shù),一般只會在做drop table或truncate table時才會調(diào)用mdunlink函數(shù),除此之外的正常調(diào)用,則不會調(diào)用這個mdunlink函數(shù),這樣就不會有這個問題了。如果父函數(shù)是 mdunlink,才跳過,否則按正常流程走。



程序使用方法:

   使用gmake生成fixgptrunc.so文件,

   然后把這個文件拷貝到master和各個segment結(jié)點,我測試的時候,放在/home/gpadmin/fixgptrunc/這個目錄下:

然后在.bashrc文件中增加環(huán)境變量:

export LD_PRELOAD_64=/home/gpadmin/fixgptrunc/fixgptrunc.so

export FIX_GP_TRUNC_DEBUG=1

   設(shè)置了環(huán)境變量FIX_GP_TRUNC_DEBUG=1,則會在/tmp文件目錄下生成一個log文件:fixgptrunc.log,便于調(diào) 試。

然后重啟greenplum后,再做truncate table或drop table就應(yīng)該很快了。

源代碼見我的blog:
http://blog.osdba.net/?post=56

論壇徽章:
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
2 [報告]
發(fā)表于 2011-08-10 10:51 |只看該作者
強(qiáng)啊,頂!

論壇徽章:
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榮譽(yù)版主
日期: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
3 [報告]
發(fā)表于 2011-08-10 22:03 |只看該作者
沒搞過這么高森的問題。

論壇徽章:
0
4 [報告]
發(fā)表于 2011-08-11 13:40 |只看該作者
數(shù)據(jù)庫很大,而且又是64位環(huán)境,1G明顯太小。最好改下RELSEG_SIZE,再重build

論壇徽章:
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榮譽(yù)版主
日期: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
5 [報告]
發(fā)表于 2011-08-23 12:01 |只看該作者
回復(fù) 4# zhanghb77


    說得有道理啊。
您需要登錄后才可以回帖 登錄 | 注冊

本版積分規(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