巨爆乳肉感一区二区三区视频动漫-67194线路一直接进入骚逼-亚洲精品无码一区二区三区四虎-亚洲国产精品有码-国产精品99无码一区二区视频-免费观看A黄色

Outlier Ventures:如何用Arweave去中心化托管網站前端

訪客 2年前 (2023-12-15) 閱讀數 417 #區塊鏈
文章標簽 快訊

作者:Lorenzo Sicilia,Outlier Ventures;翻譯:0xxz@喜來順財經

盡管 Web3 涉及無需許可和可驗證性,但仍有太多項目擁有使用 AWS、GCP、Vercel、Netlify 等托管式的完全中心化前端。

這些平臺因其出色的開發者體驗和合理的成本而成為最受開發者歡迎的工具。部署完全去中心化的應用程序并不簡單,工具也不成熟。?

在本文中,我們描述了如何輕松部署和托管完全去中心化的前端——只需一次性支付 0.003 美元即可購買約 1MB 的資產。

在 Outlier Ventures 產品和工程團隊中,我們花了很多時間討論和思考有助于塑造我們去中心化未來的新技術。你可以查看我們的 Web3 技術雷達。?

除了花時間幫助我們的投資組合公司做出正確的技術選擇之外,我們還自己構建應用程序 - 例如,Scott Canning 最近在 NEAR 上構建的去中心化融資平臺項目。

我們決定在 Web3 堆棧上構建更多內容,并在此過程中撰寫許多不同的設計選擇,并在一系列博客文章中記錄我們的發現。??在本文中,我們將關注 DePIN,特別是去中心化存儲的主題。

各種 DePIN(去中心化物理基礎設施網絡)允許開發人員利用像AWS、谷歌云、Azure 等提供的同類服務,但以真正去中心化的方式。擁有閑置計算能力的參與者會被激勵將其資源貢獻給一個有效的云計算平臺,該平臺沒有中介機構,也沒有總體的中心控制點或故障。

這篇文章解釋了:

DePIN和去中心化存儲的挑戰

我們如何解決托管挑戰

我們做出的技術選擇

Arweave 基礎知識

arweave-bundle 簡介,這是一個直接從 CI/CD 部署去中心化前端的庫。

去中心化存儲的挑戰

如果前端中心化托管,那么 DApp 就不是真正去中心化的。如果網站前端不能登錄或包含漏洞或更糟糕如第三方破壞網站,用戶對它們缺乏信心,那么擁有無需許可合約有什么好處?

當后端和前端都完全透明時,人們經常重復的 “Don’t trust, verify”才會變得更有意義。

決定托管解決方案

評估在何處托管 dApp 時需要牢記的一些驗收標準:

1、確保不可篡改性和可訪問性:允許跟蹤公共基礎設施上已部署文件的版本控制,dApp 應該是“不可停止的(unstoppable)”。

2、易于部署:易于發布新內容并能夠與 CI/CD 集成。

3、成本:盡可能便宜

4、加密支付:一種我們可以使用代幣支付而不必被迫退回到法幣通道的服務

定義了這些要求后,我們確定了一些可用的選項:?

IPFS(使用我們托管的節點)

IPFS(使用第三方提供商)

Filecoin

Storj

Arweave

出于我們 dApp 的目的,我們決定盡量減少對 Pi?ata、Web3.storage 或 Infura 等任何第三方解決方案的依賴。雖然它們在易于部署等方面帶來了許多優勢,但它們需要 API 密鑰,我們將其視為單點故障和控制風險。只要有 API 密鑰,就無法保證不可篡改性和可達性。?

不可避免地存在權衡。在 Outlier,我們經常采用 IPFS 來托管靜態內容。我們甚至討論了托管我們自己的 IPFS 節點。這將為最終用戶提供驗證特定部署是否與已部署的代碼包的 CID 相匹配的機會,并且我們可以利用 IPNS 和 IPFS 以及 ENS 來允許可變的 IPFS CID 指針更新網站內容并通過 HTTPS 啟用域名解析時。

