IPFS私有集群的安装部署_ipfs swarm peers-程序员宅基地

技术标签: ipfs  ubuntu  docker  

IPFS的安装部署(私有集群)

利用docker部署

  1. 环境

    • golang
    • docker

    生成搭建私有网络所需的swarm.key密钥

    go get github.com/Kubuxu/go-ipfs-swarm-key-gen
    cd $GOPATH
    go build
    ./ipfs-swarm-key-gen > swarm.key
    
  2. 创建挂载目录:

    ipfs 的 export 和 data 目录挂载到主机上,这里做下准备,每个不同是私链节点的挂载目录不一样。

    以node0为例

    /home/admin/Docker/IPFS/node0/export

    /home/admin/Docker/IPFS/node0/data

  3. 在docker上部署

    在docker上搜索ipfs的镜像

    docker search ipfs
    

    拉取镜像

    docker pull ipfs/go-ipfs
    

    启动容器,并创建节点

    docker run --name ipfs-node-0 -v /home/admin/Docker/IPFS/node0/export:/export -v /home/admin/Docker/IPFS/node0/data:/data/ipfs -p 10000:4001 -p 11000:5001 -p 12000:8080 -d ipfs/go-ipfs:latest
    

    查看日志

    docker logs -f ipfs-node-0
    

    日志情况:

    Changing user to ipfs
    ipfs version 0.7.0
    generating ED25519 keypair...done
    peer identity: 12D3KooWKKsuNQpDteX6Xk5949kT67B5kTeZARpt4MBRbBseG3n4
    initializing IPFS node at /data/ipfs
    to get started, enter:
    
    	ipfs cat /ipfs/QmQPeNsJPyVWPFDVHb77w8G42Fvo15z4bG2X8D2GhfbSXc/readme
    
    Initializing daemon...
    go-ipfs version: 0.7.0-ea77213
    Repo version: 10
    System version: amd64/linux
    Golang version: go1.14.4
    Swarm is limited to private network of peers with the swarm key
    Swarm key fingerprint: d11e26ed1fe5b43f743eaf27f74d704a
    Swarm listening on /ip4/127.0.0.1/tcp/4001
    Swarm listening on /ip4/172.17.0.2/tcp/4001
    Swarm listening on /p2p-circuit
    Swarm announcing /ip4/127.0.0.1/tcp/4001
    Swarm announcing /ip4/172.17.0.2/tcp/4001
    API server listening on /ip4/0.0.0.0/tcp/5001
    WebUI: http://0.0.0.0:5001/webui
    Gateway (readonly) server listening on /ip4/0.0.0.0/tcp/8080
    Daemon is ready
    

    出现“Swarm is limited to private network of peers with the swarm key”,代表使用了私有密钥,属于私有节点。
    "Daemon is ready"表示ipfs已经启动。

    删除公有集群的引导节点

    docker exec ipfs-node-0 ipfs  bootstrap rm --all
    

    单个节点启动完成。

    另起一个节点,创建方式与单个节点的方式相同。注意端口号,文件路径需要更改。

    docker run --name ipfs-node-1 -v /home/admin/Docker/IPFS/node1/export:/export -v /home/admin/Docker/IPFS/node1/data:/data/ipfs -p 10001:4001 -p 11001:5001 -p 12001:8080 -d ipfs/go-ipfs:latest
    

    查看节点,打开节点的shell,在node0中可以看到node1的identity。

    docker exec -it ipfs-node-0 /bin/sh
    / # ipfs swarm peers
    /ip4/172.17.0.3/tcp/4001/p2p/12D3KooWFAWPkrCxHdTnM4KeuVVUD1hA8uaxUYDdefNEE1aNwKvu
    

    至此,部署完毕。

    测试:

    node0发布文件,node1通过哈希值获取文件

    docker exec ipfs-node-0 ipfs add /data/ipfs/version
    

    log:

    QmUnKvaCFaE8DSHMAq2XeHfrz1wW62uVbb4dNtxQ5zXy6n version 3 B / 3 B  100.00%
    

    在node1上获取

    docker exec ipfs-node-1 ipfs cat QmUnKvaCFaE8DSHMAq2XeHfrz1wW62uVbb4dNtxQ5zXy6n
    

    log:

    10
    

    测试成功。


