我们先理解传统的web或移动app如何与存储交互。每当用户登录到app时,app从远程存储器中获取用户数据并将其显示给用户。所有复杂的计算都运行在云服务器上,而不是客户端上,客户端充当一个简易的显示终端。
下面是两个虚构角色alice和bob与传统web/移动app交互的例子。
假设我们有两个用户alice和bob。他们都有 app:whatsapp,facebook 或者 snapshot。他们与app的提供者交互。这些app基本上运行sql或者其他数据库为用户提供服务。当alice想要使用即时通讯应用与bob交互时,alice将消息发送给服务提供者,而服务提供者将消息发送给bob。
例如,alice首先向存储服务器发送信息“hi”,然后存储服务器将信息发送给bob。交互路径是 alice→存储服务器→bob,alice←→bob之间没有直接路径。这是个中心化的过程,服务提供者代表alice和bob传递数据,并控制如何共享数据。alice和bob都是通过查询中新心服务器来查找彼此的消息。服务提供者总是信任的唯一来源。
中心化存储带来的问题
1.读取写入数据与用户身份标识没有严格关联。 不能保证bob收到的消息确实来自于alice,或者消息是篡改的。而且,这些大公司也并不是免费提供服务的。他们向广告商出售用户数据,从用户数据中牟利。这样,他们可以更好地锁定潜在客户。在某些情况下,他们的做法是违法的:德国一家法院本月刚刚裁定,facebook非法收集数据,违反了消费者相关的法律。
2. 用户不能选择不同的存储提供者 ,只有app才能选择存储器以及把用户数据保存在什么位置
3.用户无法控制谁查看他们的数据,存储器总是可以查看他们的数据
blockstack 如何解决中心化存储问题
以便使用户能够控制自己的数据,并严格地将自己的数据与用户身份标识关联起来。blockstack提供了去中心化存储系统(gaia)和区块链命名系统(blockchain naming system即bns)。用户可以使用bns提供的数字身份登录到blockstack app。用户数据将与用户公钥强关联。app将代表用户读写数据到gaia hub(当且仅当用户允许时)。所有用户数据将被传输到他们的gaia hub。gaia hub可以由用户自己拥有,也可以使用blockstack提供的默认存储空间。blockstack 在默认情况下,hub用于存储由用户的公钥加密的用户数据。这样,存储器只能看到加密好的数据块。
介绍 gaia
gaia是由完全由用户拥有的存储,用户决定谁能看到它,并将其写入存储。他们可以随时更改存储器。它是基于驱动程序模型构建的分布式高性能存储系统,支持许多存储服务。它是基于驱动程序模型构建的分布式高性能存储系统,支持许多存储服务。只需做很少的工作,开发人员就可以通过gaia为dropbox、azure、s3 实现存储。
gaia vs ipfs:gaia和ipfs的主要区别在于,gaia用户对他们的数据的控制权,但在ipfs中有一个开放的网络,你的数据被放置在不同的人的设备上。
blockstack app 如何存储数据以及用户如何控制自己的数据?
假设现在alice正在使用一个blockstack 消息app。她使用自己的gaia服务和她自己的公钥进行交互。bob有相同的app。alice和bob都想和对方交流。为了相互通信,alice 的 gaia服务和bob 的gaia服务之间必须有读/写路径。
问题出现了,blockstack app如何与gaia存储交互,以及gaia如何为用户提供全面控制?
用户和存储后端都定义了url。blockstack app定义了用户存储的url路径。它根据用户从不同的存储器进行读写,这种方式允许用户对数据的控制。查找路径允许用户控制和存储他们的数据。
blockstack app 如何在 gaia 中查找数据?
这个过程分 4 步:
1.在虚拟链中查找名称以获得(名称、散列)对
2.将用户名解析为数据(通过bns和atlas网络控制),以获得相应的区域文件
3.从zonefile中发现存储后端uri,并查找连接到存储后端的uri
4. 从gaia服务中获取数据
解释
app将给定的用户名解析为某些数据。假设我们有一个用户sidra.id。app将使用blockstack.js 程序库中的blockstack bns。atlas网络获取根文件(区域文件),这个文件定义很多关于名称的信息。它还将提供存储 app数据的url。
一旦app完成了对 app根文件 的查找。申请者将能够获得更具体的数据。假设想查找文件foo.json。然后,唯一的要求是执行一个正常的url获取。最后的设置是在gaia规范中定义的。
如何更改 gaia的储存器? 在系统中,如果用户想要更改正在运行的gaia储存器。因为用户拥有自己的用户名,所以他们可以很容易地将不同的数据与他们的用户名相关联,这允许他们选择不同的app路由。这最终允许他们更改app执行这些查找的方式。查找定义了数据的控制,只要用户能够控制数据的查找就控制了数据。
gaia 接口
gaia是一个存储后端,它提供了一个简单的接口。因此,app可以像普通的post、get和put请求工作一样进行读写。gaia定义了三种路径:
1. put/store/《public-key-hash》/《file-name》 通过app代表用户向gaia服务写入数据
2. get/store/《public-key-hash》/《file-name》从公钥哈希定义的用户中读取文件
写一个 gaia hub
blockstack app代表用户编写,例如,app调用put请求将一些数据提交到gaia服务,并提供和验证头,就像公钥签名文本一样。gaia服务将验证此app实际上被授权向用户gaia写入数据。
从 gaia 中读取数据
1. 获取zone文件和数据
2. 验证zonefile hash 是否匹配用户公钥
结论
gaia是blokckstack app的存储后端。它提供了用户拥有自己数据的能力,但是存储的数据仍然依赖于传统的dns服务和复杂的云存储。它还将大多数用户设备无法处理的计算负载强加给用户。对于去中心化的互联网来说,用户隐私还有很长的路要走。大多数用户还没有为这种变化做好准备。dapp需要对用户友好,并使其他人做的工作更少才能成功。
温度/气候记录仪的制作教程
光电液位开关用于高铁动车组卫生系统
中国工业互联网这一年走的怎么样
面向低时延工业以太网的Marvell PHY 产品
AirPods3最新消息 支持降噪并推出更多的配色
Blockstack是如何解决中心化存储问题的
成立“宜家智能家居”业务部门,与谷歌、亚马逊、苹果竞争
全面分析2018中国半导体产业状况
正视人工智能带来的艺术挑战
基于IPv6的、需要低功耗和远程无线连接的智能和互联物联网应用
LM1875功放电路原理图
测试应用快速扩大阵列持续推动SMUs仪器技术
坚果手机高清拆解图集
是什么推动了中国人工智能的发展
采用COMSOL Multiphysics软件对高灵敏度光纤压力传感器进行仿真
机器人换人带来的是什么
白光LED电荷泵背光驱动器ADP8870(ADI)
瑞士信贷:9至11月份iPhone在国内市场的总出货量同比下降7.4%
125KHz三通道低功耗唤醒接收器SI3933介绍
Keil为东芝TMPM330微控制器提供技术支持