然而,由于 IPFS 本身不是一個激勵網絡,因此將 dApp 固定到我們自己的節點可能會造成單點故障,這是我們嚴格試圖避免的。

我們研究了 IPFS 固定解決方案,例如https://web3.storage/,它提供了出色的開發人員體驗,但最終它是一個中心化解決方案,因為它基于他們持有的密鑰,并且允許他們隨時撤銷服務時間。這是一項有用的服務,但在這種情況下,我們決定它不會為我們提供我們所追求的完全去中心化的體驗。

出于同樣的原因,另一個解決方案https://filebase.com/被排除。

接下來,我們考慮了 Filecoin,它在 IPFS 之上提供了一個層,并激勵提供商通過將內容固定到 IPFS 節點來提供存儲空間。以 Filecoin 向提供商支付費用,并且由于 IPFS 和 Filecoin 都是由 Protocol Labs 開發的,因此這是一種流暢且連貫的體驗。??如果不是他們的商業模式取決于交易,我們可能會選擇 Filecoin 。作為開發人員,我們不需要持續考慮向誰付款以及支付多少錢,因此對于我們的特定用例,我們也排除了 Filecoin。

我們的第三個選擇 Arweave 為我們提供了技術權衡,但最終是我們選擇的解決方案。雖然每次上傳的成本很低——每次大約 0.003 美元,而且該網絡已經存在五年了,但工具和資源比 Filecoin 和 IPFS 生態系統中的要少,因此我們必須解決一些有趣的挑戰——包括開發我們的自己的庫,用于直接從我們的 CI/CD 捆綁和上傳。??

Bzq5Vqn40dTHNi0Bavl7T1e8wyVY8a08xg1Tq1dM.png

Arweave 工具

你可以在這里按照我們的步驟熟悉如何將內容上傳到 Arweave(又名 Permaweb)。??

首先,我們熟悉了基礎知識。在我們決定構建一個簡單的 React 應用程序后,我們的第一站是https://cookbook.arweave.dev/,在那里我們找到了大量用于將數據上傳到 Arweave 的有用資源,包括部署應用程序。

先決條件?

你需要安裝 Node,以及 npx 和 pnpm。你還需要一個交易所帳戶,可以在其中購買一些用于部署的 AR。我們使用 Arweave 的主網而不是測試網,因為它足夠便宜,可以進行實驗。

第一步是創建一個 Arwave 錢包并用一些 AR 為其提供資金。有趣的是,最簡單的方法是通過 CEX。

檢查資金是否已到達你的地址:https: //viewblock.io/arweave

創建你的錢包:

$ mkdir upload-arweave

$ pnpm install arweave?

$ node -e "require('arweave').init({}).wallets.generate().then(JSON.stringify).then(console.log.bind(console)) > wallet.json

現在你有了一個 wallet.json,其中包含你的私鑰和公鑰。通過運行查找地址:

npx arweave-bundler address

你需要提供少量 AR 資金。有趣的是,最簡單的方法是通過 CEX。

檢查資金是否已到達你的地址:https: //viewblock.io/arweave

之后,你可以開始編寫幾行代碼來部署某些內容。

Arweave Hello World

首先創建一個簡單的網絡應用程序。今天最簡單的就是`pnpm create vite`并選擇最適合你的默認值。

然后查看https://cookbook.arweave.dev/,你可以在其中找到大量用于將數據(包括部署應用程序)上傳到 Arweave 的有用資源,或者繼續瀏覽博客文章以獲取好的方法。

創建一個名為 ar-deploy.js 的文件并粘貼以下內容:

import Arweave from "arweave";?

import fs from "fs";?

// load the JWK wallet key file from disk?

const jwk = JSON.parse(fs.readFileSync('./wallet.json').toString());?

// initialize arweave?

const arweave = Arweave.init({ host: "arweave.net", port: 443, protocol: "https", });?

const tx = await arweave.createTransaction( { data: "Hello world!", }, jwk );?

await arweave.transactions.sign(tx, jwk);?

