IPFS扫盲

时间:2023-01-05 13:44:11

第二届深圳区块链技术与应用大会暨展览会,深圳区块链存储与IPFS技术应用大会暨展览会于2019年4月9日在深圳会展中心6号馆举行。那么这个IPFS是什么?和区块链有什么关系?有什么用?又怎么用呢?接下来小编会为您详细解析。

目录

什么是IPFS
  简单地说
  枯燥地说
  有啥用
原理是什么
  八层协议栈
  IFPS的理想
操作
  编译
  安装启动
  基本操作
  对接RESTful
实例
  部署个人博客
  做电商网站
  FileCoin
  疑问与解决方案
  有价值的参考资料

什么是IPFS

简单地说

IPFS = Bittorrent + git + SFS + BITSWAP

枯燥地说

IPFS(The InterPlanetary File System,星际文件系统), 是一个面向全球的、点对点的分布式版本文件系统,目标是为了补充(甚至是取代)目前统治互联网的超文本传输协议(HTTP),将所有具有相同文件系统的计算设备连接在一起。
      原理用基于内容的地址替代基于域名的地址,也就是用户寻找的不是某个地址而是储存在某个地方的内容,不需要验证发送者的身份,而只需要验证内容的哈希,通过这样可以让网页的速度更快、更安全、更健壮、更持久。

有啥用

1.私人网盘(可以随时随地像访问本地存储一样,访问家里电脑里存的文件)
2.迷你CDN(类似百度金矿,让普通人可以把自家的带宽像商品一样出售给别人)
3.文件共享(知道BitTorrent么,IPFS不但可以共享文件还能共享目录)
4.版本管理(此功能和Web结合起来,以后很难再见到404了)
5.虚拟机的根目录(想想你把一个操作系统装到IPFS上)
6.分布式文件系统(把家里磁盘的使用权像产品一样出售给别人)
7.数据安全(这是去中心化的天赋,想要入侵数据库就要攻击所有人)
8.取代HTTP(基于内容寻址,网络利用率高)
。。。

原理是什么

IPFS扫盲

八层协议栈

  • 网络:传输层(WebRTC)、可靠性(uTP或SCTP)、可连接性(ICE)、完整性、可验证性

  • 路由:DSHT,用于确定同伴或内容的地址,简单说可以让你知道到那个节点去找那个文件;

  • 块交换:Bittorrent+Bitswap, 节点必须以块的形式彼此提供直接的值

IPFS扫盲

  • 对象:Merkle DAG, 路径、本地对象、对象锁定、发布对象、对象加密级别

  • 文件:Blok、List、Tree、Commit、文件系统路径、将文件分隔成LISTS和BLOBS

  • 命名:IPNS、DAG命名可变、人类友好名称,IPFS一问世就有很多人疯狂地去IPFS上注册域名,这就归功于此。

IFPS的理想

IPFS的思想是几十年成功的分布式系统的探索和开源的产物。IPFS综合了很多迄今为止很成功的系统中优秀的思想。除了BitSwap新协议之外,IPFS最大的特色就是系统的耦合以及设计的综合性。

  • IPFS是去中心化网络基础设施的一个野心设想,很多不同类型的应用都可以建立在IPFS上。
  • 最低限度,它可以用来作为一个全局的,挂载性,版本控制文件系统和命名空间,或者作为下一代的文件共享系统。
  • 而最好的情况是,IPFS可以让Web升级一个层次,当发布一个有价值的信息时,任何感兴趣的人都可以进行发布而不会强迫性的必须只允许发布机构进行发布,用户可以信任信息的内容,信不信任信息的发送者都是无关紧要的,还有一个特点就是,一些重要但很老的文件也不会丢失。
  • IPFS期待着带我们进入到一个Permanent Web的世界。

操作

编译

以Ubuntu为例

$ go get -u -d github.com/ipfs/go-ipfs
$ cd $GOPATH/src/github.com/ipfs/go-ipfs
$ make install

安装启动

$ ipfs init
$ ipfs daemon &

基本操作

# 添加文件
$ ipfs add a.txt
# QmQ4gV6RzpxURqBKypm981uDDKmPy3Q2hzcJAKFy4ug6PS是add之后生成的
$ ipfs cat QmQ4gV6RzpxURqBKypm981uDDKmPy3Q2hzcJAKFy4ug6PS
aaaaaaaaaaaaaa
# 创建文件夹并复制文件
$ ipfs files mkdir libai
$ ipfs files cp /ipfs/QmQ4gV6RzpxURqBKypm981uDDKmPy3Q2hzcJAKFy4ug6PS /libai/file.txt
# 浏览刚复制过去的文件
$ ipfs files ls /libai
# 将IPFS中的文件取到本地
$ ipfs get /ipfs/QmQ4gV6RzpxURqBKypm981uDDKmPy3Q2hzcJAKFy4ug6PS -o ./

