分散站点的关键在于分散地托管它们,这就是 IPFS 发挥作用的地方。让我们稍微熟悉一下 IPFS 以及如何使用它来托管网站!
什么是 IPFS?
星际文件系统(IPFS)是一种协议和点对点网络,用于在分布式文件系统中存储和共享数据。
它与 Torrent 所做的非常相似,但是除了接收允许它托管的内容外。一切都是分布式的。
但是 interplanetary staff?非常简单,这背后的想法是使互联网连接成为可能,即使你非常遥远。它允许你从附近的某个人检索文件,而不是从几千公里或几百万公里以外的某个地方,比如其他星球获取文件。然而,这是这个项目理想的目标。
目前,它还有两个附加的优点(除了加快从遥远的数据中心获取文件的优点):
安装 IPFS
要首先在计算机上安装 IPFS,您需要下载适用于您的操作系统和平台的发行包。按照官方发行页面查找适合您的软件包。下载并找到安装包后,请遵循以下操作系统特定的部分:
$ tar xvfz go-ipfs_*.tar.gz
运行安装(基本上它将二进制文件移至可执行文件$PATH中的某个位置)
$ cd go-ipfs
$ ./install.sh
解压下载的软件包,然后手动将 ipfs.exe 移到您的%PATH%的某个位置(或者放置到某个特定的目录并更新%PATH%变量)
$ ipfs -—version
ipfs version 0.5.1
因此,现在我们准备好将您的网站托管在 IPFS 上。
基本
由于 IPFS 存储所有设置,并且首先在本地存储库(类似于Git)中完成,所以我们需要使用以下命令对其进行初始化:
$ ipfs init
initializing IPFS node at /home/[username]/.ipfs
generating 2048-bit RSA keypair…done
peer identity: QmQddxyRmLoShfP2HeJwzcoGoh2tD7crwUeRevFBg6Lt48
to get started, enter:
ipfs cat /ipfs/QmQPeNsJPyVWPFDVHb77w8G42Fvo15z4bG2X8D2GhfbSXc/readme
您可以使用上面建议的命令来查看 IPFS(即自述文件)中已固定的内容:
$ ipfs cat
/ipfs/QmQPeNsJPyVWPFDVHb77w8G42Fvo15z4bG2X8D2GhfbSXc/readme
Hello and Welcome to IPFS!
...
If you're seeing this, you have successfully installed
IPFS and are now interfacing with the ipfs merkledag!
...
Check out some of the other files in this directory:
./about
./help
./quick-start <-- usage examples
./readme <-- this file
./security-notes
请注意,您的情况下哪些粗体哈希可能会有所不同。第一个代表您在 IPFS 网络中的对等身份。第二个是自述文件,关于,帮助,快速入门和安全说明文件的当前固定版本。您可以使用类似于上述命令的所有文件。
让您上网
为了使我们的节点联机并连接到 IPFS 网络,我们需要使用以下命令运行 IPFS 守护程序:
$ ipfs daemon
Initializing daemon…
go-ipfs version: 0.5.1
Repo version: 9
System version: amd64/linux
Golang version: go1.13.10
Swarm listening on /ip4/127.0.0.1/tcp/4001
Swarm listening on /ip4/192.168.1.190/tcp/4001
Swarm listening on /ip6/::1/tcp/4001
Swarm listening on /p2p-circuit
Swarm announcing /ip4/115.187.39.125/tcp/4001
Swarm announcing /ip4/127.0.0.1/tcp/4001
Swarm announcing /ip4/192.168.1.190/tcp/4001
Swarm announcing /ip6/::1/tcp/4001
API server listening on /ip4/127.0.0.1/tcp/5001
WebUI: http://127.0.0.1:5001/webui
Gateway (readonly) server listening on /ip4/127.0.0.1/tcp/8080
Daemon is ready
在另一个使用以下命令的终端中,您可以检查连接到的对等方:
$ ipfs swarm peers
/ip4/104.131.131.82/tcp/4001/p2p/QmaCpDMGvV2BGHeYERUEnRQAwe3N8SzbUtfsmvsqQLuvuJ
...
用粗体突出显示的是单个对等方的传输地址。还要注意节点的公钥哈希(对等身份)。
...
WebUI: http://127.0.0.1:5001/webui
...
这是您要与节点一起使用的节点的 Web 界面地址:
请注意,由于安全原因,5001 端口不会对外公开。但是,如何远程连接到您的节点(或您的VM)也有同样好的安全方法。为此,您可以使用以下命令使用 SSH 隧道将本地 5001 端口转发到您的节点:
ssh -L 5001:localhost:5001 [username]@[server-address]
您可以使用 WebUI 来管理 IPFS 节点上的文件,查看各种使用情况统计信息,并以更友好的方式配置节点。
去中心化网站
让我们开始第一个分散的网站。首先,我们将需要一个网站(我将不做过多解释,但总之,您只需要在 HTML/JS/CSS 上创建网站)。例如,使用我为您准备的模板(顺便说一句,该模板托管在 IPFS 上)。
我将假定您已从上面下载了软件包并将其解压缩到 ipfssite 目录:
$ ls ipfssite/
css images index.html js
为了发布它,您需要在节点上启动守护程序。之后,您可以运行以下命令来部署它:
$ ipfs add -r ipfssite
added QmNrgEMcUygbKzZeZgYFosdd27VE9KnWbyUD73bKZJ3bGi ipfssite/css/bootstrap.min.css
added QmToWAMXJFSi2s22JqfmajL4WPJZJdnzJtzSV1TaUdkFLp ipfssite/css/styles.css
added QmSyc5sQa4smKUvNaZtr6y44et5gVgzsf4RaWD7tu1PgCk ipfssite/images/ipfs-logo.svg
added QmamZxnEKaAwdLEoCtC7w4jwaVuR7ztb1cLayDQGM9DVci ipfssite/index.html
added QmZqVNydZxRrioxHwMxCa5CQs7yRLPqnKUexuyrTkJhBwa ipfssite/js/bootstrap.min.js
added QmWirprJ5C4m1rVmEKS1Wf3WBviqpoFgp64QvWACsa7wC8 ipfssite/js/jquery-3.3.1.slim.min.js
added QmPNoejVoMRayPqLzsKzYNLh8p5yGKyA5PBFJ3sw2xLDM3 ipfssite/js/popper.min.js
added QmbkVCDQ95ypMH8VWHACsCyZPxerwRrpfXZ5y3TDBGS3Rd ipfssite/css
added QmWJP6sa19yUjco7YXCVyqXoeX2L4378yzcTJWYxZWoMK3 ipfssite/images
added QmcZSAjXfTdciMAS9zjLjWcmRRcF3QTnBTqM66zzKCQAT1 ipfssite/js
added Qmf2EuEZJXUtwuMRALgTsN6xsDQy5g8s4H5BQKLvMYE2dV ipfssite
301.28 KiB / 301.28 KiB
[=============================================] 100.00%
最后一个哈希(用于目录本身)是您必须记住的。之后,您可以通过以下网址访问网站(输入上面收到的哈希):
http:// localhost:8080 / ipfs /Qmf2EuEZJXUtwuMRALgTsN6xsDQy5g8s4H5BQKLvMYE2dV
https://ipfs.io/ipfs/Qmf2EuEZJXUtwuMRALgTsN6xsDQy5g8s4H5BQKLvMYE2dV
请耐心等待最后一个网址,首次打开它可能需要一些时间。
我们不要在这里停下来,使其更加友好,毕竟很难通过短信发送这样的哈希值或者很难记住。
为此,您将需要您的域名。转到域名管理,并创建TXT类型的注意DNS记录以将其连接到您的网站。就我而言,我需要创建以下记录(再次,不要忘记更新到您在先前步骤中获得的哈希值):
dnslink=/ipfs/Qmf2EuEZJXUtwuMRALgTsN6xsDQy5g8s4H5BQKLvMYE2dV
dig +noall +answer TXT [your-domain-name]
[your-domain-name]. 60 IN TXT
“dnslink=/ipfs/Qmf2EuEZJXUtwuMRALgTsN6xsDQy5g8s4H5BQKLvMYE2dV”
一段时间后,DNS记录将通过世界上的DNS服务器进行更新,您将可以使用以下方式访问您的站点:
http:// localhost:8080 / ipns / [您的域名]
http://gateway.ipfs.io/ipns/ [您的域名]
非常感谢您对 IPFS&Filecoin 项目的持续支持。我们很高兴继续与您一起,为人类信息建立一个强大的,去中心化和高效的基础。
FilCloud 帮你迅速了解 IPFS 领域的热点技术和应用