青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

那誰的技術(shù)博客

感興趣領(lǐng)域:高性能服務(wù)器編程,存儲,算法,Linux內(nèi)核
隨筆 - 210, 文章 - 0, 評論 - 1183, 引用 - 0
數(shù)據(jù)加載中……

ccache0.6 版本發(fā)布

這個版本沒有太多的新特性,大部分為改進原有版本的問題,版本主要的工作包括:

version 0.6 (2009.10.22, base on svn reversion 85)
1) rename ccache_create and ccache_destroy to ccache_open and ccache_close
respectly
2) when open the cache, use ini style configure file to config the cache
3) rename the API ccache_replace to ccache_set
4) all the funcions's first param is cache
5) when open the cache, init the compare function pointer, so when use the
cache API does not need to specify the compare function  
6) add install/uninstall target in Makefile
7) use Bob Jenkins hash algorithm instead of the previous one.

項目地址在: commoncache
另外,項目的wiki頁面我新增了一些解釋commoncache實現(xiàn)和簡單的demo代碼。

另外,感謝 helloghui提出代碼中的一個BUG。






posted on 2009-10-22 20:51 那誰 閱讀(4563) 評論(8)  編輯 收藏 引用 所屬分類: ccache

評論

# re: ccache0.6 版本發(fā)布  回復(fù)  更多評論   

converse你好,看了一些ccache源碼,感謝你的開源項目。我有幾個問題(因為并沒有看到方方面面,所以也不算特別肯定,抱歉):
1、ccache使用mmap映射文件到內(nèi)存,除了持久存儲,應(yīng)該就是為了使不相關(guān)進程能訪問同一cache,但存儲里卻用了指針(ccache_t里,prev,next等等),也就是地址,而地址是僅僅只對初始化它們(init)的進程才有意義的,因為并不能保證文件會被不同進程映射到它們相同的邏輯地址。所以我覺得項目里mmap、文件的初衷達不到,也就是只有單進程能訪問cache,而且程序重啟reload file不可用。我個人覺得所有需要存儲的指針(地址)都應(yīng)該改為偏移量(off_t);
2、項目只使用了一個rwlock,也就是鎖粒度是整個cache級的,我覺得這個是不能接受的,一旦有寫鎖加上,整個cache都無法訪問。cache應(yīng)用中會有大量的讀操作(多進程,多線程),也會有一定量的寫操作,讀操作應(yīng)該盡量不被堵塞。建議讀寫鎖粒度可以細化到hashitem級。另外我看里面除了visit其他全部都是加的寫鎖,包括find,具體代碼我沒細看,可能你有一些值需要更新,但是我覺得原則上find操作應(yīng)該加讀鎖;
3、對unfix的支持好像是freearea通過多級fix(alignsiz)實現(xiàn)的?這個我沒細看,沒太多發(fā)言權(quán)。因為當(dāng)時追蹤看到了,有些奇怪,提一下。我覺得這里就是一個類似malloc包的內(nèi)存管理,malloc包也會有小的塊這樣的概念,但和你這個好像并不是相同的用意。
2010-05-04 23:13 | ping

# re: ccache0.6 版本發(fā)布  回復(fù)  更多評論   

@ping
1.第一點我沒太看明白,我的測試用例就是使用多進程去進行壓力測試的,好像還沒有發(fā)現(xiàn)問題.
2.這一點我也比較頭疼,但是目前沒有找到降低鎖粒度的辦法.find操作要加寫鎖,是因為根據(jù)LRU算法,每次訪問過的節(jié)點,需要往鏈表頭走一步,所以也有更新的操作.這樣,經(jīng)常被find的元素,就會越靠近鏈表頭.
3.是的,這個算法類似STL中內(nèi)存池的設(shè)計.
2010-05-04 23:30 | 那誰

# re: ccache0.6 版本發(fā)布  回復(fù)  更多評論   