用https的方式浏览我们刚才上传的文件

IPFS扫盲

对接RESTful

API的官方文档:https://ipfs.io/docs/api/
对接API的js开源代码:https://github.com/ipfs/js-ipfs
具体操作步骤如下:

  • 编辑ipfs的config文件:将127.0.0.1换成0.0.0.0
  • 添加跨域共享
ipfs config --json API.HTTPHeaders.Access-Control-Allow-Methods '["PUT", "GET", "POST", "OPTIONS"]'
ipfs config --json API.HTTPHeaders.Access-Control-Allow-Origin '["*"]'
  • 访问IPFS的管理页面:http://[NodeIP]:5001/webui
  • 添加文件(路径前一定要加”@”符号)
curl -F file=@myfile “http://localhost:5001/api/v0/add?recursive=false&quiet=<value>&quieter=<value>&silent=<value>&progress=<value>&trickle=<value>&only-hash=<value>&wrap-with-directory=<value>&hidden=<value>&chunker=<value>&pin=true&raw-leaves=<value>&nocopy=<value>&fscache=<value>&cid-version=0&hash=sha2-256“    

实例

看完操作步骤,相信您对IPFS的功能有了一些了解,我们进一步开下脑洞,看看能用IPFS干什么。

部署个人博客

ipfs add -r ipfs_blog/
ipfs name publish QmebnxXBK7BgxRy2VsCE6z89epc9teZDh6ih8MCQUjDCZW
ipfs name resolve Qmczs7Qzf9r5Efgi25gofF7VD1rrFuoz49eEgWwh2xdf4X

IPFS扫盲

做电商网站

IPFS扫盲
如图利用IPFS存储资源文件,利用比特币提供支付,自己写个后台提供接口,简直美滋滋(是不是少了很多审核流程),国外的Openbazaar就是这样的一个去中心化的电商,既没有交易费用,也不用担心审查。

FileCoin

Filecion是在IPFS基础上建立的项目,已经经过ICO,代币为“FIL”,用户通过向矿工支付FIL获取存储资源,从而激励有闲置资源的公众参与其中。FileCoin用复制证明(PoRep)和时空证明(Post)两种方式来证明矿工的价值,相比于依赖于工作量证明法(Pow)的比特币,FileCoin挖矿不会耗费那么多的电力和CPU。

疑问与解决方案

  1. 长长的一串哈希值不容易被记住。
    答:IPFS可以配置人类友好型域名,ipns就是解决这个问题的。
  2. 不想和世界联网,只想自己组个私网。
    答:IPFS支持搭建私网,生成一个swarm.key放到IPFS数据目录即可。

有价值的参考资料

Filecoin白皮书: https://filecoin.io/filecoin.pdf
Filecoin白皮书中文: http://chainx.org/paper/index/index/id/13.html
IPFS中文官网: http://ipfser.org/
IPFS白皮书: https://raw.githubusercontent.com/ipfs/ipfs/master/papers/ipfs-cap2pfs/ipfs-p2p-file-system.pdf
IPFS白皮书中文: https://gguoss.github.io/2017/05/28/ipfs/
IPFS源码: https://github.com/ipfs/go-ipfs
IPFS安装: https://ipfs.io/docs/install/
IPFS-js-api: https://github.com/ipfs/js-ipfs


