2023-08-09 12:46:48 -06:00
# Installing Iceshrimp
2023-08-13 08:52:57 -06:00
2023-08-09 12:46:48 -06:00
This document will guide you through manual installation of Iceshrimp on dev branch, for main branch, use Firefish's installation guide.
## Dependencies
### Build
2023-08-13 08:52:57 -06:00
2023-08-09 12:46:48 -06:00
- C/C++ compiler like **GCC** or **Clang**
- Build tools like **make**
- **Python 3**
### Required
2023-08-13 08:52:57 -06:00
2023-08-09 12:46:48 -06:00
- [**Node.js** ](https://nodejs.org ) v18.16.0+ (v20 recommended)
2023-08-10 12:58:16 -06:00
- [**PostgreSQL** ](https://www.postgresql.org/ ) 12+
- [**Redis** ](https://redis.io/ ) 6+
2023-08-09 12:46:48 -06:00
- [**libvips** ](https://www.libvips.org/ )
- **Web proxy**
- nginx
- Caddy
### Optional
2023-08-13 08:52:57 -06:00
2023-08-09 12:46:48 -06:00
- [**FFmpeg** ](https://ffmpeg.org/ ) for video transcoding
- Full text search (Choose one)
Iceshrimp has full text search powered by Postgres by default, however it's very slow, and these are alternatives for that
- [**Meilisearch** ](https://www.meilisearch.com/ ) | [Installation guide ](https://www.meilisearch.com/docs/learn/getting_started/quick_start )
- [**Sonic** ](https://crates.io/crates/sonic-server ) (More lightweight, but less features) | [Installation guide ](https://github.com/valeriansaliou/sonic#installation )
## Preparations
### Download repository
2023-08-13 08:52:57 -06:00
2023-08-09 12:46:48 -06:00
```sh
2023-10-18 18:44:55 -06:00
git clone https://iceshrimp.dev/iceshrimp/iceshrimp.git --depth=1
2023-08-09 12:46:48 -06:00
```
### Creating a new user
2023-08-13 08:52:57 -06:00
2023-08-09 12:46:48 -06:00
In case you want to run Iceshrimp as a different user, run `adduser --disabled-password --disabled-login iceshrimp`
Following steps will require you to run them as the user you have made, so use `su - iceshrimp` , or `sudo -iu iceshrimp` , or whatever else method in order to temporarily log in as that user.
### Configuration
2023-08-13 08:52:57 -06:00
2023-08-09 12:46:48 -06:00
- Copy `.config/example.yml` to `.config/default.yml`
- Edit `.config/default.yml` with text editor
- Make sure to set PostgreSQL and Redis section correctly
2023-11-05 07:00:19 -07:00
- Make sure to set/uncomment text search sections if you have chosen to set up a search backend
2023-08-09 12:46:48 -06:00
## Installing project dependencies
2023-08-13 08:52:57 -06:00
2023-11-05 07:19:40 -07:00
This project uses corepack to manage yarn versions, please make sure you don't have a globally installed non-corepack yarn binary (e.g. by having run `npm install -g yarn` in the past, or via your operating system's package manager)
2023-08-09 12:46:48 -06:00
```sh
corepack enable
2023-11-05 07:19:40 -07:00
corepack prepare --activate
2023-08-09 12:46:48 -06:00
yarn
```
## Building Iceshrimp
2023-08-13 08:52:57 -06:00
2023-08-09 12:46:48 -06:00
```sh
yarn build
```
## Database
2023-08-13 08:52:57 -06:00
2023-08-09 12:46:48 -06:00
### Creating database
2023-08-13 08:52:57 -06:00
2023-08-09 12:46:48 -06:00
This will create a postgres user with your password and database, while also granting that user all privileges on database.
Using `psql` prompt:
```sh
sudo -u postgres psql
```
```postgresql
create database iceshrimp with encoding = 'UTF8';
create user iceshrimp with encrypted password '{YOUR_PASSWORD}';
grant all privileges on database iceshrimp to iceshrimp;
\q
```
### First migration
2023-08-13 08:52:57 -06:00
2023-08-09 12:46:48 -06:00
In order for Iceshrimp to work properly, you need to initialise the database using
```bash
yarn run init
```
2023-10-07 09:09:18 -06:00
### Optimizing performance
For optimal database performance, it's highly recommended to configure PostgreSQL with [PGTune ](https://pgtune.leopard.in.ua/ ) using the "Mixed type of application" profile. This is especially important should your database server use HDD instead of SATA or NVMe SSD storage.
2023-08-09 12:46:48 -06:00
## Setting up Webproxy
2023-08-13 08:52:57 -06:00
2023-08-09 12:46:48 -06:00
### Nginx
2023-08-13 08:52:57 -06:00
2023-08-09 12:46:48 -06:00
- Run `sudo cp docs/examples/iceshrimp.nginx.conf /etc/nginx/sites-available/ && cd /etc/nginx/sites-available/`
- Edit `iceshrimp.nginx.conf` to reflect your server properly
- Run `sudo ln -s ./iceshrimp.nginx.conf ../sites-enabled/iceshrimp.nginx.conf`
- Run `sudo nginx -t` to check that the config is valid, then restart the nginx service.
### Caddy
2023-08-13 08:52:57 -06:00
2023-08-09 12:46:48 -06:00
- Add the following to your Caddyfile, and replace `example.com` with your domain
```
example.com {
reverse_proxy localhost:3000
}
```
## Running Iceshrimp
### Running manually
2023-08-13 08:52:57 -06:00
2023-08-10 12:58:16 -06:00
- Start Iceshrimp by running `NODE_ENV=production yarn run start` .
2023-08-09 12:46:48 -06:00
If this is your first run, after Iceshrimp has started successfully, you'll be able to go to the URL you have specified in `.config/default.yml` and create first user.
- To stop the server, use `Ctrl-C` .
### Running using systemd
2023-08-13 08:52:57 -06:00
2023-08-09 12:46:48 -06:00
- Run `sudo cp docs/examples/iceshrimp.service /etc/systemd/system/`
- Edit `/etc/systemd/system/iceshrimp.service` with text editor, and change `User` , `WorkingDir` , `ExecStart` if necessary.
- Run `sudo systemctl daemon-reload`
- Run `sudo systemctl enable --now iceshrimp` in order to enable and start Iceshrimp.
- (Optional) Check if instance is running using `sudo systemctl status iceshrimp`
### Updating Iceshrimp
2023-08-13 08:52:57 -06:00
2023-08-09 12:46:48 -06:00
Shut down Iceshrimp and then run these commands
```sh
2023-08-10 12:58:16 -06:00
## Run git stash commands only if you have uncommitted changes
2023-08-09 12:46:48 -06:00
git stash
git pull
git stash pop
yarn
2023-08-10 12:58:16 -06:00
yarn build & & yarn migrate
2023-08-09 12:46:48 -06:00
```
Start Iceshrimp back up
## Post-install
2023-08-13 08:52:57 -06:00
2023-08-09 12:46:48 -06:00
See [post-install ](post-install.md ).