@那誰
第一點可能我省字沒說明白,我的意思是這樣:
既然ccache使用了mmap和文件,那它肯定應(yīng)該能支持:1、一個程序啟動,往里面insert一些數(shù)據(jù),程序關(guān)閉;程序再次啟動,load上次的文件,這時它應(yīng)該是能讀取上次寫入的那些數(shù)據(jù)的;2、不相干的進程使用ccache,指定相同的文件,那它們應(yīng)該是能通信的,彼此的更新都能看到,而且也能同步訪問(rwlock)。不然你的ccache只能給一個進程或父子之類的相關(guān)進程訪問,這顯然意義不大。我想上面兩點也應(yīng)該是你使用mmap和文件的初衷。
而你想要不同的進程、不相干的進程都能理解你的文件結(jié)構(gòu)的話,只能使用偏移量,不能使用指針。比如你創(chuàng)建cache的進程(配置init=1)mmap返回的地址為A,里面的某個指針freearea指向的地方相對于它(ccache_t )的偏移量為X,然后freearea這個指針的值就為A+x,它被保存在文件里了,另一個不相干的進程(配置init=0)把它mmap到自己的進程空間,它的mmap返回值為B,而不是A,而這時你用freearea這個指針的值(A+x)去訪問你的空閑區(qū)顯然就出錯了(應(yīng)該是B+x)。所以我說在文件(以及共享內(nèi)存)不能使用指針、只能使用偏移量,是這個意思。
你的test/目錄下那個多進程insert的代碼我看了,因為是父子進程繼承mmap的關(guān)系,所以不會出錯,因為這種繼承關(guān)系本身就保證了mmap值的想同。
前面這些是基于對你的mmap作用、init作用的大概判斷的基礎(chǔ)上說的,希望沒有理解錯,以致浪費你的時間。
下面是一個會出問題的例子代碼:
#define WCF "../conf/fix_cache.conf.w"
#define RCF "../conf/fix_cache.conf.r"

void ccget()
{
int i,len;
char str[9];
ccache_data_t data;
ccache_t *cache = ccache_open(RCF,NULL);
assert(cache);

for(i = 1;i <= 1000000;i++)
{
len = sprintf(str,"%08d",i);

//data.data = (void *)&str;
//data.datasize = len;
data.key = (void *)&str;
data.keysize = len;

if(ccache_find(cache,&data) != 0)
{
printf("find FAIL\n");
break;
}
else printf("%s\t%s\n",(char *)data.key,(char *)data.data);
}
}
void ccset()
{
int i,len;
char str[9];
ccache_data_t data;
ccache_t *cache = ccache_open(WCF,NULL);
assert(cache);

for(i = 1;i <= 1000000;i++)
{
len = sprintf(str,"%08d",i);

data.data = (void *)&str;
data.datasize = len;
data.key = (void *)&str;
data.keysize = len;

if(ccache_insert(cache,&data,NULL,NULL) != 0)
{
printf("insert FAIL\n");
break;
}
}
}
int main(int argc,char **argv)
{
if(!strcmp(argv[1],"set")) ccset();
else if(!strcmp(argv[1],"get")) ccget();
}

其中fix_cache.conf.w就是你的fix_cache.conf文件,fix_cache.conf.r則是把它里面的init=1改為init=0,其它不變。
我用它來模仿不相干進程,先寫數(shù)據(jù):
./cctest set
然后再打開文件讀數(shù)據(jù):
./cctest get
我測了兩次,一次段錯誤,一次get FAIL.

如果是我對init的使用理解有誤,對耽誤你的時間表示歉意。
2010-05-06 00:02 | ping

# re: ccache0.6 版本發(fā)布  回復(fù)  更多評論   

@ping
你說的沒錯,之前這個問題一直沒有發(fā)現(xiàn),是因為我之前寫的服務(wù)器程序都是父子進程的模式,能否給我留一個聯(lián)系方式,我將在下一次修正這個BUG的時候在changelog中加入你的信息,謝謝.你可以在私人留言中給我留下聯(lián)系方式.



