1、安装包下载

ipfs安装版本下载:https://github.com/ipfs/go-ipfs/releases,这是IPFS的go语言实现版,目前实现的还有js版本。

2、安装与启动

linux下安装需注意:go-ipfs解压后需将文件所有者和组更改为root,然后安装。

修改文件夹用户组

chgrp root ./go-ipfs -R

chown root ./go-ipfs -R

-R表示递归目录下所有文件

ipfs节点初始化:

ipfs init

默认情况下,ipfs将在当前用户主目录(例如:对于hubwiz用户,其主目录就是C:\Users\hubwiz或/home/hubwiz)下建立.ipfs子目录,作为本地仓库的根目录。

如果想自定义ipfs的仓库目录,需要设置IPFS_PATH环境变量,将其指向目标目录。若IPFS_PATH设置为/home/hxdms/ipfs则创建如下文件:

ipfs后台启动命令:ipfs daemon > ipfs.log &

3、局域网搭建的三个ipfs节点之间无法下载其他节点上的文件

问题描述:A、B、C为局域网内三个IPFS节点,QmU9N3w91cLFmxF4j77EL7QAzTzVpatyUuRiKYgKz7P7DM有A节点上传;

节点B、C通过命令ipfs cat QmU9N3w91cLFmxF4j77EL7QAzTzVpatyUuRiKYgKz7P7DM无法下载。

问题分析:在B、C节点上通过命令: ipfs swarm peers,查看不到A节点,说明节点之间未建立连接,在局域网中并不能自动发现ipfs节点。

解决办法:

(1)、手动连接要访问的ipfs节点

(2)、通过构建A、B、C的私有网络

该方法对于解决这个问题比较麻烦,但对于有私有网络需求的应用使用起来比较安全高效,具体请参看:

https://www.cnblogs.com/HandyLi/p/11864639.html

4、浏览器中无法通过Gateway访问文件

问题描述:本地可以在浏览器中通过localhost访问ipfs上的文件,但局域网内的其他计算机却访问失败,

http://IP:PORT/ipfs/Qmd7WPAGcMYmr4V8Rcw11pkrd5Gmrc68dUh3AVU7KQPeK1

问题分析:查看IPFS节点的配置发现是ipfs网关设置引起的。

解决办法:通过命令修改网关——ipfs config Addresses.Gateway /ip4/0.0.0.0/tcp/8082.

默认情况下,网关为/ip4/127.0.0.1/tcp/8082,只能在本地访问。要将其公开给网络中的其他计算机,要使用0.0.0.0作为IP地址。

也可以修改API地址:ipfs config Addresses.API /ip4/127.0.0.1/tcp/5002,如果将API地址也设置为公开的:/ip4/0.0.0.0/tcp/5002,

这其中存在着安全风险,因为任何人都可以对您的节点实施远程控制。如果您需要远程控制某个节点,请确保像其他服务或数据库(防火墙,验证代理等)一样保护端口。

5、文件夹更新了,但使用方仍然想用原来的HASH访问文件

解决办法:通过IPNS发布文件夹。

ipfs提供了ipns解决文件夹更新的问题,用户提供一个key(HASH键值)绑定一个已经存在ipfs节点上的文件夹,然后就可以通过key进行访问和下载了。

具体操作如下:

1)、  上传文件夹

ipfs add -r file

#得到file文件夹HASH:QmYVfNptb5k52K9BG4Qk21Zzem1NdcmMgHMhsbsDJN5QRM

2)、  创建key

创建key用于发布文件夹:

ipfs key gen --type=rsa --size=2048 testkey

#创建名称为testkey的键

ipfs key list -l

#查看已经创建的keys,-l会列出key的HASH

3)、  发布文件夹,并绑定到指定key

将key绑定到指定文件夹:

ipfs name publish --key=testkey QmYVfNptb5k52K9BG4Qk21Zzem1NdcmMgHMhsbsDJN5QRM

#发布到IPNS,并将文件夹绑定testkey:QmYcrteNYNV1e7Wub7jCnogpHoeoBeXLNYg12ow87zHzPe

ipfs name publish QmYVfNptb5k52K9BG4Qk21Zzem1NdcmMgHMhsbsDJN5QRM

#将文件夹发布到IPNS,默认与节点ID(QmUpwjfX6gedCEeh6ncRfshXnDuwSbvZh1uXpriMy1kFnH)绑定。

4)、  文件夹访问

Gateway访问:

IP:8080/ipns/QmUpwjfX6gedCEeh6ncRfshXnDuwSbvZh1uXpriMy1kFnH

或IP:8080/ipns/ QmYcrteNYNV1e7Wub7jCnogpHoeoBeXLNYg12ow87zHzPe

5)、  文件下载:

ipfs get /ipns/QmUpwjfX6gedCEeh6ncRfshXnDuwSbvZh1uXpriMy1kFnH

或ipfs get /ipns/QmYcrteNYNV1e7Wub7jCnogpHoeoBeXLNYg12ow87zHzPe

6)、  文件夹更新

文件夹更新后需要重新发布,重复1、3步骤即可,要注意更改文件夹的HASH。

ipfs add -r file

得到file文件夹的Hash值:QmSbQBdaK4mvT1aUwDcrpjMzpRiRvtmEjZuDyziVrTeb2q

发布到之前的key:

ipfs name publish --key=testkey QmSbQBdaK4mvT1aUwDcrpjMzpRiRvtmEjZuDyziVrTeb2q

或ipfs name publish QmSbQBdaK4mvT1aUwDcrpjMzpRiRvtmEjZuDyziVrTeb2q

按原方式访问和下载

