当前位置:主页 > 区块链 > 区块链技术 > 搭建IPFS私有网络

手把手教你搭建IPFS私有网络与使用(附IPFS API参考文档)

2021-04-08 14:31:50 | 来源:登链社区 | 作者:佚名
这篇文章主要介绍了手把手教你搭建IPFS私有网络与使用,在联盟链的场景下,IPFS 作为去中心化存储的首选方案,本文将介绍如何使用 go-ipfs 搭建一个私有网络并进行简单使用。下面一起来参考下内容吧!

在联盟链的场景下,IPFS 作为去中心化存储的首选方案,本文将介绍如何使用go-ipfs搭建一个私有网络并进行简单使用。

我的环境

由于资源限制,我这里使用docker来搭建一个两个节点的 IPFS 私有网络。如果有条件可以直接在多台机器或者多个虚拟机上安装。

开始搭建

1、生成 swarm.key

swarm.key 是一个共享密钥,只有拥有相同密钥的节点才能互相通信,组成一个私钥网络。swarm.key 可以使用 工具 生成,工具的安装命令是:

go get -u github.com/Kubuxu/go-ipfs-swarm-key-gen/ipfs-swarm-key-gen

安装完成后,生成 swarm.key,命令是:

ipfs-swarm-key-gen > /Users/sixdays/tmp/ipfs/swarm.key

其中

  • /Users/sixdays/tmp/ipfs/ 目录是我 ipfs 目录。
  • /Users/sixdays/tmp/ipfs/node1 是我 ipfs 节点 1 目录。
  • /Users/sixdays/tmp/ipfs/node2 是我 ipfs 节点 2 目录。

2、启动节点

运行节点 1 和节点 2

// 运行节点 1
docker run -d --name ipfs_node_1 -e IPFS_SWARM_KEY_FILE=/Users/sixdays/tmp/ipfs/swarm.key -v /Users/sixdays/tmp/ipfs/node1/staging:/export -v /Users/sixdays/tmp/ipfs/node1/data:/data/ipfs -p 4001:4001 -p 4001:4001/udp -p 127.0.0.1:8080:8080 -p 127.0.0.1:5001:5001 ipfs/go-ipfs:latest

// 运行节点 2
docker run -d --name ipfs_node_2 -e IPFS_SWARM_KEY_FILE=/Users/sixdays/tmp/ipfs/swarm.key -v /Users/sixdays/tmp/ipfs/node2/staging:/export -v /Users/sixdays/tmp/ipfs/node2/data:/data/ipfs -p 4002:4001 -p 4002:4001/udp -p 127.0.0.1:8081:8080 -p 127.0.0.1:5002:5001 ipfs/go-ipfs:latest

清除所有缺省启动节点 bootstrap

docker exec ipfs_node_1 ipfs bootstrap rm all
docker exec ipfs_node_2 ipfs bootstrap rm all

查看节点 id

docker exec ipfs_node_1 ipfs id
docker exec ipfs_node_2 ipfs id

这里,我节点 1 的 Id 是 :

12D3KooWEVo8FqH8YUT1noXvca5hgSRWBRcDQomEcFY2zXwA7dbw

节点 1 的 address 是:

/ip4/172.17.0.3/tcp/4001/p2p/12D3KooWEVo8FqH8YUT1noXvca5hgSRWBRcDQomEcFY2zXwA7dbw

节点 2 的 Id 是

12D3KooWRcx6gpbsbvb6YiNsDpJgnmNHFCgCiUmVF42o4zn2W5Pj

节点 2 的 address 是

/ip4/172.17.0.4/tcp/4001/p2p/12D3KooWRcx6gpbsbvb6YiNsDpJgnmNHFCgCiUmVF42o4zn2W5Pj

节点的 address 我用的是 docker 给分配的 ip 地址。

添加节点 id

在节点 1 中添加节点 2 地址

docker exec ipfs_node_1 ipfs bootstrap add /ip4/172.17.0.4/tcp/4001/p2p/12D3KooWRcx6gpbsbvb6YiNsDpJgnmNHFCgCiUmVF42o4zn2W5Pj