2010-05-06 00:39 | 那誰

# re: ccache0.6 版本發(fā)布  回復(fù)  更多評論   

@那誰
呵呵,不用。之前我有看過你在CU上寫的lighttpd源碼分析學(xué)習(xí)lighttpd,收獲很多,這次看ccache的代碼也學(xué)到了一些東西,尊敬你開源和共享的精神,這次能有所幫助已經(jīng)很高興了。技術(shù)范圍內(nèi)的討論大家都有收獲就好,簡簡單單,你不用特意的感謝。
2010-05-06 09:16 | ping

# re: ccache0.6 版本發(fā)布  回復(fù)  更多評論   

有幾個問題想問問博主,感謝博主有空解答。

1。是否支持重復(fù)索引數(shù)據(jù)。
2。數(shù)據(jù)被刪除后空間是否真的被釋放。
3。能否支持按照表的方式管理。
4。可否考慮使用文件鎖的方式實現(xiàn)?
2010-08-19 20:28 | njmpop@sina.com.cn

# re: ccache0.6 版本發(fā)布  回復(fù)  更多評論   

converse,你好,你的程序我在mingw下編譯,發(fā)現(xiàn)編譯不過,找不到sys/mman.h這個頭文件,請問我怎么解決這個問題?
2010-08-26 17:57 | messi

# re: ccache0.6 版本發(fā)布  回復(fù)  更多評論   