arweave.transactions.post(tx).then(console.log).catch(console.log); console.log(`https://arweave.net/${tx.id}`);

使用“node ar-deploy.js”運行它……你剛剛將第一個內容部署到了 Permaweb!?這很好,但還不夠有用。?

上傳一個文件

下一步是上傳實際文件而不是字符串。為此,你需要處理標簽。網關需要知道它正在提供什么類型的數據(例如圖像/png)。

import Arweave from 'arweave';?

import fs from "fs"; // load the JWK wallet key file from disk?

let key = JSON.parse(fs.readFileSync("walletFile.txt").toString());?

// initialize an arweave instance?

const arweave = Arweave.init({});?

// load the data from disk?

const imageData = fs.readFileSync(`iamges/myImage.png`);?

// create a data transaction?

let transaction = await arweave.createTransaction({ data: imageData }, key);?

// add a custom tag that tells the gateway how to serve this data to a browser?

transaction.addTag('Content-Type', 'image/png');?

// you must sign the transaction with your key before posting?

await arweave.transactions.sign(transaction, key);?

// create an uploader that will seed your data to the network?

let uploader = await arweave.transactions.getUploader(transaction);?

// run the uploader until it completes the upload.?

while (!uploader.isComplete) { await uploader.uploadChunk(); }

上傳多個文件

事情開始變得有趣,但在遍歷目錄并將所有文件發布到 Permaweb 之前,還有最后一個概念需要掌握:理解清單的概念。

將文件上傳到 Arweave 時,每個文件都會分配自己唯一的交易 ID。默認情況下,這些 ID 不以任何特定方式分組或組織。

因此,清單是一個 JSON 文件,其中包含一組文件的所有 ID。它還包含一個索引屬性,該屬性指向指向任何交易 ID 的別名。

{ "manifest": "arweave/paths",?

? "version": "0.1.0",?

? "index": { "path": "index.html" },?

? "paths": { "index.html": { "id": "cG7Hdi_iTQPoEYgQJFqJ8NMpN4KoZ-vH_j7pG4iP7NI" }, "js/style.css": { "id": "fZ4d7bkCAUiXSfo3zFsPiQvpLVKVtXUKB6kiLNt2XVQ" }, "css/style.css": { "id": "fZ4d7bkCAUiXSfo3zFsPiQvpLVKVtXUKB6kiLNt2XVQ" }, "css/mobile.css": { "id": "fZ4d7bkCAUiXSfo3zFsPiQvpLVKVtXUKB6kiLNt2XVQ" }, "assets/img/logo.png": { "id": "QYWh-QsozsYu2wor0ZygI5Zoa_fRYFc8_X1RkYmw_fU" }, "assets/img/icon.png": { "id": "0543SMRGYuGKTaqLzmpOyK4AxAB96Fra2guHzYxjRGo" } } }

Arweave 交易很便宜,但創建如此多的交易遠非理想,特別是當網絡擁塞時。?

雖然此解決方案可行,但它不是最佳方案,因此我們轉向下一個解決方案:Arweave bundles ( ANS-104 )

Arweave bundles

交易捆綁是一種特殊類型的 Arweave 交易。它允許將多個其他交易和/或數據項捆綁在其中。由于交易包里含有許多嵌套交易,因此它們是 Arweave 能夠擴展到每秒數千個交易的關鍵。?

我們的主要要求是能夠將文件和資產捆綁在一起,以便我們可以在構建應用程序后以原子方式上傳,從而擁有正確版本的 dApp,而不是零散地上傳單個文件。這也具有成本優勢,因為這意味著我們只需為上傳付費一次。

我們考慮使用 Iris(以前稱為 Bundlr),它具有良好的開發人員體驗,包括允許使用許多代幣進行支付,支持不同的鏈并允許在 Arweave 和其他我們沒有的功能之上增加了一層額外的費用需要。?

你可以利用名為arbundles 的開源庫并添加一些粘合功能,從而在不使用 Irys 服務的情況下利用捆綁功能。

