溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Kubernetes中如何通過(guò)python api訪問(wèn)IPFS服務(wù)

發(fā)布時(shí)間:2021-12-04 18:00:52 來(lái)源:億速云 閱讀:241 作者:柒染 欄目:互聯(lián)網(wǎng)科技

本篇文章給大家分享的是有關(guān)Kubernetes中如何通過(guò)python api訪問(wèn)IPFS服務(wù),小編覺(jué)得挺實(shí)用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話不多說(shuō),跟著小編一起來(lái)看看吧。

IPFS是一個(gè)分布式的全球一致性(參見 HT與分布式一致性 )文件系統(tǒng),結(jié)合了BT、P2P、DHT等的優(yōu)勢(shì)。之前的帖子中,介紹了將IPFS部署到Kubernetes集群,以及通過(guò)portforward開放IPFS服務(wù)的方法。目前IPFS已經(jīng)提供了python api,可以訪問(wèn)集群中的IPFS服務(wù)。

基礎(chǔ)服務(wù)準(zhǔn)備

  • 通過(guò)Helm在Kubernetes集群上安裝IPFS。

  • IPFS在Kubernetes部署的服務(wù)開放。

  • IPFS服務(wù)的Python訪問(wèn)。

  • IPFS的Python API參考手冊(cè)。

安裝ipfsapi庫(kù)

pip install ipfsapi

訪問(wèn)IPFS服務(wù)

# 引用ipfsapi
import ipfsapi

# 連接到IPFS管理服務(wù)

# 如果是集群外運(yùn)行,但與集群在同一臺(tái)主機(jī)。
# api為返回的客戶端對(duì)象,可以使用help(api)查看其接口。
# api = ipfsapi.connect('127.0.0.1', 5001)

# 如果是在集群的pod運(yùn)行,使用內(nèi)部域名訪問(wèn)服務(wù)。
# 我在Kubernetes中的Jupyter上運(yùn)行,連接成功。
api = ipfsapi.connect('ipfs2-ipfs.ipfs2', 5001)

# 獲取peers的列表。
# api.swarm_peers()返回Dict對(duì)象,Key為Peers,value為列表。
PeerList = api.swarm_peers()["Peers"]

# 顯示Peers的總數(shù),會(huì)根據(jù)網(wǎng)絡(luò)隨時(shí)變化。
len(PeerList)

# 顯示全部Peer的列表。
print(PeerList)

顯示部分Peers的信息:

for i in range(3):
    print(PeerList[i])

輸出如下:

{'Addr': '/ip4/1.24.210.4/tcp/4001', 'Peer': 'QmZgbW9VNA4EJoxuReUmXZNszHqurheeqNQvZ671kdbYLg', 'Latency': '', 'Muxer': '', 'Streams': None}
{'Addr': '/ip4/100.34.210.63/tcp/39733', 'Peer': 'QmPRa5sovWPGhSDuEGU2cgfws5ra91bD89xTWmArJxickp', 'Latency': '', 'Muxer': '', 'Streams': None}
{'Addr': '/ip4/100.38.242.117/tcp/10238', 'Peer': 'QmXdgmKZYNmybYY33J7UFTuqFdvndEbWY2PdDcHuteqvyj', 'Latency': '', 'Muxer': '', 'Streams': None}

可以通過(guò)上面的方式查看IPFS支持的各種信息,包括添加文件、下載文件等等。

調(diào)試完成后,可以寫入腳本,進(jìn)一步放到定期任務(wù)中調(diào)度執(zhí)行。

以上就是Kubernetes中如何通過(guò)python api訪問(wèn)IPFS服務(wù),小編相信有部分知識(shí)點(diǎn)可能是我們?nèi)粘9ぷ鲿?huì)見到或用到的。希望你能通過(guò)這篇文章學(xué)到更多知識(shí)。更多詳情敬請(qǐng)關(guān)注億速云行業(yè)資訊頻道。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI