Skip to content

FSI Server Installation Repository - Standalone web server for high-speed automatic image resizing, manipulation and conversion from various formats to JPEG, WebP, PNG or GIF in real time.

Notifications You must be signed in to change notification settings

neptunelabs/fsi-server-docker-v22

Repository files navigation

FSI Server Container Setup

(valid until version 22.x)

alt text

What is FSI Server? · Requirements · How to use this repository · Synchronisation to mirror servers with lsyncd · Backup · Nginx and SSL/TLS Certificates · Bottlenecks · Benchmark · What's next? · Licensing · Quick reference


What is FSI Server?

FSI Server dynamically generates images in a variety of formats, sizes and qualities - in real time. You only need to upload one high-resolution source image for each image used on a website, eliminating costly and time-consuming manual image preparation. Variations are retrieved by a web application directly from FSI Server using HTTP queries. FSI Server provides a comprehensive set of HTTP commands that allow full control over the image data delivered.

In addition, the FSI Server comes with a variety of viewers that make integration into existing websites very easy.

Requirements

From version 16 FSI Server is available as a pre-configured container. This allows setting up the software on many more platforms, reduces the setup efforts to a minimum and enables software updates with very little downtime.

Users of FSI Server with Tomcat/WAR (Web Application Archive) installations are strongly advised to upgrade to the container version.

Containers are currently shipped for x86-64 architectures.

At least 2 GB of RAM per CPU thread and a total amount of 8 GB RAM are recommended. For production environments with millions of images, systems with more than 32GB of RAM are recommended. Monitor the log output to identify any bottlenecks.

How to use this repository

This repository contains a docker compose file for Docker Compose V2 or higher.

Depending on the version, perform typical start/stop as follows.

docker compose up --build -d
docker compose down

If you are new to docker or docker compose commands, you might want to read the documentation first.

Web Interface

After starting the containers, the FSI Server can be reached via a web interface. The default ports are 80 and 443. When the server is started locally, it is accessible as follows, with invalid certificates:

https://localhost/

compose.yaml and .env

This repository comes with a compose.yaml file that contains Apache Solr for internal search, nginx for SSL termination and lsyncd for synchronisation. You are free to replace nginx with your own preferred SSL termination server, such as Caddy, Traefik or Hitch.

It also contains invalid, but necessary for a first start, SSL certificates for localhost. You should replace them with valid certificates for your domain for production purposes.

The compose.yaml contains variable assignments from the file .env. Please adjust the file according to your needs, i.e. the path for the source files and the storage, the configuration, etc. The variables mean:

VARIABLE DESCRIPTION
FSI_SERVER_IMAGE_TAG the version you want to use or can use (depending on the licence)
NGINX_IMAGE_TAG Docker version tag for the nginx container
FSI_CONFIG_PATH path in your filesystem for the FSI Server configuration
NGINX_CONFIG_PATH path to the nginx configuration and certificated
ASSET_PATH path in your filesystem for all your images and static assets
STORAGE_PATH path in your filesystem for all images optimised for real-time scaling
OVERLAY_PATH config folder for all FSI Viewer settings
SOLR_PATH path for FSI Server solr core index and data
SOLR_SERVER_URI HTTP path to connect to the Apache Solr server
LOG_PATH path where all log files are stored
LOG_FSI_LEVEL log output verbosity
SYNC_KEY path to the lsyncd private key
MIRROR_HOSTNAME domain name or IP of the mirror server
MIRROR_SSH_PORT SSH port of the mirror server

Directory: conf/fsi-server

All relevant settings of the FSI Server can be found in this directory. The server uses a highly configurable combination of permission sets and groups to control access to stored assets. The container needs write access to this directory because user data from the server can be stored here.

You can create new connectors, groups or users here and manage the permissions for them.

