Skip to content

Latest commit

 

History

History
65 lines (43 loc) · 2.79 KB

README.md

File metadata and controls

65 lines (43 loc) · 2.79 KB

Gentoo-distfiles-IPFS Mirror

Note this is still work in progress!

Scripts for syncing Gentoo distfiles, adding to IPFS and maintaining publishes to IPNS

Using as a mirror

The intention of this is to use IPFS as a mirror for distfiles as described at https://www.gentoo.org/downloads/mirrors/

  • Add GENTOO_MIRRORS="https://ipfs.io/ipns/gentoo.free.netboot.se $GENTOO_MIRRORS" in /etc/portage/make.conf fallbacks are keept just in case
  • Enjoy immutable and distributed updates to your system!

There are a few ways you can use the IPFS Gentoo mirror.

Recommend to use DNS via IPNS for now, until performance issues with IPNS has been resolved.

Usage with local daemon

To get the most benefit of IPFS when downloading packages, you should be running a local go-ipfs node. Once you have it up and running, you can replace ipfs.io with localhost:8080 and everything should work the same, except you get better caching and you help rehost the packages you download.

Mount IPFS and locate files via fuse

This would avoid duplicate files and remove need for portage to download anything - but have not been tested yet

Hosting your own mirror

Requirements

  • go-ipfs version 0.4.14 or later (tested with 0.4.16)
  • about 500GB of diskspace (real usage will be around ~390GB but good with a buffer)
    • This diskspace requirement only applies if you want to host your own mirror, not if you're using a existing one

Setup

Want to setup your own IPFS mirror? It's easy, just follow these steps:

  • Edit ./sync-gentoo-distfiles.sh to make sure mirror and other things is set appropiately.
  • Run ./sync-gentoo-distfiles.sh which downloads the latest distfiles to ./gentoo-distfiles.
  • Add to crontab 10 */4 * * * sh /home/distfiles/sync-gentoo-distfiles.sh &
  • If dnsupdate.sh exists and is executable then it will be called with $1 being dnslink=/ipfs/$HASH Use to update a DNS record like: _dnslink 60 TXT $1, which would result in _dnslink 60 TXT dnslink=/ipfs/$HASH

TODO write more details here

Findings

License

MIT 2018 - Christian Nilsson Based on work by Victor Bjelkholm