2023-09-11 22:21:40 +02:00
# Install and run a Veilid Node
2023-08-01 21:37:38 -05:00
## Server Grade Headless Nodes
2023-08-18 21:33:58 +00:00
These network support nodes are heavier than the node a user would establish on their phone in the form of a chat or social media application. A cloud based virtual private server (VPS), such as Digital Ocean Droplets or AWS EC2, with high bandwidth, processing resources, and uptime availability is crucial for building the fast, secure, and private routing that Veilid is built to provide.
2023-09-12 16:19:14 +02:00
## Install
2023-08-18 09:34:58 -04:00
2023-09-12 16:19:14 +02:00
### Debian
Follow the steps here to add the repo to a Debian based system and install Veilid.
2023-08-18 21:33:58 +00:00
2023-09-15 22:38:32 +02:00
**Step 1**: Add the GPG keys to your operating systems keyring.< br / >
2023-08-18 09:34:58 -04:00
*Explanation*: The `wget` command downloads the public key, and the `sudo gpg` command adds the public key to the keyring.
2023-09-12 08:43:09 -05:00
2023-08-18 21:33:58 +00:00
```shell
2023-08-01 21:37:38 -05:00
wget -O- https://packages.veilid.net/gpg/veilid-packages-key.public | sudo gpg --dearmor -o /usr/share/keyrings/veilid-packages-keyring.gpg
```
2023-09-12 08:43:09 -05:00
2023-09-12 16:19:14 +02:00
**Step 2**: Identify your architecture< br / >
2023-08-18 09:34:58 -04:00
*Explanation*: The following command will tell you what type of CPU your system is running
2023-09-12 08:43:09 -05:00
2023-08-18 09:34:58 -04:00
```shell
dpkg --print-architecture
```
2023-09-12 16:19:14 +02:00
**Step 3**: Add Veilid to your list of available software.< br / >
*Explanation*: Use the result of your command in **Step 2** and run **one** of the following:
2023-08-18 09:34:58 -04:00
2024-07-17 11:17:54 -05:00
- For *STABLE* releases
- **AMD64** based systems run this command:
2023-09-12 08:43:09 -05:00
2023-09-12 16:19:14 +02:00
```shell
echo "deb [arch=amd64 signed-by=/usr/share/keyrings/veilid-packages-keyring.gpg] https://packages.veilid.net/apt stable main" | sudo tee /etc/apt/sources.list.d/veilid.list 1>/dev/null
```
2023-09-12 08:43:09 -05:00
2024-07-17 11:17:54 -05:00
- **ARM64** based systems run this command:
2023-09-12 08:43:09 -05:00
2023-09-12 16:19:14 +02:00
```shell
echo "deb [arch=arm64 signed-by=/usr/share/keyrings/veilid-packages-keyring.gpg] https://packages.veilid.net/apt stable main" | sudo tee /etc/apt/sources.list.d/veilid.list 1>/dev/null
```
2024-07-19 14:08:25 -05:00
2024-07-17 11:17:54 -05:00
- For *NIGHTLY* (bleeding edge) releases
- **AMD64** based systems run this command:
```shell
echo "deb [arch=amd64 signed-by=/usr/share/keyrings/veilid-packages-keyring.gpg] https://packages.veilid.net/apt nightly main" | sudo tee /etc/apt/sources.list.d/veilid.list 1>/dev/null
```
- **ARM64** based systems run this command:
```shell
echo "deb [arch=arm64 signed-by=/usr/share/keyrings/veilid-packages-keyring.gpg] https://packages.veilid.net/apt nightly main" | sudo tee /etc/apt/sources.list.d/veilid.list 1>/dev/null
```
2023-09-12 08:43:09 -05:00
2023-08-18 09:34:58 -04:00
*Explanation*:
2023-08-18 21:33:58 +00:00
Each of the above commands will create a new file called `veilid.list` in the `/etc/apt/sources.list.d/` . This file contains instructions that tell the operating system where to download Veilid.
2023-08-18 09:34:58 -04:00
2023-09-12 16:19:14 +02:00
**Step 4**: Refresh the package manager.< br / >
*Explanation*: This tells the `apt` package manager to rebuild the list of available software using the files in `/etc/apt/sources.list.d/` directory.
2023-09-12 08:43:09 -05:00
2023-08-01 21:37:38 -05:00
```shell
2023-08-24 17:41:35 +00:00
sudo apt update
2023-08-01 21:37:38 -05:00
```
2023-08-18 09:34:58 -04:00
2023-09-12 08:43:09 -05:00
**Step 5**: Install Veilid.
2023-08-01 21:37:38 -05:00
```shell
2023-08-24 17:41:35 +00:00
sudo apt install veilid-server veilid-cli
2023-08-01 21:37:38 -05:00
```
2023-08-18 09:34:58 -04:00
2024-08-04 16:59:44 +00:00
**Step 6**: Start veilid-server.service
2024-07-19 14:08:25 -05:00
Go to [Start headless node ](#start-headless-node )
2024-08-04 16:59:44 +00:00
**Step 7**: View Node Activity
2024-07-19 14:08:25 -05:00
Invoke the Veilid CLI utility.
2024-08-02 23:29:12 +00:00
Either add your user to the _veilid_ group and invoke the command
2024-07-19 14:08:25 -05:00
```shell
veilid-cli
```
2024-08-02 23:29:12 +00:00
Or use _sudo_ to invoke as the _veilid_ user
```shell
sudo -u veilid veilid-cli
```
2024-07-19 14:08:25 -05:00
2023-09-12 16:19:14 +02:00
### RPM-based
Follow the steps here to add the repo to
RPM-based systems (CentOS, Rocky Linux, AlmaLinux, Fedora, etc.)
and install Veilid.
2023-09-12 08:43:09 -05:00
**Step 1**: Add Veilid to your list of available software.
2024-07-19 14:08:25 -05:00
- For *STABLE* releases
2023-08-01 21:37:38 -05:00
```shell
2024-07-19 14:08:25 -05:00
sudo dnf config-manager --add-repo https://packages.veilid.net/rpm/stable/x86_64/veilid-stable-x86_64-rpm.repo
2023-09-12 16:19:14 +02:00
```
2024-07-19 14:08:25 -05:00
- For *NIGHTLY* (bleeding edge) releases
```shell
sudo dnf config-manager --add-repo https://packages.veilid.net/rpm/nightly/x86_64/veilid-nightly-x86_64-rpm.repo
```
2023-09-12 16:19:14 +02:00
**Step 2**: Install Veilid.
```shell
sudo dnf install veilid-server veilid-cli
2023-08-01 21:37:38 -05:00
```
2023-09-12 08:43:09 -05:00
2024-08-04 16:59:44 +00:00
**Step 3**: Start veilid-server.service
2024-07-19 14:08:25 -05:00
Go to [Start headless node ](#start-headless-node )
2024-08-04 16:59:44 +00:00
**Step 4**: View Node Activity
2024-07-19 14:08:25 -05:00
Invoke the Veilid CLI utility.
2024-08-02 23:29:12 +00:00
Either add your user to the _veilid_ group and invoke the command
2024-07-19 14:08:25 -05:00
```shell
veilid-cli
```
2024-08-02 23:29:12 +00:00
Or use _sudo_ to invoke as the _veilid_ user
```shell
sudo -u veilid veilid-cli
```
2024-07-19 14:08:25 -05:00
2024-08-04 16:59:44 +00:00
### Setup Auto Updates
**Stable Releases**
We set the bootstrap nodes to check for updates every hour by using crontab
On a Debian based machine:
```shell
sudo crontab -e
```
In the editor that opens append:
```shell
2024-08-06 21:01:52 +00:00
0 * * * * apt -y update && apt -y upgrade --only-upgrade veilid-cli veilid-server > ~/auto_updates.log 2>& 1
2024-08-04 16:59:44 +00:00
```
**Nightly Releases**
The nightly auto release triggers at 11PM US Central Time. The following crontab exmaple will
trigger at 6AM for your machine's local time which should give plenty of time for the auto release
to complete no matter where you are in the world.
```shell
sudo crontab -e
```
In the editor that opens append:
```shell
* 6 * * * apt -y update && apt -y upgrade veilid-cli veilid-server > ~/auto_updates.log 2>& 1
```
**Fedora Based Machines**
The above steps should work, replace the apt commands with appropriate dnf commands.
2024-01-02 09:16:50 -08:00
### macOS
2024-08-04 16:59:44 +00:00
***Not maintained by the Veilid team. Seek assistance in the Discord community.***
2024-01-02 09:16:50 -08:00
Veilid is available [via Homebrew ](https://formulae.brew.sh/formula/veilid ).
```shell
brew install veilid
```
You can then run `veilid-server` and `veilid-cli` from the command line.
2023-09-11 22:21:40 +02:00
## Start headless node
2023-09-15 22:38:32 +02:00
### With systemd
To start a headless Veilid node, run:
2023-09-12 08:43:09 -05:00
2023-08-01 21:37:38 -05:00
```shell
2023-09-15 22:38:32 +02:00
sudo systemctl start veilid-server.service
2023-08-01 21:37:38 -05:00
```
2023-09-11 22:21:40 +02:00
2023-12-05 02:06:56 +00:00
*-OR-*
2023-09-15 22:38:32 +02:00
To have your headless Veilid node start at boot:
2023-09-11 22:21:40 +02:00
```shell
2023-09-15 22:38:32 +02:00
sudo systemctl enable --now veilid-server.service
2023-09-11 22:21:40 +02:00
```
2023-09-15 22:38:32 +02:00
### Without systemd
`veilid-server` must be run as the `veilid` user.
To start your headless Veilid node without systemd, run:
```shell
sudo -u veilid veilid-server
```
2024-04-22 14:52:47 +01:00
2024-08-14 08:32:08 -04:00
## Configuration
You can find the default location of the server configuration for your platform in the help text:
```shell
/path/to/veilid-server -h
```
Information on configuring veilid-server can be found in the [Developer Book ](https://veilid.gitlab.io/developer-book/admin/config.html ) and examples are available in [the doc directory ](https://gitlab.com/veilid/veilid/-/tree/main/doc/config ) of this repository.
### Logging
veilid-server has extensive logging functionality that can be configured via the configuration file or changed while running using veilid-cli's `change_log_level` command. The default log settings for veilid-server packages are:
- Linux - `INFO` log level to syslog (usually `/var/log/syslog` )
- Mac OS - `INFO` log level to syslog (usually `/var/log/system.log` )
2024-05-22 22:22:46 +01:00
## Network Considerations
2024-04-22 14:52:47 +01:00
2024-05-22 22:22:46 +01:00
> **note:** if you're interested in using a veilid-server node for local development, you're better off reading the [Developer Book](https://veilid.gitlab.io/developer-book/), though the implementation to enable local development using a veilid-server node is still forthcoming.
2024-06-06 10:25:56 +01:00
Veilid nodes need to be internet facing or behind a firewall that allows inbound connections via port 5150 for both TCP and UDP. This will allow veilid-server to access other nodes in the wider network since 5150 is the port that the process uses by default. If the port is not available, veilid-server will wait for it to become available.
2024-05-07 11:41:17 +01:00
2024-06-06 10:25:56 +01:00
In the event the listening port is not opened in the firewall, an application may still operate, though in a fairly degraded mode that relies on another node to relay incoming RPC messages to them.