在节点 2 中添加节点 1 地址

docker exec ipfs_node_1 ipfs bootstrap add /ip4/172.17.0.3/tcp/4001/p2p/12D3KooWEVo8FqH8YUT1noXvca5hgSRWBRcDQomEcFY2zXwA7dbw

至此,我们 2 个节点的 IPFS 私有网络已搭建完成。

用一下

使用命令

docker exec ipfs_node_1 ipfs -h

可以看到 IPFS 的基础命令。

添加文件 add

$ docker exec ipfs_node_1 ipfs add /data/ipfs/swarm.key
added QmRitSEMhFJtNhLYtwGRJvhDrTTT4gQLjuLepZjo9C8a2X swarm.key

其中 :

  • /data/ipfs/swarm.key 为 ipfs_node_1 容器的目录。
  • QmRitSEMhFJtNhLYtwGRJvhDrTTT4gQLjuLepZjo9C8a2X 为文件 hash

查看文件 cat

$ docker exec ipfs_node_2 ipfs cat QmRitSEMhFJtNhLYtwGRJvhDrTTT4gQLjuLepZjo9C8a2X
/key/swarm/psk/1.0.0/
/base16/
5b9941085678c502b44cc98e2614dd648cb801115dcb6acee8e83d9bf8cf454c

可以看到我们可以在 node2 中查看到 node1 上传的文件内容。

下载文件 get

$ docker exec ipfs_node_2 ipfs get QmRitSEMhFJtNhLYtwGRJvhDrTTT4gQLjuLepZjo9C8a2X -o /data/ipfs/test.key
Saving file(s) to /data/ipfs/test.key
95 B / 95 B 100.00% 0s

其中 -o 表示输出目录,docker 容器中的 /data/ipfs 对应我们主机目录为 /Users/sixdays/tmp/ipfs/node2/data

查看文件列表 ls

$ docker exec ipfs_node_2 ipfs pin ls
QmQ5vhrL7uv6tuoN9KeVBwd4PwfQkXdVVmDLUZuTNxqgvm indirect
QmU5k7ter3RdjZXu3sHghsga1UQtrztnQxmTL22nPnsu3g indirect
QmYCvbfNbCwFR45HiNP45rwJgvatpiW38D961L5qAhUM5Y indirect
QmejvEPop4D7YUadeGqYWmZxHhLc4JBUCzJJHWMzdcMe2y indirect
QmPZ9gcCEpqKTo6aq61g2nXGUhM4iCL3ewB6LDXZCtioEB indirect
QmQGiYLVAdSHJQKYFRTJZMG4BXBHqKperaZtyKGmCRLmsF indirect
QmQPeNsJPyVWPFDVHb77w8G42Fvo15z4bG2X8D2GhfbSXc recursive
QmQy6xmJhrcC5QLboAcGFcAE1tC8CrwDVkrHdEYJkLscrQ indirect
QmUNLLsPACCz1vLxQVkXqqLX5R1X345qqfHbsf67hvA3Nn recursive

其中 recursive 表示文件夹,indirect 表示文件

参考:IPFS API参考文档

到此这篇关于手把手教你搭建IPFS私有网络与使用(附IPFS API参考文档)的文章就介绍到这了,更多相关搭建IPFS私有网络内容请搜索脚本之家以前的文章或继续浏览下面的相关文章,希望大家以后多多支持脚本之家!

免责声明:本文只为提供市场讯息,所有内容及观点仅供参考,不构成投资建议,不代表本站观点和立场。投资者应自行决策与交易,对投资者交易形成的直接或间接损失,作者及本站将不承担任何责任。!
Tag:IPFS   私有网络   区块链  

你可能感兴趣的文章

更多

