This repository contains Ansible roles to install and run
go-ipfs and
IPFS Cluster.
They include a Systemd service file both.
If you are familiar with Ansible, you can just re-use the modules in the way that fits you best. Otherwise follow these steps:
- Make sure you have ansible installed:
pip install ansible. - Fill in
inventory.ymland place the hostnames of your nodes under the[ipfs]group. - Edit the
group_vars/ipfs.ymlandgroup_vars/ipfs_cluster.ymlfile setting the right configuration values, including generating an IPFS Cluster secret withod -vN 32 -An -tx1 /dev/urandom | tr -d ' \n' ; echo - Add a file for each hostname (filename is the hostname), to the
host_varsfolder as outlined inhost_vars/README.md, containing the necessary host-specific variables (example in thehost_varsREADME). - Run
make.
make will run ansible for the ipfs and the ipfs-cluster roles, which
apply to the [ipfs] and [ipfs_cluster] inventory group. Upon successful,
both go-ipfs and ipfs-cluster should be running in the nodes (they are
installed under /usr/local/bin and run by a created ipfs system user).
You can use systemctl status ipfs and systemctl status ipfs-cluster to
check the status of the new services.
Note that ipfs configuration has been generated using profile=server, thus
will not automatically scan the local network.