IPFS:从零到分布式网站

分散站点的关键在于分散地托管它们,这就是 IPFS 发挥作用的地方。让我们稍微熟悉一下 IPFS 以及如何使用它来托管网站!

什么是 IPFS?

星际文件系统(IPFS)是一种协议和点对点网络,用于在分布式文件系统中存储和共享数据。
它与 Torrent 所做的非常相似,但是除了接收允许它托管的内容外。一切都是分布式的。
但是 interplanetary staff?非常简单,这背后的想法是使互联网连接成为可能,即使你非常遥远。它允许你从附近的某个人检索文件,而不是从几千公里或几百万公里以外的某个地方,比如其他星球获取文件。然而,这是这个项目理想的目标。
目前,它还有两个附加的优点(除了加快从遥远的数据中心获取文件的优点):
  • 它使互联网更具弹性,即使主节点关闭,您的用户也可以从其他地方获取您的网页。
  • 审查内容变得更加困难,没有任何地方可以影响和阻止您的内容。

安装 IPFS

要首先在计算机上安装 IPFS,您需要下载适用于您的操作系统和平台的发行包。按照官方发行页面查找适合您的软件包。下载并找到安装包后,请遵循以下操作系统特定的部分:
MacOS 或 Linux
解压您的包裹:

					
$ 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/ [您的域名]
End
非常感谢您对 IPFS&Filecoin 项目的持续支持。我们很高兴继续与您一起,为人类信息建立一个强大的,去中心化和高效的基础。
FilCloud 帮你迅速了解 IPFS 领域的热点技术和应用
公众号:filcloud

24小时热点

热点专题

Gem和Genie功能大对比

2022年4月25日,OpenSea官方发推宣布收购NFT交 ...

2397889

TopHolder 头号藏家

Genie 就是一个 NFT 市场的交易聚合器

Web3 中的「聚合器」是一个非常重要的组件,例如 1inc ...

2363077

嗨艺购

一个pi币现在值多少人民币?pi币2024年可以交易吗?

近年来,加密货币市场迅速发展,各种新型数字资产层出不穷。其中 ...

1625055

Alameda Research

USDT是什么币?新手如何购买和交易?

USDT是什么币?新手如何购买和交易?USDT是什么?USD ...

1301292

Cosmos Art

2024年pi币多少钱一个?介绍pi币历年价格

Pi币是一种新兴的数字货币,它的概念于2019年由一位斯坦福 ...

1287487

Alameda Research

CORE未来能涨到多少钱?core2024大约能涨到多少钱?

在数字货币市场中,CORE 作为一种加密货币,在过去的一段时 ...

878479

BitKeep钱包

欧科集团设立1000万元疫情防治专项基金 联合中华慈善总会共同支援一线防护工作

这个春节,新型冠状病毒疫情牵动着大家的心。1月26日0—24 ...

832338

TokenInsight

举报:PAXG币 (PAX Gold)涉嫌违法?

PAXG币(PAX Gold)是一种基于以太坊区块链网络创建 ...

780914

NewsBTC

什么是Polygon(Matic)网络?

由于网络拥堵仍然是以太坊区块链的一个问题,像Polygon这 ...

774002

树图链

ZT交易所介绍

ZT交易所介绍 ZT是为全球用户提供最优质数字资 ...

759409

ZT GLOBAL 交易所