這篇文章主要介紹了memcache一致性hash的php實現方法,實例分析了memcache中hash一致性的實現原理與相關技巧,需要的朋友可以參考下
本文實例講述了memcache一致性hash的php實現方法。分享給大家供大家參考。具體如下:
最近在看一些分布式方面的文章,所以就用php實現一致性hash來練練手,以前一般用的是最原始的hash取模做 分布式,當生產過程中添加或刪除一臺memcache都會造成數據的全部失效,一致性hash就是為了解決這個問題,把失效數據降到最低,相關資料可以 google一下!
php實現效率有一定的缺失,如果要高效率,還是寫擴展比較好
經測試,5個memcache,每個memcache生成100個虛擬節點,set加get1000次,與單個memcache直接set加get慢5倍,所以效率一般,有待優化!
在閱讀本文之前,最好知道二分查找法。
實現過程:
memcache的配置 ip+端口+虛擬節點序列號 做hash,使用的是crc32,形成一個閉環。
對要操作的key進行crc32
二分法在虛擬節點環中查找最近的一個虛擬節點
從虛擬節點中提取真實的memcache ip和端口,做單例連接
希望本文所述對大家的php程序設計有所幫助。
新聞熱點
疑難解答