11 KiB
Notice for server administrators
You can skip intermediate versions when upgrading from an old version, but please read the notices and follow the instructions for each intermediate version before upgrading.
Unreleased
For all users
Upgrading may take a long time due to the large changes in the database. Please make sure to perform the operations when you have time.
The time required to upgrade varies greatly depending on the database size and the environment. For reference, we have checked that the database migration takes
- 70 seconds if the database stores 600,000 posts
- 28 minutes if the database stores 12,000,000 posts
(i.e., it takes roughly (𝑛 / 470,000) minutes where 𝑛 is the number of posts) on a server with 2 GB of RAM. You may want to tweak your database configuration (postgres.conf
) if the process is significantly slower than our experimental result.
The number of posts stored on your database can be found at https://yourserver.example.com/admin/database
(or notesCount
of stats
API response).
For systemd/pm2 users
Please do not terminate pnpm run migrate
even if it appears to be frozen.
For Docker/Podman users
You may not be able to access your server for a while after starting the container.
v20240326
For Docker/Podman users
The Firefish OCI container image is now based on docker.io/node:20-alpine
(migrated from Debian to Alpine). This is a notification only and no action is required.
v20240319
The full-text search engine used in Firefish has been changed to PGroonga. This is no longer an optional feature, so please enable PGroonga on your system. If you are using Sonic, Meilisearch, or Elasticsearch, you can also uninstall it from your system and remove the settings from .config/default.yml
.
For systemd/pm2 users
- Required Node.js version has been bumped from v18.16.0 to v18.17.0.
- You need to install PGroonga on your system. Please follow the instructions below.
[Edit (2024/03/23 23:55 UTC+9)] Warning: You may fail to install PGroonga, since the package registry of Apache Arrow (one of the subdependencies of PGroonga) is currently down (GitHub issue). We recommend that you hold off on upgrading until this problem is resolved.
[Edit (2024/03/25 22:31 UTC+9)] The Apache Arrow repository is now back up and running again.
1. Install PGroonga
Please execute psql --version
to check your PostgreSQL major version. This will print a message like this:
psql (PostgreSQL) 16.1
In this case, your PostgreSQL major version is 16
.
There are official installation instructions for many operating systems on https://pgroonga.github.io/install, so please follow the instructions on this page. However, since many users are using Ubuntu LTS or Debian, and there are no instructions for Arch Linux and Fedora, we explicitly list the instructions for Ubuntu LTS, Debian, Arch Linux and Fedora here. Please keep in mind that this is not official information and the procedures may change.
Ubuntu LTS
- Install subdependencies
sudo apt install -y software-properties-common sudo add-apt-repository -y universe sudo add-apt-repository -y ppa:groonga/ppa sudo apt install -y wget lsb-release wget https://packages.groonga.org/ubuntu/groonga-apt-source-latest-$(lsb_release --codename --short).deb sudo apt install -y -V ./groonga-apt-source-latest-$(lsb_release --codename --short).deb
- Install PGroonga (replace
16
with your PostgreSQL version)sudo apt install postgresql-16-pgdg-pgroonga # Depending on your PostgreSQL installation method, # the above command may fail and you need to run # the following instead: # sudo apt install postgresql-16-pgroonga
Debian
- Install subdependencies
sudo apt install -y -V ca-certificates lsb-release wget wget https://apache.jfrog.io/artifactory/arrow/$(lsb_release --id --short | tr 'A-Z' 'a-z')/apache-arrow-apt-source-latest-$(lsb_release --codename --short).deb sudo apt install -y -V ./apache-arrow-apt-source-latest-$(lsb_release --codename --short).deb wget https://packages.groonga.org/debian/groonga-apt-source-latest-$(lsb_release --codename --short).deb sudo apt install -y -V ./groonga-apt-source-latest-$(lsb_release --codename --short).deb
- Install PGroonga (replace
16
with your PostgreSQL version)sudo apt install postgresql-16-pgdg-pgroonga # Depending on your PostgreSQL installation method, # the above command may fail and you need to run # the following instead: # sudo apt install postgresql-16-pgroonga
Arch Linux
You can install PGroonga from the Arch User Repository.
git clone https://aur.archlinux.org/pgroonga.git && cd pgroonga && makepkg -si
# or paru -S pgroonga
# or yay -S pgroonga
Fedora
You need to build PGroonga from source and create a policy package.
sudo dnf install make groonga-devel postgresql-server-devel redhat-rpm-config
wget https://packages.groonga.org/source/pgroonga/pgroonga-3.1.8.tar.gz
tar xvf pgroonga-3.1.8.tar.gz
cd pgroonga-3.1.8
make
sudo make install
cat > pgroonga.te << EOF
module pgroonga 1.0;
require {
type postgresql_t;
type postgresql_db_t;
class file map;
}
allow postgresql_t postgresql_db_t:file map;
EOF
checkmodule -M -m -o pgroonga.mod pgroonga.te
semodule_package -o pgroonga.pp -m pgroonga.mod
sudo semodule -i pgroonga.pp
2. Enable PGroonga
After the instllation, please execute this command to enable PGroonga:
sudo --user=postgres psql --dbname=your_database_name --command='CREATE EXTENSION pgroonga;'
The database name can be found in .config/default.yml
.
db:
port: 5432
db: database_name # substitute your_database_name with this
user: firefish
pass: password
For Docker/Podman users
Please edit your docker-compose.yml
to replace the database container image from docker.io/postgres
to docker.io/groonga/pgroonga
.
The list of tags can be found on https://hub.docker.com/r/groonga/pgroonga/tags. Tags are named as {PGroonga version}-{alpine or debian}-{PostgreSQL major version}
.
Please make sure to use the same PostgreSQL version. If you are using docker.io/postgres:16-alpine
(PostgreSQL v16), the corresponding image is docker.io/groonga/pgroonga:3.1.8-alpine-16
(or docker.io/groonga/pgroonga:3.1.8-alpine-16-slim
). There are also tags called latest-alpine-16
and latest-alpine-16-slim
, but please be careful if you use these tags since PGroonga may introduce breaking changes, similar to PostgreSQL.
db:
restart: unless-stopped
image: docker.io/groonga/pgroonga:3.1.8-alpine-16-slim # change here
container_name: firefish_db
After that, execute this command to enable PGroonga:
docker-compose up db --detach && sleep 5 && docker-compose exec db sh -c 'psql --user="${POSTGRES_USER}" --dbname="${POSTGRES_DB}" --command="CREATE EXTENSION pgroonga;"'
# or podman-compose up db --detach && sleep 5 && podman-compose exec db sh -c 'psql --user="${POSTGRES_USER}" --dbname="${POSTGRES_DB}" --command="CREATE EXTENSION pgroonga;"'
Once this is done, you can start Firefish as usual.
docker pull registry.firefish.dev/firefish/firefish && docker-compose up --detach
# or podman pull registry.firefish.dev/firefish/firefish && podman-compose up --detach
v20240301
For all users
A new setting item has been added to control the log levels, so please consider updating your .config/default.yml
. (example settings)
v20240225
For Docker/Podman users
- The bug where
custom
directory was not working has (finally) been fixed. Please add thecustom
directory tovolumes
in yourdocker-compose.yml
:services: web: image: registry.firefish.dev/firefish/firefish:latest # and so on ... volumes: - ./custom:/firefish/custom:ro # <- Please add this line - ./files:/firefish/files - ./.config:/firefish/.config:ro
v20240222
For Docker/Podman users
- You only need to pull the new container image (
docker/podman pull
) to upgrade your server, so we assume that many of you don't update the code (git pull --ff
), but it's still worth noting here that we have renameddocker-compose.yml
todocker-compose.example.yml
in the repository, anddocker-compose.yml
is now set to be untracked by git.- Since
docker-compose.yml
may be edited by users (e.g., change port number, add reverse proxy), it shouldn't have been tracked by git in the first place. - If you want to update the repository (
git pull --ff
), please take the following steps to keep yourdocker-compose.yml
:- Backup (make a copy) your
docker-compose.yml
cp docker-compose.yml /tmp/my-docker-compose.yml # or somewhere else
- Restore the original
docker-compose.yml
so it doesn't conflict with the upstream changesgit checkout -- docker-compose.yml
- Pull the new code
git switch main git pull --ff
- Bring back your
docker-compose.yml
mv /tmp/my-docker-compose.yml docker-compose.yml
- Backup (make a copy) your
- If any modifications are needed to
docker-compose.yml
in the future, we will provide a notice. - Also, PostgreSQL v12.2 (
docker.io/postgres:12.2-alpine
) has been used in this compose file, but we highly recommend that you upgrade it to a newer version (e.g.,docker.io/postgres:16-alpine
).- Note: some manual (painful) operations are needed to upgrade the PostgreSQL major version, so please be careful when performing upgrades: https://github.com/docker-library/postgres/issues/37
- Since
v20240214
For systemd/pm2 users
- Required Rust version has been bumped from v1.70 to v1.74.
cargo --version # check version rustup update # update version
v20240213
For systemd/pm2 users
-
packages/backend/native-utils
can be removed.- This directory was removed in the repository, but it's not completely removed from your system by
git pull --ff
, because some folders likepackages/backend/native-utils/built
are not tracked by git.
rm --recursive --force packages/backend/native-utils
- This directory was removed in the repository, but it's not completely removed from your system by
v20240206
For all users
- The git repository has been moved, so please update the
git remote
url.git remote set-url origin https://firefish.dev/firefish/firefish.git
For systemd/pm2 users
- Required Rust version has been bumped from v1.68 to v1.70.
libvips
is no longer required (unless your server OS is *BSD), so you may uninstall it from your system. Make sure to execute the following commands after that:pnpm clean-npm pnpm install
For Docker/Podman users
- The image tag has been changed to
registry.firefish.dev/firefish/firefish:latest
, so please updatedocker-compose.yml
.