比特币之Bloom过滤器

背景

比特币SPV节点因为不具有全链数据,所以无法对交易进行验证。必须要从核心客户端(具备全链数据的节点)下载特定的交易进行选择性验证。这样就产生了隐私风险。比如监控网络的第三方可以跟踪某个SPV节点上的钱包所请求的全部交易信息,并且利用这些交易信息可以把钱包用户和比特币地址关联起来,从而会导致失去匿名信。
鉴于此,比特币开发人员添加了新功能--Bloom过滤器,用以解决SPV隐私暴露风险问题。Bloom过滤器通过一个采样概率,运行SPV节点只接收交易信息的子集,同时不会精确泄露哪些是他们感兴趣的

Bloom过滤器

Bloom过滤器是一个允许用户描述特定关键词组合而不需要精确描述的基于概率的过滤方法。假如有个游客需要询问去某个特定地址的路线,如果他向陌生人问“联运街88号在哪里?”,这样他就会暴露自己的目的地。Bloom过滤器则会这样问:“附近有带联字的街道吗?”这样就暴露了很少的关键词。会得到更多的结果(包含自己需要的),保护了自己的隐私。

1. SPV节点会初始化一个不匹配任何关键词的空白Bloom过滤器。
2. SPV节点会创建一个包含钱包中所有地址信息的列表,并创建一个与每个地址相对应的交易输出相匹配的搜索模式。
3. SPV节点会将所有的搜索模式放入Bloom过滤器。这样只要关键词出现在交易中就可以被过滤器识别出来。
4. 对等节点用收到的Bloom过滤器来匹配传送至SPV节点的交易。

Bloom过滤器采用一个可变的二进制数组(N)和M个哈希函数组成。这些哈希函数的输出区间是[1, N],该值与二进制数组对应。且这些哈希函数必须为确定性函数(任何一个节点使用相同Bloom过滤器实现的哈希函数针对同样的输入最后输出的结果是一致的)。通过调节N和M来改变Bloom过滤器的准确性和私密性。
下面我们用一个16位的二进制数组和3个哈希函数来演示Bloom过滤器应用原理。

初始化Bloom过滤器.png

Bloom过滤器数组中每个初始值都是0。
将关键词依次通过每个哈希函数(此例中是3个)运算,输出M个在1到N之间的数。二进制数组相应的位就置为1,这就意味着Bloom过滤器记录下了某个关键词

输入关键词A.png

输入关键词B.png

注意:当Bloom过滤器增加关键词时,其中某个哈希函数的输出值对应的二进制数组值可能已经是1了,此时不改变二进制数组值。也就是说,随着更多的关键词指向某个二进制数组值,Bloom过滤器随着位1的增加而饱和,准确性就降低了。准确性依赖于关键字数量、二进制数组大小和哈希函数数量。更大的数组和更多的哈希函数会记录更多的关键词,会提高准确性;小的数组及有限的哈希函数只能记录有限的关键词从而降低准确性。
为了测试某个关键词能否通过Bloom过滤器验证,首先将关键词依次使用哈希函数运算,将运算完成的结果与二进制数组做比较。如果所有结果对应的位在二进制数组中都是1,那么这个关键词可能在Bloom过滤器中被记录了。如果所有结果对应的位有一位在二进制数组中为0,那么这个关键词肯定不在Bloom过滤器中被记录。
可能是.png

一定不是.png

参考

《精通比特币》6.8节

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,372评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,368评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,415评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,157评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,171评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,125评论 1 297
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,028评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,887评论 0 274
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,310评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,533评论 2 332
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,690评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,411评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,004评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,659评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,812评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,693评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,577评论 2 353