FILE SETTING DESCRIPTION
settings.yml Basic settings, storage location and the default size of the rendered images. For these container installations, you should leave this file untouched.
users.yml Users and their passwords and, if applicable, the 2FA Secret
groups.yml User and rights assignments to a group
permissionsets.yml Permission settings for user groups and for connectors
interface.yml Settings for the Web Interface
headers.yml Presets for HTTP header overwrites
connectors/*.yml Mapping for local paths to addressable paths via FSI Server
renderers/*.yml Encoder presets for retrieving rendered images

This demo repository contains the images and a statics directory under fsi-data/assets and the corresponding connectors which you can find in the connectors directory. To add more mappings just copy one of these connectors, change the origin.location and make sure that you choose the correct type (storage for dynamic rendered images and static for immutable assets).

Directory: conf/nginx

The configuration for the nginx container. The start-up script generates certificates for localhost in the certificates folder at start-up.

Directory: conf/lsyncd

The configuration for the lsyncd container if you use the compose file for mirror servers.

Directory: fsi-data/assets

Contains sample assets that corresponding to the two connectors supplied. The images folder contains images that can be rendered dynamically. The statics folder contains files that are delivered unchanged, for example .mp4, .pdf or .html or image files.

The path can be adjusted via the .env variable ASSET_PATH.

Directory: fsi-data/storage

(exists after start the container)

This directory contains the so-called storage, which contains optimised versions of all assets. The path can be adjusted via the .env variable STORAGE_PATH.
⚠️ This folder is mandatory persistent, should not be lost and can be about the same size as all the folders addressed in the connectors.

Directory: fsi-data/solr-core

The internal search of the FSI server requires an external Apache Solr server. This directory therefore contains the so-called Solr core, which defines the mapping of the image metadata.

If the core is not present, it will be created again when the fsi-server container is restarted.

Directory: fsi-data/overlay

(exists after start the container)

The FSI Viewer can make use of ready-made presets and skins. These are stored in this directory. The path can be changed via the variable OVERLAY_PATH.

Directory: fsi-data/logs

(exists after start the container)

Log files for the FSI server, nginx and, if applicable, lsyncd are stored centrally here. The path can be changed via the variable LOG_PATH.

Directory: container

The containers for nginx, lsync and the benchmark are built using the files in this directory. Normally it is not necessary to make adjustments here.Normalerweise ist es nicht notwendig hier Anpassungen vorzunehmen.

Where to put my pictures?

For test purposes, you can store your images to fsi-data/assets/images and your static files (like videos or PDF files) to fsi-data/assets/statics. For production environments, place the images where it is best for backup and synchronisation tasks. Then create or change connectors under conf/fsi-server/connectors, according to the mappings in the compose.yaml.

kubernetes

Apart from docker or Podman, you can also run the containers in a k8s environment. The important thing here is access to the assets and the storage. These should be connected as efficiently as possible. In the case of k8s, this may include atypical local storage.

If you connect an S3 storage via e.g. s3fs-fuse or mountpoint, we recommend benchmarks (see below) for filling with images and retrieving them before going live.

Synchronisation to mirror servers with lsyncd

If you do not operate a second, third or further mirror server, you can ignore all information in this section.

However, if you want to run more than one image server with the same assets, which is actually obligatory for productive purposes, you need to synchronise not only the images between the servers, but also new asset metadata and viewer configurations. Depending on your setup, you may also want to synchronise the server configuration.

If you are not using a distributed file system, lsyncd can be used as a synchronisation tool. Lsyncd is reliable and proven, and allows very complex settings through Lua script-based configuration.

Configuration

This is based on the compose-with-mirror.yaml compose file, which also provides a lsyncd service.

On the target systems, ssh and rsync are required.

An SSH Key is used to authenticate. The configuration of the lsyncd daemon are provided in the conf/lsyncd directory.

For production use, you will need to change MIRROR_HOSTNAME for the remote server in .env. The paths should be in the same place, otherwise the file conf/lsyncd/lsyncd.conf.lua must be adapted accordingly, e.g. like this:

sync {
  target = "fsi-secondary.domain.tld:/data/fsi-data/overlay",
}

If necessary, you should leave the source and rsh configuration as is, or only adjust it if your compose.yaml is modified accordingly.

SSH key generation

For example, the SSH key can be generated using this command

ssh-keygen -t ed25519 -q -N "" -o -C "fsi-sync-key@$(hostname)" -f ./conf/lsyncd/sync.key

and transferred with this:

ssh-copy-id -i ./conf/lsyncd/sync.key user@fsi-secondary.domain.tld

After changing the configuration, you need to restart the lsyncd container and check that everything works as expected:

docker restart lsyncd
docker logs -f lsyncd

If you also want to synchronise the configuration of the FSI server or nginx, you will need to add another sync section to lsycd.conf.lua which will contain the paths to their configurations.

Anti-Pattern

You may be tempted to synchronise the fsi-data directory with storage. Although this works in principle by disabling the scanner on the mirror instances, it is still not a good idea.

The technical background lies in the internal, RAM-based caches of the FSI server. In the case of accesses to assets that are being synchronised, the server mirror server returns a 5xx error because it does not know about the internal status of the asset.

Synchronisation is also not a good idea in case of errors in storage processing.

Even if it means a higher load per mirror server, you should not transfer the storage.

Backup

Of course, depending on how the images arrive at the image server, you should back up your images. In any case, you should also back up the conf/fsi-server directory, as the server licence, the created users and connectors are stored there.

In addition, the $OVERLAY_PATH and $STORAGE_PATH/metadata should be saved. The search database does not need to be included, as it is automatically rebuilt after a restore.

Does it make sense to back up the storage?

This depends very much on how fast your server is, how many images you have and whether or how many mirror servers you have.

If you have a lot of images, it can take a very long time until a storage is ready for productive use again. And it may be that the restore time without rebuild is considerably shorter, if the storage is backed up. This problem can be significantly reduced by using mirror servers.

Nginx and SSL/TLS Certificates

The Nginx configuration in conf/nginx is prepared for LetsEncrypt certificates. Of course, certificates without Let’s Encrypt can also be used.

It is assumed that certbot is installed on the system.

For Let's Encrypt an additional directory should be created for the HTTP-01 Challenge.

mkdir ./conf/nginx/acme

If nginx is running, then a certificate can be generated via certbot:

certbot certonly --webroot \
-w ./conf/nginx/acme \
-d fsi.domain.tld \
--agree-tos \
-m my@email.tld

Then the Let's Encrypt directory must be included in the nginx container:

  nginx:
    volumes:
      - /etc/letsencrypt/live:/etc/letsencrypt/live

Finally, the file conf/nginx/sites/fsi-server.conf must be adapted:

ssl_certificate /etc/letsencrypt/live/fsi.domain.tld/fullchain.pem;
ssl_certificate_key /etc/letsencrypt/live/fsi.domain.tld/privkey.pem;
ssl_trusted_certificate /etc/letsencrypt/live/fsi.domain.tld/chain.pem;

Bottlenecks

FSI Server is a monolithic application, but it is highly parallelized internally. Even with individual image requests, both the CPU and the I/O system can be utilised to capacity through this parallelization.

Basically, the FSI servers tend to be I/O bound if they use a strong CPU.

In practice, therefore, the use of a powerful I/O system is necessary if you have high loads with millions of hits per day and possibly millions of images.

Local SSD or NVMe are not essential, but helpful. However, for very large numbers of images, customers often use spinning discs for cost reasons, which is usually sufficient.

Benchmark

To help you assess whether your system is fast enough, we have put together a useful benchmark based on fio and sysbench. It respects the settings of ASSET_PATH and STORAGE_PATH in the .env file.

To start the test, the benchmark.yaml is executed as a compose file, e.g. as follows. The test takes about 4 minutes and requires at least 5GB of hard disk space.

docker compose -f benchmark.yaml run --rm benchmark

A result will look like this:

CPU-1            : 90.72 ops/sec
CPU-MAX          : 1383.10 ops/sec
MEMORY           : 7419.45 MiB/sec
I/O BW Assets    : 166 MB/sec
I/O IOPS Assets  : 39959 IOPS
I/O Storage      : 217 MB/sec
I/O IOPS Storage : 53023 IOPS

How to interpret the values?

CPU-1 - ops/sec

This test tests classically via the calculation of prime numbers. The test is performed on a single thread/core. It indicates how fast a thread can work and corresponds to the clock frequency and performance of the processor.

CPU-MAX - ops/sec

The same test, but using all available threads/cores.

MEMORY - MiB/sec

The RAM throughput with one thread is tested.

I/O - BW

Corresponds to the measured read bandwidth on this device. The test is performed separately for ASSET_PATH and STORAGE_PATH.

I/O - IOPS

Corresponds to the measured I/O operations per second on this device. The test is also performed separately for ASSET_PATH and STORAGE_PATH.

Recommendations

In order to assess the values obtained the following recommendations are based on our many years of experience with FSI Server.

Minimum should not be undercut, except perhaps for demo purposes. For productive use of medium-sized websites and the use of single source imaging, the medium values are at least required.

Individual values can also be undercut and are strongly dependent on the use of the FSI Server.

Type CPU-1 ops/sec CPU-MAX ops/sec MEMORY MiB/sec I/O BW I/O IOPS
Minimum 10 250 2000 30 10000
Medium 15 700 3000 100 25000
Recommended 20 1000 4000 200 50000

What's next?

Using Single Source and FSI Viewer

The FSI Viewer, included in the FSI Server, offers zoom, 360° rotation, page flipping in brochures, showcases, video/image combinations and more. Product presentations become more vivid and compelling as you can view the product from all sides and explore every from all sides and explore every detail of an image with fast, smooth zooming.

The viewer can be used on any device, including standard desktop touchscreen displays, smartphones and tablets.

You can now benefit from the many features of FSI Server. Learn how to use the server efficiently with your website by consulting our various repositories.

Here are just a few:

When you use FSI Server with our dynamic Single Source Imaging (SSI) technology, you only need to provide one high-resolution source image for every image used on a website. FSI Server dynamically generates images in different formats, sizes and qualities on the fly.

The Image Repository shows you how to create a website front page using SSI:

SSI Image 1


You can also implement zoom on your website images, for example with the fly-out zoom shown in the FSI QuickZoom repository:

QuickZoom Image 1


or the Zoom and Pan function in the FSI Viewer repository:

Zoom Image 1

But that's not all. Explore the other repositories to learn about various other features such as

Interactive Brochures in the FSI Pages repository:

Pages Image 1

or extensive configurator options in the FSI Layers repository:

Layers Image 1

To learn more about the features and how to use them, including tutorials for each viewer, you can also browse our documentation section.

Licensing

You can use and try the software for as long as you like. There are no feature restrictions or performance limitations in the unregistered version, except that watermarks are displayed. We also provide a free 60-day trial key without watermarks, you can see how to get one here.


Quick reference