很久不更新版本了,封板了。
2012-05-25 16:50 | wxh
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            久久精品一区四区| 久久精品亚洲国产奇米99| 欧美精品成人| 99热免费精品在线观看| 午夜在线电影亚洲一区| 国产一区久久久| 噜噜噜91成人网| 99国内精品| 久久精品视频亚洲| 亚洲日本精品国产第一区| 欧美日本精品在线| 亚洲欧美在线aaa| 欧美超级免费视 在线| 一区二区av在线| 国产日韩亚洲| 欧美高清在线视频| 性色av一区二区怡红| 欧美激情一区二区三区在线视频观看| 一本色道久久99精品综合| 国产午夜亚洲精品理论片色戒| 久热成人在线视频| 在线中文字幕一区| 欧美a级大片| 午夜精品久久久| 亚洲精品裸体| 国产一区视频观看| 欧美特黄一级大片| 另类激情亚洲| 午夜精品福利在线观看| 亚洲二区免费| 久久精品久久99精品久久| 99精品国产福利在线观看免费 | 日韩午夜免费| 久久久999成人| 一区二区三区鲁丝不卡| 狠狠色丁香婷婷综合久久片| 欧美日韩国产不卡在线看| 欧美在线短视频| 一区二区三区视频观看| 欧美国产极速在线| 久久天天躁狠狠躁夜夜av| 亚洲综合色网站| 在线亚洲美日韩| 亚洲三级免费电影| 一色屋精品视频在线观看网站| 国产精品毛片va一区二区三区 | 亚洲高清视频中文字幕| 欧美资源在线观看| 亚洲一区二区三区在线播放| 亚洲精品极品| 91久久精品视频| 永久555www成人免费| 国产一级一区二区| 国产伦精品一区| 国产精品久久波多野结衣| 欧美精品免费看| 欧美精品一区二区三区蜜桃| 美国十次了思思久久精品导航| 欧美亚洲一区二区在线观看| 亚洲免费伊人电影在线观看av| 日韩写真视频在线观看| 亚洲精品久久嫩草网站秘色| 欧美福利影院| 亚洲成色www8888| 欧美好吊妞视频| 亚洲国产综合在线看不卡| 欧美激情视频一区二区三区不卡| 欧美777四色影视在线| 免费不卡在线观看| 欧美不卡视频| 亚洲二区免费| 亚洲精一区二区三区| 91久久久久| 一区二区久久久久久| 一区二区精品在线| 亚洲女人天堂av| 久久大综合网| 久久久综合网站| 免费日韩视频| 欧美精品成人91久久久久久久| 欧美精品成人一区二区在线观看| 欧美片在线播放| 国产精品国产三级国产普通话99| 国产精品久久久久久亚洲调教| 国产伦一区二区三区色一情| 韩国福利一区| 亚洲日本中文字幕| 亚洲影院高清在线| 久久久久久久999精品视频| 欧美成人在线影院| 亚洲乱码精品一二三四区日韩在线| 夜久久久久久| 欧美一区不卡| 欧美成人一区二区| 国产精品免费一区二区三区观看 | 欧美xx视频| 亚洲破处大片| 亚洲一区视频在线观看视频| 久久国内精品自在自线400部| 久久综合激情| 欧美午夜电影在线观看| 国产一区二区三区精品久久久| 在线观看久久av| 一区二区国产日产| 久久久久久成人| 亚洲国产三级网| 性欧美video另类hd性玩具| 久久综合中文字幕| 国产精品乱码一区二区三区| 伊人成人在线| 亚洲欧美影院| 欧美激情亚洲激情| 亚洲欧美日韩一区二区三区在线观看 | 亚洲一区免费网站| 久久伊人精品天天| 国产精品理论片| 亚洲区一区二| 久久久91精品国产| 亚洲精品网址在线观看| 久久不见久久见免费视频1| 欧美激情综合| 国内外成人免费激情在线视频| 99伊人成综合| 免费视频一区| 欧美一区二区三区婷婷月色| 欧美日韩精选| 91久久国产综合久久91精品网站| 欧美中文在线观看国产| 91久久精品国产91久久| 久久精品成人一区二区三区| 国产精品xvideos88| 亚洲精品久久久久久久久| 久久久久久九九九九| 亚洲天堂免费在线观看视频| 欧美激情精品久久久久久大尺度 | 欧美一区永久视频免费观看| 亚洲人屁股眼子交8| 久久综合激情| 国内精品美女在线观看| 香蕉久久夜色精品国产| 亚洲伦理自拍| 欧美成人精品一区| 亚洲国产成人av| 免费欧美电影| 久久国产精品久久国产精品| 国产九九精品| 亚洲欧美中文字幕| 中文日韩欧美| 欧美性大战xxxxx久久久| 99国产精品久久久久久久| 欧美激情精品久久久久久变态| 久久久人成影片一区二区三区观看| 国产欧美短视频| 午夜亚洲影视| 亚洲欧美久久久| 国产精品综合| 欧美怡红院视频| 销魂美女一区二区三区视频在线| 国产精品一区二区男女羞羞无遮挡 | 国产目拍亚洲精品99久久精品| 亚洲一区二区视频在线| 亚洲精品国产系列| 欧美三级韩国三级日本三斤| 在线亚洲精品| 亚洲小视频在线| 国产精品影视天天线| 午夜亚洲精品| 香蕉久久夜色精品国产| 国模精品一区二区三区色天香| 久久国产精品色婷婷| 久久精品观看| 亚洲成人直播| 亚洲激情视频网站| 欧美日韩国产精品一区二区亚洲 | 久久国产精品亚洲va麻豆| 韩国欧美一区| 欧美大片一区二区| 欧美国产大片| 午夜精品福利一区二区蜜股av| 亚洲欧美另类在线观看| 狠狠色香婷婷久久亚洲精品| 久久综合五月天婷婷伊人| 狼人社综合社区| 一区二区电影免费观看| 国产精品99久久久久久久久| 国产欧美日韩亚洲一区二区三区 | 亚洲区一区二区三区| 欧美亚男人的天堂| 久久婷婷久久一区二区三区| 欧美不卡视频| 性做久久久久久久久| 久久久久久国产精品mv| 亚洲精品中文在线| 亚洲一二三区在线| 狠狠色综合日日| 日韩午夜一区| 激情综合中文娱乐网| 一本久道久久综合婷婷鲸鱼| 国产亚洲成av人片在线观看桃| 亚洲高清免费在线|