IPFS问题总结的更多相关文章

  1. IPFS搭建分布式文件系统 - 访问控制

    IPFS 一个内容可寻址.对等的超媒体分发协议. IPFS网络中的节点形成分布式文件系统. 为什么要用IPFS? “IPFS and the Blockchain are a perfect matc ...

  2. 什么是IPFS?(二)

    IPFS的的"宏伟"目标是取代HTTP, 那么先来看看IPFS是如何工作的? IPFS为每一个文件分配一个独一无二的哈希值(文件指纹: 根据文件的内容进行创建), 即使是两个文件内 ...

  3. IPFS家族(二)

    go-ipfs IPFS协议的go语言实现,ipfs的核心协议,最新版是v0.4.13 下载地址:https://dist.ipfs.io/#go-ipfs 源代码地址:https://github. ...

  4. IPFS家族(一)

    IPFS这个项目其实很大,并不像大家想象的是一个东西,IPFS是由很多模块组成,每一个模块现在都已经独立成项目了,并且有自己的主页.让我们来简单看一下IPFS家族成员. 协议实验室的主页:https: ...

  5. IPFS: Merkle DAG数据结构

    今天带大家来深入探索一下IPFS的核心数据结构Merkle DAG 什么是 Merkle DAG? Merkle DAG是IPFS系统的核心概念之一,当然Merkle DAG并不是IPFS团队发明的, ...

  6. IPFS网络是如何运行的(p2p网络)

    IPFS是一个p2p网络,先来看看BitTorrent的p2p网络是如何工作的? 想要bt下载一个文件,首先你需要一个种子文件torrent,种子文件包含至少一个 Tracker(一台服务器地址)信息 ...

  7. IPFS: BitSwap协议(数据块交换)

    原创 2018-01-11 飞向未来 IPFS指南 BitSwap协议 IPFS节点之间是如何进行数据交换的?本文来讲一下这个问题. IPFS在BitTorrent的基础上实现了p2p数据交换协议:B ...

  8. IPFS: NAT traversal(NAT穿越)

    IPFS是一个p2p网络,那么一定绕不开的一个问题就是NAT穿越.之前的文章里面也提到过IPFS网络连通性使用的ICE NAT穿越框架,本文简单介绍一下什么是NAT.   为什么有NAT技术? NAT ...

  9. IPFS开发团队是如何工作的?

    小编不是一个很八卦的人,连当红明星都认不全.不过,今天还是带领大家来扒一扒ipfs开发团队是如何工作的. 工作方式: 全体会议:每周一有一个全体会议,这个会议是提前安排好的一个日程 任务讨论:把大任务 ...

  10. IPFS:Filecoin和复制证明

    这篇文章主要来讲一下Filecoin协议里面的复制证明(Proof of Replication),由于协议涉及到很多概念,可能看起来有点晕乎乎的,小编尽量把复杂问题简单化 ,力求给大家做大普及IPF ...

随机推荐

  1. 一维跳棋(BFS)

    一维跳棋是一种在1×(2N+1) 的棋盘上玩的游戏.一共有N个棋子,其中N 个是黑的,N 个是白的.游戏开始前,N 个白棋子被放在一头,N 个黑棋子被放在另一头,中间的格子空着. 在这个游戏里有两种移 ...

  2. 利用tensorflow编写自己的机器学习模型主要步骤

    利用tensorlow编写自己的机器学习模型主要分为两个阶段: 第一阶段:建立模型或者建立网络结构 1.定义输入和输出所需要的占位符 2.定义权重 3.定义具体的模型接口 4.定义损失函数 5.定义优 ...

  3. Python 学习笔记:Python 连接 SQL Server 报错(20009, b'DB-Lib error message 20009, severity 9)

    问题及场景: 最近需要使用 Python 将数据写到 SQL Server 数据库,但是在进行数据库连接操作时却报以下错误:(20009, b'DB-Lib error message 20009, ...

  4. JavaScript学习笔记 - 进阶篇(3)- 流程控制语句

    if语句 if语句是基于条件成立才执行相应代码时使用的语句. 语法: if(条件) { 条件成立时执行代码} 注意:if小写,大写字母(IF)会出错! 假设你应聘web前端技术开发岗位,如果你会HTM ...

  5. CF 1047 C - Enlarge GCD [素数筛]

    传送门:http://codeforces.com/contest/1047/problem/C 题意:给出n个数字,求最少删除几个数可以使剩下的数字的GCD大于n个数字的GCD 思路:最开始想的是先 ...

  6. HTTP知识整理

    HTTP协议 HTTP协议的主要特点可概括如下: 1.支持客户/服务器模式. 2.简单快速:客户向服务器请求服务时,只需传送请求方法和路径.请求方法常用的有GET.HEAD.POST.每种方法规定了客 ...

  7. StartDT AI Lab | 数据增强技术如何实现场景落地与业务增值?

    有人说,「深度学习“等于”深度卷积神经网络算法模型+大规模数据+云端分布式算力」.也有人说,「能够在业内叱咤风云的AI都曾“身经百战”,经历过无数次的训练与试错」.以上都需要海量数据做依托,对于那些数 ...

  8. jedis异常Broken pipe (Write failed)

    异常:java.net.SocketException: Broken pipe (Write failed); nested exception is redis.clients.jedis.exc ...

  9. soap,restful 两种web service实现方式比较

    web service服务 目前常用的实现web service的方式有有两种 1.SOAP 原始的web service标准,一堆标准,不过这些标准是在开发框架中实现的,有上层接口,可以调用 2.R ...

  10. Eclipse 中 Syntax error on token "Invalid Character", delete this token 的解决

    eclipse中遇到了Syntax error on token "Invalid Character", delete this token(令牌“无效字符”上的语法错误,删除此 ...