在ubuntu虚拟机中部署

  1. 为各个虚拟机分配不同的IP地址(静态IP),参考博客: https://www.cnblogs.com/yyee/p/12899953.html

  2. 在官网上,下载ipfs安装包。下载地址: https://dist.ipfs.io/go-ipfs/

    由于特殊原因,网站需要科学上网,也可以从我的网盘获取go-ipfs的安装包(version: v0.7.0)。

    网盘地址:https://wws.lanzous.com/i0GjXjamlbi

  3. 解压安装包,在go-ipfs目录下运行如下指令

    sudo ./install.sh
    
  4. 初始化及相关配置

    在根目录运行如下指令

    ipfs init
    

    执行完此条命令之后,ipfs会在本地的根目录下创建一个名为.ipfs的隐藏文件夹,运行如下指令,即可看到新创建的文件夹

    ls -f
    
  5. 搭建私有节点

    搭建私有集群需要所有的节点使用同一个swarm.key私有密钥。
    生成私有密钥需要配置go语言环境,如果虚拟机里没有go语言环境,可以选择在有go语言的环境中,生成swarm.key,再复制到节点的目录中也是一样的。

    • 从github上获取生成私有密钥的代码,并运行生成私有密钥。

      go get -u http://github.com/Kubuxu/go-ipfs-swarm-key-gen/ipfs-swarm-key-gen
      cd $GOPATH
      cd src/github.com/Kubuxu/go-ipfs-swarm-key-gen/ipfs-swarm-key-gen/
      go build
      ./ipfs-swarm-key-gen > ~/swarm.key 
      

      “>”后是生成目录,可以任意选择,这里直接生成到了根目录下,方便之后copy到别的虚拟机中,也可以直接生成到ipfs的目录下。

    • 将swarm.key移动到ipfs的目录下

      sudo mv swarm.key ~/.ipfs
      
    • 移除默认的公有集群引导节点

      ipfs bootstrap rm --all
      
    • 启动服务

      ipfs daemon
      

    日志中出现“Swarm is limited to private network of peers with the swarm key”,代表创建的是私有节点。

  6. 搭建私有网络集群

    首先,需要保证节点的ipfs服务在运行状态,即“ipfs daemon”指令在运行中。

    然后,在要连接的目标节点中,通过如下指令,查询该节点的id。

    ipfs id
    

    最后,在私有节点中,手动添加其它节点的bootstrap信息。

    ipfs bootstrap add /ip4/192.168.23.101/tcp/4001/ipfs/12D3KooWG8oq9bC6WWsuUuvzUjNF6vPpjkoWmhTpQonJPfZbCRosB
    

    其中,/ip4/后面的ip地址是要连接的目标节点的ip地址,可以通过指令:ip address在目标节点中查看。

    /ipfs/后是目标节点的ipfs的id。

  7. 验证与测试

    在节点中输入如下指令,查询当前连接的节点。

    ipfs swarm peers
    

    测试在一个节点创建文件并添加到ipfs网络,其它节点接收。

    • 创建文件

      echo helloworld > test.txt
      
    • 添加到ipfs网络

      ipfs add test.txt
      

      返回信息,其中包括以Qm开头的哈希值,复制哈希值。

    • 通过哈希值获取文件

      在另一个节点中,通过文件的哈希值,获取文件。

      ipfs cat <Qm开头的哈希值>
      

      运行过后,打印出helloworld,代表搭建成功。

  8. 注意事项

    如果发现ipfs节点没有正常连接,首先检查各个节点的ipfs服务是否正在运行状态,如果运行状态正常,检查是否正确的设置了虚拟机的静态ip地址。

IPFS服务器后台运行

在Linux环境下,如果需要IPFS服务器在后台运行,只需输入以下指令

nohup ipfs daemon &
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/weixin_41746734/article/details/111069803

智能推荐

使用nginx解决浏览器跨域问题_nginx不停的xhr-程序员宅基地

