分享
  1. 首页
  2. 文章

IPFS安装编译

Jisen · · 6211 次点击 · · 开始浏览
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

[TOC]

安装

参考:

如果没有Go环境,首先需要安装Go环境:

brew install go

配置Go环境变量:
执行sudo vi /etc/profile加入

#go config
export PATH=$PATH:/usr/local/go/bin
export PATH=$PATH:$GOPATH/bin

执行wq! 强制保存退出。

下载并编译IPFS

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

❌出现error:

ERROR: from shell.Get(): Post https://ipfs.io/api/v0/get?arg=QmaPbCnUMBohSGo3KnxEa2bHqyJVVeEEcwtqJAYxerieBo&encoding=json&stream-channels=true: dial tcp 173.252.102.16:443: getsockopt: operation timed out

install from source #4851

⚠️:如果gx (用于依赖关系管理)或其任何依赖关系崩溃,go get则此进程可能会中断,因为将始终选择每个依赖关系的最新代码,通常会导致API不匹配。

预编译安装包安装IPFS

上述这个问题暂时还没解决,gx依赖以及中国网关的问题。那么通过????安装包的方式来安装运行IPFS:

  1. 下载go-ipfs,Mac OS X 請下載Darwin amd64,Ubuntu 請下載Linux amd64
  2. 使用tar xvfz go-ipfs_v0.4.14_darwin-amd64.tar.gz解压安装包。
  3. 运行项目,通过ipfs init在本地计算机建立一个IPFS节点。
  4. 测试一下,使用ipfs id查看节点id。

    {
    "ID": "QmZXXApnUUTD75bph88eNii3Sc97fiumTX7AMBv5CKHGdf",
    "PublicKey": "CAASpgIwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQCmeja+Xls57HMzJdpyk2uutamqNf0zwKUIde6AmK/qtneFSszEr7fwPZ6lE2KUxlaIdDelBpYLWKgwnJA89vWVDcFElXbgmLEwjlWeAnjR3EWLSQcmVGifB7jKrSG0VNeZdRv4Pj/i75zSdxAujZ0EwY6TpN6ZNaXX3BI/8owLlZAVq2wAKjFhjOtSfdGd5Tm61tN4q0EfPPHnU/kC9kr+HQkJm9h71pIL2Uu6LhoRQNpx/ZTnTXm6L0pxzEQSzal7lYsBQGiBKzzaL7PhZtZ6kY6atALRiiFj7ID8rbE03LrOQw4xoFjo3UBardTy1gQVflyqsysCi1DIStzn8qKNAgMBAAE=",
    "Addresses": null,
    "AgentVersion": "go-ipfs/0.4.14/",
    "ProtocolVersion": "ipfs/0.1.0"
    }
  5. 使用ipfs daemon启动节点服务器
  6. 新建终端执行命令ipfs cat /ipfs/QmYwAPJzv5CZsnA625s3Xf2nemtYgPpHdWEz79ojWnPbdG/readme
  7. 浏览器输入网址http://localhost:5001/webui出现一个漂亮的UI界面。

更新

IPFS有一个可以通过访问的更新工具ipfs update。该工具并不与IPFS一起安装,以保持独立于主代码库的逻辑。要安装ipfs update,请在此处下载

使用IPFS下载IPFS构建

列出go-ipfs的可用版本:

ipfs cat /ipns/dist.ipfs.io/go-ipfs/versions

然后,查看以前命令($ VERSION)中版本的可用版本:

ipfs ls /ipns/dist.ipfs.io/go-ipfs/$VERSION

下载一个版本的给定版本:

ipfs get /ipns/dist.ipfs.io/go-ipfs/$VERSION/go-ipfs_$VERSION_darwin-386.tar.gz # darwin 32-bit build
ipfs get /ipns/dist.ipfs.io/go-ipfs/$VERSION/go-ipfs_$VERSION_darwin-amd64.tar.gz # darwin 64-bit build
ipfs get /ipns/dist.ipfs.io/go-ipfs/$VERSION/go-ipfs_$VERSION_freebsd-amd64.tar.gz # freebsd 64-bit build
ipfs get /ipns/dist.ipfs.io/go-ipfs/$VERSION/go-ipfs_$VERSION_linux-386.tar.gz # linux 32-bit build
ipfs get /ipns/dist.ipfs.io/go-ipfs/$VERSION/go-ipfs_$VERSION_linux-amd64.tar.gz # linux 64-bit build
ipfs get /ipns/dist.ipfs.io/go-ipfs/$VERSION/go-ipfs_$VERSION_linux-arm.tar.gz # linux arm build
ipfs get /ipns/dist.ipfs.io/go-ipfs/$VERSION/go-ipfs_$VERSION_windows-amd64.zip # windows 64-bit build

用法

 ipfs - Global p2p merkle-dag filesystem.
 ipfs [<flags>] <command> [<arg>] ...
SUBCOMMANDS
 BASIC COMMANDS
 init Initialize ipfs local configuration # 初始化ipfs本地配置
 add <path> Add a file to ipfs # 向ipfs添加文件
 cat <ref> Show ipfs object data # 显示ipfs object数据
 get <ref> Download ipfs objects # 下载ipfs objects
 ls <ref> List links from an object # 一个对象链接的列表
 refs <ref> List hashes of links from an object # 一个对象链接的哈希列表
 DATA STRUCTURE COMMANDS
 block Interact with raw blocks in the datastore # 与数据存储中的原始块交互
 object Interact with raw dag nodes # 与原始dag节点交互
 files Interact with objects as if they were a unix filesystem # 与objects交互,就好像它们是unix文件系统一样
 ADVANCED COMMANDS
 daemon Start a long-running daemon process # 启动一个长时间运行的守护进程
 mount Mount an ipfs read-only mountpoint # 安装一个ipfs只读挂载点
 resolve Resolve any type of name # 解析任何类型的名称
 name Publish or resolve IPNS names # 发布或解析IPNS名称
 dns Resolve DNS links # 解析DNS链接
 pin Pin objects to local storage # 将object定位到本地存储
 repo Manipulate an IPFS repository # 操作一个ipfs仓库
 NETWORK COMMANDS
 id Show info about ipfs peers # 显示ipfs 节点的信息
 bootstrap Add or remove bootstrap peers # 添加或删除bootstrap节点
 swarm Manage connections to the p2p network # 管理与p2p网络的连接
 dht Query the DHT for values or peers # 为values或者节点查询DHT
 ping Measure the latency of a connection # 测量连接的延迟
 diag Print diagnostics # 打印诊断信息
 TOOL COMMANDS
 config Manage configuration # 管理配置
 version Show ipfs version information # 显示ipfs版本信息
 update Download and apply go-ipfs updates # 下载并应用go-ipfs更新 
 commands List all available commands # 所有可用的命令列表
 Use 'ipfs <command> --help' to learn more about each command.
 ipfs uses a repository in the local file system. By default, the repo is located
 at ~/.ipfs. To change the repo location, set the $IPFS_PATH environment variable:
 export IPFS_PATH=/path/to/ipfsrepo

另见:ipfs getting-started

要开始使用IPFS,您必须首先在您的系统上初始化IPFS的配置文件,这是通过ipfs init。查看ipfs init --help它所需的可选参数的信息。初始化完成后,就可以使用ipfs mount,ipfs add或其他任何命令来探索!

本地'ipfs working'基本使用:

echo "hello world" > hello
ipfs add hello
# This should output a hash string that looks something like:
# QmT78zSuBmuS4z925WZfrqQ1qHaJ56DQaTfyMUF7F8ff5o
ipfs cat <that hash>

使用Docker

IPFS的docker镜像位于hub.docker.com/r/ipfs/go-ipfs。要在容器内部显示文件,您需要使用-v docker选项安装主机目录。选择一个您想用来从IPFS导入/导出文件的目录。您还应该选择一个目录来存储IPFS文件,这些文件在重新启动容器时将保留。

export ipfs_staging=</absolute/path/to/somewhere/>
export ipfs_data=</absolute/path/to/somewhere_else/>

启动运行ipfs的容器并公开端口4001,50018080:

docker run -d --name ipfs_host -v $ipfs_staging:/export -v $ipfs_data:/data/ipfs -p 4001:4001 -p 127.0.0.1:8080:8080 -p 127.0.0.1:5001:5001 ipfs/go-ipfs:latest

观看ipfs日志:

docker logs -f ipfs_host

等待ipfs启动。看到以下内容时,ipfs正在运行:

Gateway (readonly) server
listening on /ip4/0.0.0.0/tcp/8080

现在可以停止观看日志。
运行ipfs命令:

docker exec ipfs_host ipfs <args...>

例如:连接到节点

docker exec ipfs_host ipfs swarm peers

添加文件:

cp -r <something> $ipfs_staging
docker exec ipfs_host ipfs add -r /export/<something>

停止正在运行的容器:

docker stop ipfs_host

⚠️:如果您之前已经安装过IPFS,并且遇到了使新版本工作的问题,请尝试删除(或备份其他位置)IPFS配置目录(默认为〜/ .ipfs)并重新运行ipfs init。这会将配置文件重新初始化为其默认值,并清除任何错误条目的本地数据存储区。

扩展链接


有疑问加站长微信联系(非本文作者)

本文来自:Segmentfault

感谢作者:Jisen

查看原文:IPFS安装编译

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

关注微信
6211 次点击
暂无回复
添加一条新回复 (您需要 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传

用户登录

没有账号?注册
(追記) (追記ここまで)

今日阅读排行

    加载中
(追記) (追記ここまで)

一周阅读排行

    加载中

关注我

  • 扫码关注领全套学习资料 关注微信公众号
  • 加入 QQ 群:
    • 192706294(已满)
    • 731990104(已满)
    • 798786647(已满)
    • 729884609(已满)
    • 977810755(已满)
    • 815126783(已满)
    • 812540095(已满)
    • 1006366459(已满)
    • 692541889

  • 关注微信公众号
  • 加入微信群:liuxiaoyan-s,备注入群
  • 也欢迎加入知识星球 Go粉丝们(免费)

给该专栏投稿 写篇新文章

每篇文章有总共有 5 次投稿机会

收入到我管理的专栏 新建专栏