IPFS扫盲的更多相关文章

  1. &lbrack;转载&rsqb;敏捷开发之Scrum扫盲篇

    现在敏捷开发是越来越火了,人人都在谈敏捷,人人都在学习Scrum和XP...      为了不落后他人,于是我也开始学习Scrum,今天主要是对我最近阅读的相关资料,根据自己的理解,用自己的话来讲述S ...

  2. ECMAScript 6 扫盲

    ECMAScript 6 目前基本成为业界标准,它的普及速度比 ES5 要快很多,主要原因是现代浏览器对 ES6 的支持相当迅速,尤其是 Chrome 和 Firefox 浏览器,已经支持 ES6 中 ...

  3. 转摘 MySQL扫盲篇

    一下文章摘自:http://www.jellythink.com/archives/636 MySQL扫盲篇 2014-09-15 分类:MySQL / 数据库 阅读(1412) 评论(1)  为什么 ...

  4. 敏捷开发之Scrum扫盲篇

    现在敏捷开发是越来越火了,人人都在谈敏捷,人人都在学习Scrum和XP... 为了不落后他人,于是我也开始学习Scrum,今天主要是对我最近阅读的相关资料,根据自己的理解,用自己的话来讲述Scrum中 ...

  5. Android扫盲教程大全经典教程全分享

    Android扫盲教程大全经典教程全分享,相当于android的简单用户手册下载路径 Android扫盲教程大全经典教程全分享.rar

  6. 【转】扫盲 同步利器、分布式网盘--BT Sync

    原文地址:http://program-think.blogspot.com/2015/01/BitTorrent-Sync.html先向大伙儿宣布个好消息——经过多位热心读者的大力支持,经过几天的努 ...

  7. 扫盲 BT Sync——不仅是同步利器,而且是【分布式】网盘

    先向大伙儿宣布个好消息-- 经过多位热心读者的大力支持,经过几天的努力,已经完成了"微软网盘"到"BitTorrent Sync"的迁移工作. 再次向这批热心读 ...

  8. jQuery学习笔记 - 基础知识扫盲入门篇

    jQuery学习笔记 - 基础知识扫盲入门篇 2013-06-16 18:42 by 全新时代, 11 阅读, 0 评论, 收藏, 编辑 1.为什么要使用jQuery? 提供了强大的功能函数解决浏览器 ...

  9. &lbrack;IIS&rsqb;IIS扫盲&lpar;六&rpar;

    一:聊天室  聊天室的种类有很多,免费的聊天室也有很多,这些聊天室的ASP源码从网上都可以下载得到,我们就以毒爱聊天室为版本来教大家做.好,大家先下载毒爱聊天室,当然,本站软件下载里就有下载,下载的是 ...

随机推荐

  1. 怎样在Windows资源管理器中添加右键菜单以及修改右键菜单顺序

    有时,我们需要在Windows资源管理器的右键菜单中添加一些项,以方便使用某些功能或程序. 比如我的电脑上有一个免安装版的Notepad++,我想在所有文件的右键菜单中添加一项用Notepad++打开 ...

  2. Coin Change

    You are given coins of different denominations and a total amount of money amount. Write a function ...

  3. JavaScript标准Selection操作

    简介 术语 属性 方法 document.activeElement document.designMode = 'on'; 简介 selection是对当前激活选中区(即高亮文本)进行操作. 在非I ...

  4. Android 设置控件可见与不可见

    通常控件的可见与不可见分为三种情况 第一种    gone         表示不可见并且不占用空间 第二种    visible       表示可见 第三种    invisible    表示不 ...

  5. FMDB 的基本操作

    在FMDB下载文件后,工程中必须导入如下文件,并使用 libsqlite3.dylib 依赖包 FMDB同时兼容ARC和非ARC工程,会自动根据工程配置来调整相关的内存管理代码. FMDB常用类: F ...

  6. Oracle to&lowbar;char&comma;to&lowbar;date

    一.在oracle中,当想把字符串为‘2011-09-20 08:30:45’的格式转化为日期格式,我们可以使用oracle提供的to_date函数. sql语句为: SELECT to_date(' ...

  7. ionic中应用sass

    在学习ionic过程中看到sass,总结了一下基本用法和问题解决办法1.首先需要一个ionic项目,并执行下面的命令ionic start CustomSass blank && cd ...

  8. Elasticsearch强制重置未分配的分片&lpar;unassigned&rpar;

    强制重置未分片的分片,这个问题源自于Elasticsearch维护中,Node意外退出的场景. 意外退出后Elasticsearch由于网络原因或者jvm性能压力,未能短时间内分配分片. 看一下分片的 ...

  9. EJB3基本概念、运行环境、下载安装与运行jboss

    EJB3基本概念 什么是EJB: EJB(EnterpriceJavaBeans)是一个用于分布式业务应用的标准服务端组件模型.采用EJB架构编写的应用是可伸的.事务性的.多用户安全的.采用EJB编写 ...

  10. 我眼中的 Docker(二)Image

    Docker 安装 如何安装 docker 详见官网: installation 或者 中文指南. 不过 linux 上我推荐用 curl 安装,因为 apt-get 中源要么没有 docker,要么 ...