文章浏览阅读1k次。通过使用ajax方法跨域请求是浏览器所不允许的,浏览器出于安全考虑是禁止的。警告信息如下:不过jQuery对跨域问题也有解决方案,使用jsonp的方式解决,方法如下:$.ajax({ async:false, url: 'http://www.mysite.com/demo.do', // 跨域URL ty..._nginx不停的xhr

在 Oracle 中配置 extproc 以访问 ST_Geometry-程序员宅基地

文章浏览阅读2k次。关于在 Oracle 中配置 extproc 以访问 ST_Geometry,也就是我们所说的 使用空间SQL 的方法,官方文档链接如下。http://desktop.arcgis.com/zh-cn/arcmap/latest/manage-data/gdbs-in-oracle/configure-oracle-extproc.htm其实简单总结一下,主要就分为以下几个步骤。..._extproc

Linux C++ gbk转为utf-8_linux c++ gbk->utf8-程序员宅基地

文章浏览阅读1.5w次。linux下没有上面的两个函数,需要使用函数 mbstowcs和wcstombsmbstowcs将多字节编码转换为宽字节编码wcstombs将宽字节编码转换为多字节编码这两个函数,转换过程中受到系统编码类型的影响,需要通过设置来设定转换前和转换后的编码类型。通过函数setlocale进行系统编码的设置。linux下输入命名locale -a查看系统支持的编码_linux c++ gbk->utf8

IMP-00009: 导出文件异常结束-程序员宅基地

文章浏览阅读750次。今天准备从生产库向测试库进行数据导入,结果在imp导入的时候遇到“ IMP-00009:导出文件异常结束” 错误,google一下,发现可能有如下原因导致imp的数据太大,没有写buffer和commit两个数据库字符集不同从低版本exp的dmp文件,向高版本imp导出的dmp文件出错传输dmp文件时,文件损坏解决办法:imp时指定..._imp-00009导出文件异常结束

python程序员需要深入掌握的技能_Python用数据说明程序员需要掌握的技能-程序员宅基地

文章浏览阅读143次。当下是一个大数据的时代,各个行业都离不开数据的支持。因此,网络爬虫就应运而生。网络爬虫当下最为火热的是Python,Python开发爬虫相对简单,而且功能库相当完善,力压众多开发语言。本次教程我们爬取前程无忧的招聘信息来分析Python程序员需要掌握那些编程技术。首先在谷歌浏览器打开前程无忧的首页,按F12打开浏览器的开发者工具。浏览器开发者工具是用于捕捉网站的请求信息,通过分析请求信息可以了解请..._初级python程序员能力要求

Spring @Service生成bean名称的规则(当类的名字是以两个或以上的大写字母开头的话,bean的名字会与类名保持一致)_@service beanname-程序员宅基地

文章浏览阅读7.6k次,点赞2次,收藏6次。@Service标注的bean,类名:ABDemoService查看源码后发现,原来是经过一个特殊处理:当类的名字是以两个或以上的大写字母开头的话,bean的名字会与类名保持一致public class AnnotationBeanNameGenerator implements BeanNameGenerator { private static final String C..._@service beanname

随便推点

二叉树的各种创建方法_二叉树的建立-程序员宅基地

文章浏览阅读6.9w次,点赞73次,收藏463次。1.前序创建#include&lt;stdio.h&gt;#include&lt;string.h&gt;#include&lt;stdlib.h&gt;#include&lt;malloc.h&gt;#include&lt;iostream&gt;#include&lt;stack&gt;#include&lt;queue&gt;using namespace std;typed_二叉树的建立

解决asp.net导出excel时中文文件名乱码_asp.net utf8 导出中文字符乱码-程序员宅基地

文章浏览阅读7.1k次。在Asp.net上使用Excel导出功能,如果文件名出现中文,便会以乱码视之。 解决方法: fileName = HttpUtility.UrlEncode(fileName, System.Text.Encoding.UTF8);_asp.net utf8 导出中文字符乱码

笔记-编译原理-实验一-词法分析器设计_对pl/0作以下修改扩充。增加单词-程序员宅基地

文章浏览阅读2.1k次,点赞4次,收藏23次。第一次实验 词法分析实验报告设计思想词法分析的主要任务是根据文法的词汇表以及对应约定的编码进行一定的识别,找出文件中所有的合法的单词,并给出一定的信息作为最后的结果,用于后续语法分析程序的使用;本实验针对 PL/0 语言 的文法、词汇表编写一个词法分析程序,对于每个单词根据词汇表输出: (单词种类, 单词的值) 二元对。词汇表:种别编码单词符号助记符0beginb..._对pl/0作以下修改扩充。增加单词

android adb shell 权限,android adb shell权限被拒绝-程序员宅基地

文章浏览阅读773次。我在使用adb.exe时遇到了麻烦.我想使用与bash相同的adb.exe shell提示符,所以我决定更改默认的bash二进制文件(当然二进制文件是交叉编译的,一切都很完美)更改bash二进制文件遵循以下顺序> adb remount> adb push bash / system / bin /> adb shell> cd / system / bin> chm..._adb shell mv 权限

投影仪-相机标定_相机-投影仪标定-程序员宅基地

文章浏览阅读6.8k次,点赞12次,收藏125次。1. 单目相机标定引言相机标定已经研究多年,标定的算法可以分为基于摄影测量的标定和自标定。其中,应用最为广泛的还是张正友标定法。这是一种简单灵活、高鲁棒性、低成本的相机标定算法。仅需要一台相机和一块平面标定板构建相机标定系统,在标定过程中,相机拍摄多个角度下(至少两个角度,推荐10~20个角度)的标定板图像(相机和标定板都可以移动),即可对相机的内外参数进行标定。下面介绍张氏标定法(以下也这么称呼)的原理。原理相机模型和单应矩阵相机标定,就是对相机的内外参数进行计算的过程,从而得到物体到图像的投影_相机-投影仪标定

Wayland架构、渲染、硬件支持-程序员宅基地

文章浏览阅读2.2k次。文章目录Wayland 架构Wayland 渲染Wayland的 硬件支持简 述: 翻译一篇关于和 wayland 有关的技术文章, 其英文标题为Wayland Architecture .Wayland 架构若是想要更好的理解 Wayland 架构及其与 X (X11 or X Window System) 结构;一种很好的方法是将事件从输入设备就开始跟踪, 查看期间所有的屏幕上出现的变化。这就是我们现在对 X 的理解。 内核是从一个输入设备中获取一个事件,并通过 evdev 输入_wayland

推荐文章

热门文章

相关标签