import { bundleAndSignData, createData } from "arbundles";?

const dataItems = [createData("some data"), createData("some other data")];

const signer = new ArweaveSigner(jwk);?

const bundle = await bundleAndSignData(dataItems, signer);

我們的 Arweave 實用程序:arweave-bundler

我們決定創建自己的 Arweave 實用程序,以便直接在 CI/CD 中利用捆綁功能,并使步驟始終可重復。?

在 Arweave Bundler 的公共存儲庫中,你將找到一個 GitHub Action 和 CLI,用于從目錄上傳靜態資產,這非常適合將單頁應用程序 (Single Page App,SPA) 或其他靜態內容發布到 Arweave。?

如果你想使用GitHub Action,配置如下:

uses: outlierventures/arweave-bundler-action@v0.3.1?

with: directory: build/?

private-key: ${secret.ARWEAVE_PRIVATE_KEY}?

dry-run: false network: arweave.net

確保將私鑰添加到存儲庫的 GitHub Secrets 中。如果你希望使用 CLI,請按照以下步驟捆綁和部署你的 Web 應用程序:

npx arweave-bundler upload build/ --private-key ${PRIVATE_KEY}

始終確保你的私鑰存儲為環境變量。

結論

Arweave 提供了一種廉價且便捷的方式來永久存儲 Web 應用程序前端,證明去中心化存儲比中心化存儲更便宜。另一方面,雖然中心化存儲提供商擁有經過驗證的商業模式,但我們需要等待 Arweave 模型是否能夠通過時間的考驗。主要挑戰是激勵調整,即費用。在一個沒有租金且只收取一次性費用的系統中,如果節點不再獲得足夠的獎勵,它們可能會決定離開。

雖然這個發現過程中最復雜的部分是在無法訪問大量文檔或示例的情況下找到我們的方法,但我們最終找到了一個有彈性的解決方案,我們希望其他開發人員能夠從使用 arweave-bundler 簡化其部署過程中受益。

我們的下一個任務是研究去中心化的域名管理。我們的下一篇文章將重點關注實施 ENS 和 ANT(Arweave 名稱代幣)所涉及的挑戰和決 策。