热门币种

  • 币名
    最新价格
    24H涨幅
  • bitcoin BTC 比特币

    BTC

    比特币

    $ 75872.69¥ 517239.3
    +2.68%
  • ethereum ETH 以太坊

    ETH

    以太坊

    $ 2314.42¥ 15777.86
    +2.14%
  • tether USDT 泰达币

    USDT

    泰达币

    $ 1.0001¥ 6.8178
    -0.01%
  • ripple XRP 瑞波币

    XRP

    瑞波币

    $ 1.4244¥ 9.7104
    +2.2%
  • binance-coin BNB 币安币

    BNB

    币安币

    $ 629.18¥ 4289.24
    +2.14%
  • usdc USDC USD Coin

    USDC

    USD Coin

    $ 0.9994¥ 6.8131
    -0.02%
  • solana SOL Solana

    SOL

    Solana

    $ 85.2798¥ 581.36
    +2.08%
  • tron TRX 波场

    TRX

    波场

    $ 0.329¥ 2.2428
    -0.03%
  • dogecoin DOGE 狗狗币

    DOGE

    狗狗币

    $ 0.095108¥ 0.6483
    +2.21%
  • hyperliquid HYPE Hyperliquid

    HYPE

    Hyperliquid

    $ 40.7604¥ 277.87
    +0.52%

币圈快讯

  • 某新建钱包从CEX提取199999枚HYPE后售出获得815万枚USDC

    2026-04-21 09:21
    据OnchainLens监测,某新建钱包从CEX提取199,999枚HYPE后售出获得815万枚USDC,随后从Hyperliquid提出这笔资金存入币安。
  • Strategy单周斥资$25.4亿增购34164枚BTCBitmine上周购入101627枚ETH创年内最大单周纪录

    2026-04-21 09:21
    据BBX数据,昨日两大加密资产储备公司同步披露持仓更新,比特币与以太坊国库储备扩张速度均创阶段性新高,核心动态如下:Strategy,Inc.(NASDAQ:$MSTR)于4月20日提交SECForm8-K,披露公司在4月13日至19日期间增购34,164枚BTC,总耗资约$25.4亿,均价约$74,395,为公司历史上第三大单次购入规模;本轮购币资金约85%来源于STRC优先股ATM融资(净入账$21.76亿),余款来自MSTR普通股(净入账$3.66亿)。截至4月19日,公司总持仓达815,061枚BTC,总成本约$615.6亿(均价$75,527),2026年初至今BTCYield为9.5%。BitmineImmersionTechnologies,Inc.(NYSE:$BMNR)于4月20日通过PRNewswire发布官方公告,截至4月19日4:00pmET,公司持有4,976,485枚ETH(约占ETH流通总量4.12%),上周单周购入101,627枚ETH(约合$2.3亿),为2026年最大单周增持量;公司合并加密资产、现金及战略投资总额约$129亿(含$11.2亿现金)。当前已质押3,334,637枚ETH(占总持仓约67%),年化质押收益约$2.21亿(7日质押年化收益率2.88%)。
  • StrategyCEO:STRC年内购入比特币规模已达ETF总和的10倍

    2026-04-21 09:15
    比特币财库公司Strategy首席执行官PhongLe在X平台转发数据显示,旗下永续优先股STRC在2026年迄今购入的比特币数量已达到所有比特币ETF同期总购入量的约10倍,显示出企业端持续加码配置的强劲趋势。
  • 摩根士丹利ETF增持215枚比特币贝莱德ETF增持3372枚

    2026-04-21 09:01
    4月21日,据OnchainLens监测,摩根士丹利ETF4小时前购买215枚BTC,价值1643万美元。现在他们持有价值1.381亿美元的1820.6枚BTC。贝莱德ETF在过去8小时内从Coinbase提取了3,372枚BTC(价值2.5586亿美元)。
  • 美国SOL现货ETF单日总净流入328.38万美元

    2026-04-21 08:59
    根据SoSoValue数据,SOL现货ETF单日总净流入328.38万美元。 净流入最多的SOL现货ETF为FidelitySolanaFundETF(FSOL),单日净流入254.25万美元,目前历史总净流入达1.58亿美元。其次为VanEckSolanaETF(VSOL),单日净流入56.86万美元,目前历史总净流入达1910.98万美元。 截至发稿前,SOL现货ETF总资产净值为8.72亿美元,SOL净资产比率1.76%,历史累计净流入已达10.13亿美元。
  • 查看更多