熱門
国内揄拍国内精品久久| 午夜精品久久久久久久久久蜜桃| 人人狠狠综合久久亚洲婷婷 | 综合中文字幕| 伊人精品在线| 久久亚洲精品爱爱| 久久99国内| 狠狠色丁香久久综合频道| 四虎4545www国产精品 | 综合激情网...| 免费看日韩精品| 日本欧美加勒比视频| 欧洲亚洲成人| 最近高清中文在线字幕在线观看1| 亚洲无中文字幕| 亚洲特色特黄| 日韩国产91| 久久国产精品免费精品3p | 在线国产日韩| 欧美午夜不卡| 狠狠干综合网| 国产一区二区三区成人欧美日韩在线观看 | 伊人亚洲精品| 婷婷综合激情| 青草国产精品久久久久久| 久久久久综合| 欧美日韩卡一| 99tv成人| 久久精品久久99精品久久| 青青一区二区| 成人在线不卡| 欧美成人一区在线观看| 成人国产精选| 久久精品欧美一区| 成人高清一区| 久久中文字幕av一区二区不卡| 国产原创一区| 欧美精品一二| 捆绑调教一区二区三区| 伊人天天综合| 国产成人一区| 欧美gayvideo| 国产精品22p| 日本电影久久久| 精品国产成人| 玖玖精品在线| 一本久道综合久久精品| 伊人久久一区| 日韩av自拍| 亚洲天天综合| 99re8精品视频在线观看| 羞羞答答成人影院www| 亚洲三级毛片| 先锋亚洲精品| 精品国产一区二区三区性色av| 亚洲欧美小说色综合小说一区| 红杏一区二区三区| 欧美v亚洲v综合v国产v仙踪林| 成人a'v在线播放| 国产激情综合| 日韩国产一区二区三区| 欧美日韩中文一区二区| 欧美激情1区2区| caoporn视频在线观看| 精品视频黄色| 91视频亚洲| 欧美不卡高清一区二区三区 | 草民电影神马电影一区二区| 国产国产精品| 国产日韩一区二区三免费高清| 成人在线免费电影网站| 99成人在线| 禁断一区二区三区在线| 亚洲色图网站| 日韩精品1区| 午夜久久久久| 精品国产一区二区三区2021| 久久精品久久99精品久久| 视频在线观看国产精品| 97精品久久| 国内自拍一区| 91天天综合| 免播放器亚洲| 伊人春色精品| 亚洲国产欧美在线观看| 国产精品成人一区二区网站软件| 欧美激情欧美| 91成人影院| 欧美日韩网站| 国产亚洲字幕| 国产欧美亚洲一区| 日韩美女一区二区三区在线观看| 伊人成人在线| 精品久久中文| 亚洲人成网www| 影音先锋中文字幕一区二区| 欧美视频免费看| 日本一区二区在线看| 在线精品国产| 久久久成人网| 三级欧美日韩| 亚洲老女人视频免费| 亚洲区第一页| 羞羞视频在线观看一区二区| 性色一区二区三区| 婷婷综合在线| 天天久久夜夜| 国产成人福利av| 日韩av中文在线观看| 欧美精品影院| 国产精品v日韩精品v欧美精品网站| 亚洲国产伊人| 成人在线视频免费| 婷婷六月国产精品久久不卡| 大桥未久在线视频| 日韩影院在线观看| 国产亚洲激情| 免费看的黄色欧美网站| 最新日韩在线| 黑丝一区二区三区| 久久精品国产www456c0m| 精品视频高潮| 久久97久久97精品免视看秋霞| aaa国产精品视频| 久久天堂久久| 免费观看性欧美大片无片| 国产乱码精品一区二区亚洲 | 欧美韩一区二区| 91麻豆精品激情在线观看最新| 亚洲黄色录像| 亚洲+变态+欧美+另类+精品| 亚洲最新色图| 亚洲第一论坛sis| 久久久国产精品入口麻豆| 伊人久久亚洲| aaa国产精品视频| 国产精品极品| 欧美色图一区| 欧美军人男男激情gay| 亚洲国产一成人久久精品| 亚洲精品极品少妇16p| 伊人久久综合| 四季av在线一区二区三区| 日韩精品诱惑一区?区三区| 九九精品调教| 亚洲高清在线| 中文字幕免费一区二区三区| 国产精品**亚洲精品| 日韩福利视频一区| 北条麻妃一区二区三区在线| 女一区二区三区| 1024精品久久久久久久久| 美女国产精品| 日韩一区欧美| 国产欧美一区二区三区国产幕精品| 麻豆精品久久久| 日韩欧美影院| 91精品婷婷色在线观看| 99视频精品免费观看| 蜜臀久久99精品久久久画质超高清 | 美女久久精品| 免费观看久久av| 噜噜噜在线观看免费视频日韩| 国产调教在线| 国产精品夜夜夜| 偷窥自拍亚洲色图精选| 97se亚洲| 国产视频久久| 欧美国产日韩电影| 亚洲字幕久久| 国产欧美自拍一区| 一区久久精品| 欧美日韩va| 国产亚洲电影| 久久综合国产| 免费不卡在线观看| 肉色丝袜一区二区| 视频在线一区| 国产精品日韩精品欧美精品| 日韩高清成人| 亚洲欧美在线综合| 99久久久久| 中国字幕a在线看韩国电影| 久久一区精品| 国产精品22p| 成人激情电影在线| 亚洲精品影视| 成人免费电影网址| 91偷拍一区二区三区精品| 亚洲精选国产| 欧美色图婷婷| 国产欧洲在线| 国模大尺度视频一区二区| 99热国内精品永久免费观看| 四虎国产精品免费观看| 国产一区二区三区的电影 | 久久久久久久欧美精品 | 99久久99热这里只有精品| 97精品国产一区二区三区 | 欧美大片aaaa|